tux-droid-svn Mailing List for Tux Droid CE (Page 46)
Status: Beta
Brought to you by:
ks156
You can subscribe to this list here.
| 2007 |
Jan
|
Feb
(32) |
Mar
(108) |
Apr
(71) |
May
(38) |
Jun
(128) |
Jul
(1) |
Aug
(14) |
Sep
(77) |
Oct
(104) |
Nov
(90) |
Dec
(71) |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 2008 |
Jan
(81) |
Feb
(18) |
Mar
(40) |
Apr
(102) |
May
(151) |
Jun
(74) |
Jul
(151) |
Aug
(257) |
Sep
(447) |
Oct
(379) |
Nov
(404) |
Dec
(430) |
| 2009 |
Jan
(173) |
Feb
(236) |
Mar
(519) |
Apr
(300) |
May
(112) |
Jun
(232) |
Jul
(314) |
Aug
(58) |
Sep
(203) |
Oct
(293) |
Nov
(26) |
Dec
(109) |
| 2010 |
Jan
(19) |
Feb
(25) |
Mar
(33) |
Apr
(1) |
May
|
Jun
(3) |
Jul
|
Aug
|
Sep
|
Oct
|
Nov
|
Dec
|
|
From: remi <c2m...@c2...> - 2009-06-26 08:52:54
|
Author: remi
Date: 2009-06-26 10:52:47 +0200 (Fri, 26 Jun 2009)
New Revision: 4905
Modified:
software_suite_v3/smart-core/smart-server/trunk/util/scheduler/Task.py
Log:
* fixed bug (Task every x from full hour with delay of 1 hour, when the server is launched between 00H and 01H ...) I am lucky to saw this bug ...
Modified: software_suite_v3/smart-core/smart-server/trunk/util/scheduler/Task.py
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/util/scheduler/Task.py 2009-06-26 08:49:28 UTC (rev 4904)
+++ software_suite_v3/smart-core/smart-server/trunk/util/scheduler/Task.py 2009-06-26 08:52:47 UTC (rev 4905)
@@ -50,17 +50,20 @@
self.__monthAtStart = now.month
self.__monthMask = self.__createMonthMask(self.__monthAtStart)
if ruleType == SCH_LOOP_ABS:
+ hourFixe = now.hour - delay[0]
+ if hourFixe < 0:
+ hourFixe = 0
if delay[0] == 0:
if delay[1] == 0:
m = 0
else:
m = int(now.minute / delay[1]) * delay[1]
self.__startTime = datetime.datetime(now.year, now.month,
- now.day, now.hour - delay[0], m, delay[2])
+ now.day, hourFixe, m, delay[2])
self.__incrementTime = datetime.timedelta(minutes = delay[1])
else:
self.__startTime = datetime.datetime(now.year, now.month,
- now.day, now.hour - delay[0], delay[1], delay[2])
+ now.day, hourFixe, delay[1], delay[2])
self.__incrementTime = datetime.timedelta(hours = delay[0])
elif ruleType == SCH_LOOP_REL:
self.__startTime = datetime.datetime.now()
|
|
From: remi <c2m...@c2...> - 2009-06-26 08:49:36
|
Author: remi
Date: 2009-06-26 10:49:28 +0200 (Fri, 26 Jun 2009)
New Revision: 4904
Modified:
software_suite_v3/smart-core/smart-server/trunk/util/applicationserver/plugin/PluginParameter.py
Log:
* fixed parameters "enum" and "booleans" type parsing. (Now accept the () inside the enumerations)
Modified: software_suite_v3/smart-core/smart-server/trunk/util/applicationserver/plugin/PluginParameter.py
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/util/applicationserver/plugin/PluginParameter.py 2009-06-25 18:42:56 UTC (rev 4903)
+++ software_suite_v3/smart-core/smart-server/trunk/util/applicationserver/plugin/PluginParameter.py 2009-06-26 08:49:28 UTC (rev 4904)
@@ -53,12 +53,16 @@
self.__enumValuesList = []
if self.__type.lower().find("enum") == 0:
self.__type = "enum"
- self.__enumValues = self.__dictionary['type'].split("(")[1][:-1]
+ idxb = self.__dictionary['type'].find("(") + 1
+ idxe = self.__dictionary['type'].rfind(")")
+ self.__enumValues = self.__dictionary['type'][idxb:idxe]
for value in self.__enumValues.split(","):
self.__enumValuesList.append(value.strip())
elif self.__type.lower().find("booleans") == 0:
self.__type = "booleans"
- self.__enumValues = self.__dictionary['type'].split("(")[1][:-1]
+ idxb = self.__dictionary['type'].find("(") + 1
+ idxe = self.__dictionary['type'].rfind(")")
+ self.__enumValues = self.__dictionary['type'][idxb:idxe]
for value in self.__enumValues.split(","):
self.__enumValuesList.append(value.strip())
else:
|
|
From: jerome <c2m...@c2...> - 2009-06-25 18:43:04
|
Author: jerome
Date: 2009-06-25 20:42:56 +0200 (Thu, 25 Jun 2009)
New Revision: 4903
Modified:
software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/src/net/karmaLab/tuxDroid/plugins/WeatherPlugin.java
Log:
* Fixed a tts bug.
Modified: software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/src/net/karmaLab/tuxDroid/plugins/WeatherPlugin.java
===================================================================
--- software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/src/net/karmaLab/tuxDroid/plugins/WeatherPlugin.java 2009-06-25 18:16:18 UTC (rev 4902)
+++ software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/src/net/karmaLab/tuxDroid/plugins/WeatherPlugin.java 2009-06-25 18:42:56 UTC (rev 4903)
@@ -172,10 +172,10 @@
humidity = humidity.split(":")[1]; //$NON-NLS-1$
humidity = ((String) humidity.subSequence(0, humidity.length() - 1)).trim();
if (weather.length() == 0) {
- throwMessage("Current weather at {0} is \"unknown\" with a temperature of {1} degrees {2}; Humidity level is {3} percent.", configuration().getLocation(), temperature, configuration().getUnit() == Unit.celsius ? "celsius" : "fahrenheit",
+ throwMessage("Current weather at {0} is \"unknown\" with a temperature of {1} degrees {2}; Humidity level is {3} percent.", configuration().getLocation().replace("%20", " "), temperature, configuration().getUnit() == Unit.celsius ? "celsius" : "fahrenheit",
humidity);
} else {
- throwMessage("Current weather at {0} is \"{1}\" with a temperature of {2} degrees {3}; Humidity level is {4} percent.", configuration().getLocation(), weather, temperature, configuration().getUnit() == Unit.celsius ? "celsius" : "fahrenheit",
+ throwMessage("Current weather at {0} is \"{1}\" with a temperature of {2} degrees {3}; Humidity level is {4} percent.", configuration().getLocation().replace("%20", " "), weather, temperature, configuration().getUnit() == Unit.celsius ? "celsius" : "fahrenheit",
humidity);
}
|
|
From: jerome <c2m...@c2...> - 2009-06-25 18:16:25
|
Author: jerome Date: 2009-06-25 20:16:18 +0200 (Thu, 25 Jun 2009) New Revision: 4902 Added: software_suite_v3/software/plugin/plugin-system/ software_suite_v3/software/plugin/plugin-system/branches/ software_suite_v3/software/plugin/plugin-system/tags/ software_suite_v3/software/plugin/plugin-system/trunk/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/LICENSE software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/build.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/PluginPackager.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/__init__.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/__init__.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/DirectoriesAndFilesTools.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/__init__.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/version.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/version.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/executables/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/executables/plugin-system.py software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.po software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.wiki software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.po software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.wiki software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.po software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.wiki software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/help.wiki software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.po software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.wiki software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.png software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.pot software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.xml Log: * Added plugin-system. Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/LICENSE =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/LICENSE (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/LICENSE 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,340 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + <one line to give the program's name and a brief idea of what it does.> + Copyright (C) <year> <name of author> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + <signature of Ty Coon>, 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/build.py =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/build.py (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/build.py 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,11 @@ +# -*- coding: utf-8 -*- + +# Copyright (C) 2009 C2ME Sa +# Remi Jocaille <rem...@c2...> +# Distributed under the terms of the GNU General Public License +# http://www.gnu.org/copyleft/gpl.html + +from builder.PluginPackager import PluginPackager + +if __name__ == "__main__": + PluginPackager().createScp("plugin-system.scp") Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/PluginPackager.py =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/PluginPackager.py (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/PluginPackager.py 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,78 @@ +# -*- coding: utf-8 -*- + +import version +__author__ = version.author +__date__ = version.date +__version__ = version.version +__licence__ = version.licence +del version + +# Copyleft (C) 2009 C2ME Sa +# Remi Jocaille <rem...@c2...> +# Distributed under the terms of the GNU General Public License +# http://www.gnu.org/copyleft/gpl.html + +import os +from zipfile import * + +from util.misc.DirectoriesAndFilesTools import * + +# ------------------------------------------------------------------------------ +# Class to create a SCP file from the main directory of a python plugin project. +# ------------------------------------------------------------------------------ +class PluginPackager(object): + """Class to create a SCP file from the main directory of a python plugin + project. + """ + + # -------------------------------------------------------------------------- + # Create a scp file. + # -------------------------------------------------------------------------- + def createScp(self, scpFileName): + """Create a scp file. + @param scpFileName: Smart-Core Plugin file name. + @return: The success of the file creation. + """ + self.__sourcePath = os.path.realpath("") + if not os.path.isdir(self.__sourcePath): + return False + if not os.path.isdir(os.path.join(self.__sourcePath, "executables")): + return False + if not os.path.isdir(os.path.join(self.__sourcePath, "resources")): + return False + # Get some paths + SRC_EXECUTABLES_PATH = os.path.join(self.__sourcePath, "executables") + SRC_RESOURCES_PATH = os.path.join(self.__sourcePath, "resources") + TMP_BUILD_PATH = os.path.join(self.__sourcePath, "tmp") + DEST_EXECUTABLES_PATH = os.path.join(TMP_BUILD_PATH, "executables") + DEST_RESOURCES_PATH = os.path.join(TMP_BUILD_PATH, "resources") + DEST_SCP_FILENAME = os.path.join(self.__sourcePath, scpFileName) + # Create the temporary build path + MKDirsF(TMP_BUILD_PATH) + # Copy "executables" directory + CPDir(SRC_EXECUTABLES_PATH, DEST_EXECUTABLES_PATH) + # Copy "resources" directory + CPDir(SRC_RESOURCES_PATH, DEST_RESOURCES_PATH) + # Filtering the content of temporary path + RMWithFilters(TMP_BUILD_PATH, filters = ['.svn', '.pyc']) + # Create a zip file + directory = TMP_BUILD_PATH + last_cwd = os.getcwd() + os.chdir(TMP_BUILD_PATH) + zf = ZipFile(DEST_SCP_FILENAME, 'w', compression = ZIP_DEFLATED) + def walker(zip, directory, files, root = directory): + for file in files: + file = os.path.join(directory, file) + name = file[len(TMP_BUILD_PATH) + 1:] + if os.path.isfile(file): + zip.write(file, name, ZIP_DEFLATED) + elif os.path.isdir(file): + file = os.path.join(file, "") + name = os.path.join(name, "") + zip.writestr(name, name) + os.path.walk(TMP_BUILD_PATH, walker, zf) + zf.close() + os.chdir(os.path.abspath(last_cwd)) + # Remove the temporary directory + RMDirs(TMP_BUILD_PATH) + return True Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/__init__.py =================================================================== Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/__init__.py =================================================================== Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/DirectoriesAndFilesTools.py =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/DirectoriesAndFilesTools.py (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/DirectoriesAndFilesTools.py 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,161 @@ +# -*- coding: utf-8 -*- + +import version +__author__ = version.author +__date__ = version.date +__version__ = version.version +__licence__ = version.licence +del version + +# Copyleft (C) 2008 Acness World +# Remi Jocaille <rem...@c2...> +# Distributed under the terms of the GNU General Public License +# http://www.gnu.org/copyleft/gpl.html + +import os +import shutil + +if os.name == 'nt': + import win32con + import win32file + +# ============================================================================== +# Public functions +# ============================================================================== + +# ------------------------------------------------------------------------------ +# Force to create a directories tree if not exists. +# ------------------------------------------------------------------------------ +def MKDirs(path): + """Force to create a directories tree if not exists. + @param path: Directory path. + """ + if not os.path.isdir(path): + try: + os.makedirs(path) + except: + pass + +# ------------------------------------------------------------------------------ +# Force to create a directories tree after having deleted the old one. +# ------------------------------------------------------------------------------ +def MKDirsF(path): + """Force to create a directories tree after having deleted the old one. + @param path: Directory path. + """ + if os.path.isdir(path): + RMDirs(path) + os.makedirs(path) + +# ------------------------------------------------------------------------------ +# Remove directories and files recursively. +# ------------------------------------------------------------------------------ +def RMDirs(path): + """Remove directories and files recursively. + @param path: Path of the base directory. + """ + if not os.path.isdir(path): + return + for root, dirs, files in os.walk(path, topdown = False): + for d in dirs: + try: + os.removedirs(os.path.join(root, d)) + except: + pass + for f in files: + try: + if os.name == 'nt': + win32file.SetFileAttributesW(os.path.join(root, f), + win32con.FILE_ATTRIBUTE_NORMAL) + os.remove(os.path.join(root, f)) + except: + pass + if os.path.isdir(path): + try: + os.removedirs(path) + except: + pass + +# ------------------------------------------------------------------------------ +# Remove directories and files recursively with filters. +# ------------------------------------------------------------------------------ +def RMWithFilters(path, filters = ['.pyc', '.pyo']): + """Remove directories and files recursively with filters. + @param path: Path of the base directory. + @param filters: Filters as list. + """ + def checkFilter(name): + for filter in filters: + if name.lower().find(filter.lower()) == (len(name) - len(filter)): + return True + return False + + if not os.path.isdir(path): + return + + for root, dirs, files in os.walk(path, topdown = False): + for d in dirs: + if checkFilter(os.path.join(root, d)): + try: + RMDirs(os.path.join(root, d)) + except: + pass + for f in files: + if checkFilter(os.path.join(root, f)): + try: + if os.name == 'nt': + win32file.SetFileAttributesW(os.path.join(root, f), + win32con.FILE_ATTRIBUTE_NORMAL) + os.remove(os.path.join(root, f)) + except: + pass + +# ------------------------------------------------------------------------------ +# Remove a file. +# ------------------------------------------------------------------------------ +def RMFile(path): + """Remove a file. + @param path: File path. + """ + if os.path.isfile(path): + try: + if os.name == 'nt': + win32file.SetFileAttributesW(path, + win32con.FILE_ATTRIBUTE_NORMAL) + os.remove(path) + except: + pass + +# ------------------------------------------------------------------------------ +# Copy a directories tree to another directory. +# ------------------------------------------------------------------------------ +def CPDir(src, dest): + """Copy a directories tree to another directory. + @param src: Source path. + @param dest: Destination path. + """ + if not os.path.isdir(src): + return + if os.path.isdir(dest): + RMDirs(dest) + shutil.copytree(src, dest) + +# ------------------------------------------------------------------------------ +# Retrieve the OS temporary directory. +# ------------------------------------------------------------------------------ +def GetOSTMPDir(): + """Retrieve the OS temporary directory. + @return: The OS temporary directory. + """ + result = None + # On Windows + if os.name == 'nt': + result = os.environ.get('tmp') + if result == None: + result = os.environ.get('temp') + if result == None: + result = "c:\\windows\\temp" + # On linux + else: + result = "/tmp" + return result Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/__init__.py =================================================================== Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/version.py =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/version.py (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/util/misc/version.py 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- + +"""Version data for tuxisalive.lib.Util""" + +__author__ = "Remi Jocaille (rem...@c2...)" + +# Copyleft (C) 2008 C2ME Sa +# Remi Jocaille <rem...@c2...> +# Distributed under the terms of the GNU General Public License +# http://www.gnu.org/copyleft/gpl.html + +name = 'util.misc' +version = '0.0.1' +author = "Remi Jocaille (rem...@c2...)" + +description = "Utilities libraries." + +licence = "GPL" +date = "December 2008" Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/version.py =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/version.py (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/builder/version.py 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,9 @@ +# Copyleft (C) 2009 C2ME Sa +# Remi Jocaille <rem...@c2...> +# Distributed under the terms of the GNU General Public License +# http://www.gnu.org/copyleft/gpl.html + +version = '2.0' +author = "Jerome Conan (jer...@ky...)" +licence = "GPL" +date = "2009" Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/executables/plugin-system.py =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/executables/plugin-system.py (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/executables/plugin-system.py 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,325 @@ +# -*- coding: utf-8 -*- + +# Copyright (C) 2009 Kysoh Sa +# Jerome Conan <jer...@ky...> +# Distributed under the terms of the GNU General Public License +# http://www.gnu.org/copyleft/gpl.html + +__author__ = "Jerome Conan" +__appname__ = "plugin-system" +__version__ = "1.0" +__date__ = "2009/06/25" +__license__ = "GPL" + +import os +import sys + +import commands +import platform +import subprocess +import string +import threading + +from time import sleep + +sys.path.append(os.environ['TUXDROID_SERVER_PYTHON_UTIL']) + +from util.SimplePlugin.SimplePluginConfiguration import SimplePluginConfiguration +from util.SimplePlugin.SimplePlugin import SimplePlugin + +class Configuration(SimplePluginConfiguration): + """ + This class make an access to the plugin parameters. + """ + + def __init__(self): + """ + Initialization of the class. + """ + # Call the super class + SimplePluginConfiguration.__init__(self) + # Initialize the parameters + self.__cpuTresholdParam = "" + self.__memTresholdParam = "" + self.__checkCpuParam = True + self.__checkMemParam = True + + def getCpuTresholdParam(self): + return string.replace(self.__cpuTresholdParam, r"%", "") + + def setCpuTresholdParam(self, stringParam): + self.__cpuTresholdParam = stringParam + + def getMemTresholdParam(self): + return string.replace(self.__memTresholdParam, r"%", "") + + def setMemTresholdParam(self, stringParam): + self.__memTresholdParam = stringParam + + def getCheckMemParam(self): + return self.__checkMemParam + + def setCheckMemParam(self, booleanParam): + self.__checkMemParam = stringParam + + def getCheckCpuParam(self): + return self.__checkCpuParam + + def setCheckCpuParam(self, booleanParam): + self.__checkCpuParam = stringParam + + + +class SystemUtils(object): + """ + This class contain utilities to retrieve system informations. + """ + + def __getPlatform(self): + ''' + Return the plateform name of this current computer. + ''' + return platform.system() + + + + def isWindows(self): + ''' + Return true if plateform is windows. + ''' + platform = self.__getPlatform() + return (platform == 'Windows' ) or (platform == 'windows') or (platform == "Microsoft") + + + + def getLinuxCPULoad(self): + ''' + Return the current cpu load for linux systems. + ''' + data = commands.getoutput("cat /proc/stat") + u1 = float( data.split()[1] ) + n1 = float( data.split()[2] ) + s1 = float( data.split()[3] ) + i1 = float( data.split()[4] ) + sleep(2) + datas = commands.getoutput("cat /proc/stat") + u2 = float( datas.split()[1] ) + n2 = float( datas.split()[2] ) + s2 = float( datas.split()[3] ) + i2 = float( datas.split()[4] ) + usage = (u2-u1) + (n2 - n1) + (s2 - s1) + total = (u2-u1) + (n2 - n1) + (s2 - s1) + (i2 -i1) + lo = int((usage/total)* 100) + return str(lo) + + + + + def getWindowsCPULoad(self): + ''' + Return the cpu load for windows operating systems. + ''' + from win32com.client import GetObject + wmi = GetObject('winmgmts:') + cpu = wmi.InstancesOf('Win32_Processor') + + x = cpu[0] + return x.Properties_('LoadPercentage').value + + + + + + def getLinuxMemoryUsage(self): + ''' + Return the current memory usage for linux systems. + ''' + def get_freemem(): + """ + Get free memory + """ + cached = commands.getoutput("""cat /proc/meminfo | grep Cached | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + buffers = commands.getoutput("""cat /proc/meminfo | grep Buffers | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + free = commands.getoutput("""cat /proc/meminfo | grep MemFree | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + return str(int(cached.split()[0])/1024 + int(buffers)/1024 + int(free)/1024) + + + def get_usedmem(): + """ + Get used memory + """ + total = commands.getoutput("""cat /proc/meminfo | grep MemTotal | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + cached = commands.getoutput("""cat /proc/meminfo | grep Cached | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + buffers = commands.getoutput("""cat /proc/meminfo | grep Buffers | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + free = commands.getoutput("""cat /proc/meminfo | grep MemFree | awk 'BEGIN {FS=":"} {print $2}' | awk '{print $1, $9}'""") + return str(int(total)/1024 - int(cached.split()[0])/1024 - int(buffers)/1024 - int(free)/1024) + + free = get_freemem() + used = get_usedmem() + + return str(int((float(used) / (float(used) + float(free))) * 100.0)) + + + + def getWindowsMemoryUsage(self): + '''' + Return the windows memory usage. + ''' + process = subprocess.Popen("systeminfo", stdin=subprocess.PIPE, stdout=subprocess.PIPE) + result = process.stdout.read() + totalIndex = result.find("Total Physical Memory") + totalAvailable = result.find("Available Physical Memory") + totalMem = result.find("MB", totalIndex, totalAvailable) + totalMem = result[ totalIndex + len("Total Physical Memory:") : totalMem ] + + freeMem = result.find("MB", totalAvailable) + freeMem = result[ totalAvailable + len("Available Physical Memory:") : freeMem ] + + totalMem = string.replace(totalMem.strip(), ".", "") + freeMem = string.replace(freeMem.strip(), ".", "") + + totalMem = string.replace(totalMem.strip(), ",", "") + freeMem = string.replace(freeMem.strip(), ",", "") + + totalMem = string.replace(totalMem.strip(), "'", "") + freeMem = string.replace(freeMem.strip(), "'", "") + + value = str(float( float(int(totalMem) - int(freeMem)) / float(totalMem) ) * 100) + if value.find("."): + value = value[ : value.find(".")] + return value + + + +class SystemPlugin(SimplePlugin): + """ + This class override the SimplePlugin class to make easy the plugin coding. + """ + + def __init__(self): + """Initialization of the class. + """ + # Call the super class + SimplePlugin.__init__(self) + # Initialize some values ... + self.__daemonRun = False + self.__daemonMutex = threading.Lock() + + + def start(self): + """Plugin entry point. + This method should be used to dispatch commands. + """ + if self.getCommand() == "run": + self.run(False) + elif self.getCommand() == "runDaemon": + self.runDaemon() + elif self.getCommand() == "check": + self.run() + else: + self.run() + + + def run(self, notif): + """ + Plugin entry point for the "run" command. + """ + cpu = "" + memory = "" + + sutils = SystemUtils() + + if self.configuration().getCheckCpuParam(): + ''' + Getting cpu load. + ''' + + if not self.isWindows(): + #linux system. + cpu = sutils.getLinuxCPULoad() + if not notif: + self.throwMessage("Your c p u load is {0} percent", cpu) + + else: + #windows system. + cpu = sutils.getWindowsCPULoad() + if not notif: + self.throwMessage("Your c p u load is {0} percent", cpu) + + + if self.configuration().getCheckMemParam(): + ''' + Getting Memory load. + ''' + if not sutils.isWindows(): + #linux system. + memory = sutils.getLinuxMemoryUsage() + if not notif : + self.throwMessage("Your used memory is {0} percent", memory) + else: + memory = sutils.getWindowsMemoryUsage() + if not notif : + self.throwMessage("Your used memory is {0} percent", memory) + + if notif : + return cpu, memory + + + def __getDaemonRun(self): + """ + """ + self.__daemonMutex.acquire() + result = self.__daemonRun + self.__daemonMutex.release() + return result + + + + def __setDaemonRun(self, daemonRun): + """ + """ + self.__daemonMutex.acquire() + self.__daemonRun = daemonRun + self.__daemonMutex.release() + + + + def runDaemon(self): + """ + Plugin entry point for the "run_daemon" command. + """ + self.__setDaemonRun(True) + while self.__getDaemonRun(): + + cpu, memory = self.run(True) + + if (float(cpu) > float(self.configuration().getCpuTresholdParam())): + self.throwNotification("start") + self.throwMessage("c p u meltdown") + self.throwNotification("stop") + + if (float(memory) > float(self.configuration().getMemTresholdParam())): + self.throwNotification("start") + self.throwMessage("memory is up") + self.throwNotification("stop") + + sleep(1.9) + + + def onPluginStop(self): + """Callback on plugin stop. + """ + pass + + + def onPluginEvent(self, eventName, eventValues): + """ + Callback on plugin event. + @param eventName: Event name. + @param eventValues: Event values. + """ + pass + +if __name__ == "__main__": + plugin = SystemPlugin() + plugin.boot(sys.argv[1:], Configuration()) Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.po =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.po (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.po 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,31 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-04-01 14:56+0200\nPO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\nLast-Translator: FULL NAME <EMAIL@ADDRESS>\nLanguage-Team: LANGUAGE <LL...@li...>\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nX-Generator: Translate Toolkit 1.3.0\n" + +msgid "System plugin" +msgstr "System plugin" + +msgid "With this plugin Tux Droid will monitor your cpu and memory load on your PC." +msgstr "With this plugin Tux Droid will monitor your cpu and memory load on your PC." + +msgid "Give system information." +msgstr "Give system information." + +msgid "Your c p u load is {0} percent" +msgstr "Your c p u load is {0} percent" + +msgid "Your used memory is {0} percent" +msgstr "Your used memory is {0} percent" + +msgid "CPU threshold" +msgstr "CPU threshold" + +msgid "Memory threshold" +msgstr "Memory threshold" + +msgid "c p u meltdown" +msgstr "c p u meltdown" + +msgid "memory is up" +msgstr "memory is up" + Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/en.wiki 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,2 @@ +== Synopsis == +Tux Droid will inform you of the current memory and CPU load. Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.po =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.po (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.po 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,31 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-04-01 14:56+0200\nPO-Revision-Date: 2009-04-03 19:57+0200\nLast-Translator: Santiago Perez <san...@gm...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: es\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "System plugin" +msgstr "Plugin del Sistema" + +msgid "With this plugin Tux Droid will monitor your cpu and memory load on your PC." +msgstr "Con este plugin Tux Droid monitorizará el uso de su cpu y el consumo de memoria de su PC." + +msgid "Give system information." +msgstr "Da información del sistema." + +msgid "Your c p u load is {0} percent" +msgstr "Su carga de cpu es del {0} porciento" + +msgid "Your used memory is {0} percent" +msgstr "Su memoria usada es del {0} porciento" + +msgid "CPU threshold" +msgstr "Carga de CPU" + +msgid "Memory threshold" +msgstr "Consumo de memoria" + +msgid "c p u meltdown" +msgstr "CPU por dejabo del limite" + +msgid "memory is up" +msgstr "Memoria libre por debajo del limite" + Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/es.wiki 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,3 @@ +== Synopsis == + +Tux Droid informará de la memoria actualmente en uso y de la carga de su CPU. \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.po =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.po (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.po 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,31 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-04-01 14:56+0200\nPO-Revision-Date: 2009-04-15 11:14+0200\nLast-Translator: jerome <jer...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: fr\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n > 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "System plugin" +msgstr "Plugin système" + +msgid "With this plugin Tux Droid will monitor your cpu and memory load on your PC." +msgstr "Avec ce plugin, Tux Droid vous informera de la charge mémoire et cpu de votre PC." + +msgid "Give system information." +msgstr "Donne les informations système." + +msgid "Your c p u load is {0} percent" +msgstr "Votre charge c p u est de {0} pour cent" + +msgid "Your used memory is {0} percent" +msgstr "L'utilisation de la mémoire est de {0} pour cent" + +msgid "CPU threshold" +msgstr "Seuil CPU" + +msgid "Memory threshold" +msgstr "Seuil mémoire" + +msgid "c p u meltdown" +msgstr "Seuil c p u dépassé" + +msgid "memory is up" +msgstr "Seuil mémoire dépassé" + Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/fr.wiki 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,3 @@ +== Synopsis == + +Tux Droid vous informera quant à la charge cpu et mémoire de votre PC. \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/help.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/help.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/help.wiki 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,2 @@ +== Synopsis == +Tux Droid will inform you of the current memory and CPU load. Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.po =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.po (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.po 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,31 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-04-01 14:56+0200\nPO-Revision-Date: 2009-04-01 15:20+0200\nLast-Translator: Sebastiaan Vanpoucke <se...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: nl\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "System plugin" +msgstr "Systeem plugin" + +msgid "With this plugin Tux Droid will monitor your cpu and memory load on your PC." +msgstr "Met deze plugin kan Tux Droid de capaciteit van de processor en het geheugen meten." + +msgid "Give system information." +msgstr "Geef systeeminformatie." + +msgid "Your c p u load is {0} percent" +msgstr "Je c p u is {0} procent actief" + +msgid "Your used memory is {0} percent" +msgstr "Je geheugen is {0} procent vol" + +msgid "CPU threshold" +msgstr "CPU limiet" + +msgid "Memory threshold" +msgstr "Geheugen limiet" + +msgid "c p u meltdown" +msgstr "Je c p u is aan het smelten" + +msgid "memory is up" +msgstr "Je geheugen is op" + Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/nl.wiki 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,2 @@ +== Synopsis == +Tux Droid de geheugen- en processoractiviteit rapporteren. \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.png =================================================================== (Binary files differ) Property changes on: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.png ___________________________________________________________________ Name: svn:mime-type + application/octet-stream Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.pot =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.pot (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.pot 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,26 @@ +msgid "System plugin" +msgstr "" + +msgid "With this plugin Tux Droid will monitor your cpu and memory load on your PC." +msgstr "" + +msgid "Give system information." +msgstr "" + +msgid "Your c p u load is {0} percent" +msgstr "" + +msgid "Your used memory is {0} percent" +msgstr "" + +msgid "CPU threshold" +msgstr "" + +msgid "Memory threshold" +msgstr "" + +msgid "c p u meltdown" +msgstr "" + +msgid "memory is up" +msgstr "" Added: software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.xml =================================================================== --- software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.xml (rev 0) +++ software_suite_v3/software/plugin/plugin-system/trunk/plugin-system/resources/plugin.xml 2009-06-25 18:16:18 UTC (rev 4902) @@ -0,0 +1,58 @@ +<plugin> + <interpreter + kind="python"> + <executable>executables/plugin-system.py</executable> + </interpreter> + <description> + <name>System plugin</name> + <description>With this plugin Tux Droid will monitor your cpu and memory load on your PC.</description> + <author>Jérôme Conan</author> + <version>2.0</version> + <iconFile>resources/plugin.png</iconFile> + <executionMode>command</executionMode> + <uuid>8349ed52-572d-4c3f-a7b8-aad4a4ae1d2</uuid> + </description> + <parameters> + <parameter + category="Options" + name="cpuTresholdParam" + description="CPU threshold" + type="enum(10%, 20%, 30%, 40%, 50%, 60%, 70%, 80%, 90%)" + defaultValue="90%" + /> + <parameter + category="Options" + name="memTresholdParam" + description="Memory threshold" + type="enum(10%, 20%, 30%, 40%, 50%, 60%, 70%, 80%, 90%)" + defaultValue="90%" + /> + <parameter + category="Options" + name="checkCpuParam" + description="Check Cpu" + type="boolean" + defaultValue="true" + /> + <parameter + category="Options" + name="checkMemParam" + description="Check Memory" + type="boolean" + defaultValue="true" + /> + </parameters> + <commands> + <commands + name="run" + description="Give system informations." /> + <command + name="runDaemon" + description="Start system daemon" + daemon="true" + notifier="true" + expiration="1"/> + </commands> + <tasks> + </tasks> +</plugin> |
|
From: jerome <c2m...@c2...> - 2009-06-25 12:59:41
|
Author: jerome Date: 2009-06-25 14:29:50 +0200 (Thu, 25 Jun 2009) New Revision: 4901 Added: software_suite_v3/software/plugin/plugin-WMP/ software_suite_v3/software/plugin/plugin-WMP/branches/ software_suite_v3/software/plugin/plugin-WMP/tags/ software_suite_v3/software/plugin/plugin-WMP/trunk/ software_suite_v3/software/plugin/plugin-WMP/trunk/LICENSE software_suite_v3/software/plugin/plugin-WMP/trunk/pom.xml software_suite_v3/software/plugin/plugin-WMP/trunk/resources/ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.po software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.wiki software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.po software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.wiki software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.po software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.wiki software_suite_v3/software/plugin/plugin-WMP/trunk/resources/help.wiki software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.po software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.wiki software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.png software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.pot software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.xml software_suite_v3/software/plugin/plugin-WMP/trunk/src/ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Configuration.java software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/MediaPlayerThread.java software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Threading/ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Threading/SThread.java software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/WMPlayer.java software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/listener/ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/listener/WMPThreadListener.java Log: * Added plugin-WMP. Added: software_suite_v3/software/plugin/plugin-WMP/trunk/LICENSE =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/LICENSE (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/LICENSE 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,340 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + <one line to give the program's name and a brief idea of what it does.> + Copyright (C) <year> <name of author> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + <signature of Ty Coon>, 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. Added: software_suite_v3/software/plugin/plugin-WMP/trunk/pom.xml =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/pom.xml (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/pom.xml 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,120 @@ +<project> + <!--General project informations--> + <modelVersion>4.0.0</modelVersion> + <groupId>com.kysoh</groupId> + <artifactId>plugin-WMP</artifactId> + <packaging>jar</packaging> + <version>2.0</version> + <name>Windows media player for Tux Droid</name> + <url>http://www.tuxisalive.com</url> + + <!--Dependency list--> + <dependencies> + <dependency> + <groupId>com.kysoh</groupId> + <artifactId>tuxdroid-plugin-java-kit</artifactId> + <version>0.0.3</version> + </dependency> + <dependency> + <groupId>X10Gimli</groupId> + <artifactId>X10GimliLaunch</artifactId> + <version>1.0</version> + </dependency> + + </dependencies> + + <!--Repository list--> + <repositories> + <repository> + <id>kysoh</id> + <name>Kysoh Repository</name> + <layout>default</layout> + <url>http://ftp.kysoh.com/maven2</url> + <snapshots> + <enabled>false</enabled> + </snapshots> + </repository> + </repositories> + + <!--Build process--> + <build> + <sourceDirectory>src</sourceDirectory> + <plugins> + + <!--This section copy the dependencies into ./libraries--> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-dependency-plugin</artifactId> + <executions> + <execution> + <id>copy-dependencies</id> + <phase>package</phase> + <goals> + <goal>copy-dependencies</goal> + </goals> + <configuration> + <outputDirectory>./libraries</outputDirectory> + </configuration> + </execution> + </executions> + </plugin> + + <!--This plugin run small ant scripts to pack and clean the plugin --> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-antrun-plugin</artifactId> + <version>1.3</version> + <executions> + + <!--This section create the .scp file during the package lifecycle--> + <execution> + <phase>package</phase> + <id>package</id> + <configuration> + <tasks> + <mkdir dir="./libraries"/> + <copy file="${project.build.directory}/${project.artifactId}-${project.version}.jar" + todir="./libraries" /> + <zip destfile="./${project.artifactId}.scp"> + <zipfileset dir="." includes="resources/*" /> + <zipfileset dir="." includes="libraries/*" > + <exclude name="libraries/tuxdroid-plugin-java-kit*" /> + <exclude name="libraries/karmalab-commons*" /> + </zipfileset> + <zipfileset dir="." includes="executables/*" /> + </zip> + </tasks> + </configuration> + <goals> + <goal>run</goal> + </goals> + </execution> + + <!--This section clean the ./libraries and the SCP file during the 'clean' lifecycle--> + <execution> + <phase>clean</phase> + <configuration> + <tasks> + <delete dir="./libraries"/> + <delete file="./${project.artifactId}.scp"/> + </tasks> + </configuration> + <goals> + <goal>run</goal> + </goals> + </execution> + </executions> + </plugin> + + <!--This plugin compile the project--> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-compiler-plugin</artifactId> + <configuration> + <source>1.6</source> + <target>1.6</target> + </configuration> + </plugin> + </plugins> + </build> +</project> Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.po =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.po (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.po 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,25 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-03-12 14:48+0200\nPO-Revision-Date: 2009-03-11 12:27+0200\nLast-Translator: jerome <jer...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: en\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "WMP Plugin" +msgstr "WMP Plugin" + +msgid "Take control of Windows media player with the Tux Droid remote control or flippers." +msgstr "Take control of Windows media player with the Tux Droid remote control or flippers." + +msgid "Select file, directory or playlist to read" +msgstr "Select file, directory or playlist to read" + +msgid "Quit Media Player when the plugin stops" +msgstr "Quit Media Player when plugin stops" + +msgid "Cannot get connected to Windows Media Player" +msgstr "Cannot get connected to Windows Media Player" + +msgid "Dongle not connected" +msgstr "Dongle not connected" + +msgid "Cannot get connected to the Tux Droid server" +msgstr "Can not get connected to the Tux Droid server" + Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/en.wiki 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,15 @@ +== Synopsis == + +=== To control Windows Media Player with the remote control, the following buttons are used === +* Play/Pause : play or pause the current song +* OK : play or pause the current song +* Stop : stop current song +* Skip previous/next : Skip to previous/next song +* Arrow up/down : Skip to previous/next song +* Volume plus / Volume minus : Increase/Decrease volume +* Back space : Enter/Quit the fullscreen mode +* Power button : Quit the gadget (Quit Windows Media Player too if option is enabled) +* Mute button : Mute the sound + +=== To control Windows Media Player with Tux Droid === +* left/right flipper : skip to the previous/next song \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.po =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.po (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.po 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,25 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-03-12 14:48+0200\nPO-Revision-Date: 2009-04-02 15:24+0200\nLast-Translator: jerome <jer...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: es\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "WMP Plugin" +msgstr "WMP Plugin" + +msgid "Take control of Windows media player with the Tux Droid remote control or flippers." +msgstr "Controla el Windows Media Player con el mando a distancia de Tux Droid o sus alas." + +msgid "Select file, directory or playlist to read" +msgstr "Seleccione fichero, carpeta o lista a leer" + +msgid "Quit Media Player when the plugin stops" +msgstr "Salir del Media Player cuando salir el plugin" + +msgid "Cannot get connected to Windows Media Player" +msgstr "Imposible conectar con Windows Media Player" + +msgid "Dongle not connected" +msgstr "Dongle no conectado" + +msgid "Cannot get connected to the Tux Droid server" +msgstr "Imposible conectar con el Tux Droid" + Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/es.wiki 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,15 @@ +== Synopsis == + +=== Para controlar Windows Media Player con el control remoto === +* Play/Pause : reproduce o pausa la pista en curso +* OK : reproduce o pausa la pista en curso +* Stop : detiene la pista en curso +* Skip previous/next : salta a la pista anterior/siguiente +* Flecha arriba/abajo : Salta a la pista anterior/siguiente +* Vol+ / Vol- : sube / baja el volumen +* Retroceso : Entrar/Salir modo pantalla completa +* Boton ecendido : Sale del gadget (y detiene Windows Media Player si ese opcion estaactivada) +* Boton silencio : Silenciar sonido + +=== Para controlar Windows Media Player con Tux === +*Izquierda/derecha : salta a la pista anterior/siguiente \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.po =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.po (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.po 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,25 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-03-12 14:48+0200\nPO-Revision-Date: 2009-03-11 18:18+0200\nLast-Translator: jerome <jer...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: fr\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n > 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "WMP Plugin" +msgstr "Plugin WMP" + +msgid "Take control of Windows media player with the Tux Droid remote control or flippers." +msgstr "Le gadget WMP contrôle Windows Media Player avec la télécommande ou les ailes de Tux Droid." + +msgid "Select file, directory or playlist to read" +msgstr "Sélectionnez un fichier ou dossier à lire" + +msgid "Quit Media Player when the plugin stops" +msgstr "Quitter WMP en stoppant le plugin" + +msgid "Cannot get connected to Windows Media Player" +msgstr "Impossible de se connecter à Windows Media Player" + +msgid "Dongle not connected" +msgstr "Le dongle n'est pas connecté" + +msgid "Cannot get connected to the Tux Droid server" +msgstr "Impossible de se connecter au serveur de Tux Droid" + Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/fr.wiki 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,16 @@ +== Synopsis == + +=== Pour contrôler Windows Media Player avec la télécommande === +* Lecture / Pause : Lit ou met en pause la chanson +* OK : Lit ou met en pause la chanson +* Stop : Arrête la lecture +* Précédent / Suivant : Lit la chanson précédente / suivante +* Flèche haut / bas : Lit la chanson précédente / suivante +* Volume plus / Volume moins : Augmente / Diminue le volume +* Retour : Entre / Quitte le mode plein-écran +* Bouton power : Quitte le gadget (et quitte Windows Media Player si l'option est activée) +* Bouton mute : Coupe le son + +=== Pour contrôler Windows Media Player avec Tux Droid : ===- +* Aile gauche / Aile droite : Lit la chanson précédente / suivante + \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/help.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/help.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/help.wiki 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,15 @@ +== Synopsis == + +=== To control Windows Media Player with the remote control, the following buttons are used === +* Play/Pause : play or pause the current song +* OK : play or pause the current song +* Stop : stop current song +* Skip previous/next : Skip to previous/next song +* Arrow up/down : Skip to previous/next song +* Volume plus / Volume minus : Increase/Decrease volume +* Back space : Enter/Quit the fullscreen mode +* Power button : Quit the gadget (Quit Windows Media Player too if option is enabled) +* Mute button : Mute the sound + +=== To control Windows Media Player with Tux Droid === +* left/right flipper : skip to the previous/next song Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.po =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.po (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.po 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,25 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-03-12 14:48+0200\nPO-Revision-Date: 2009-03-11 15:49+0200\nLast-Translator: Sebastiaan Vanpoucke <se...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: nl\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "WMP Plugin" +msgstr "WMP Plugin" + +msgid "Take control of Windows media player with the Tux Droid remote control or flippers." +msgstr "Met deze gadget kan je Windows Media Player controleren via de afstandsbediening." + +msgid "Select file, directory or playlist to read" +msgstr "Selecteer een bestand, folder of playlist" + +msgid "Quit Media Player when the plugin stops" +msgstr "Stop WMP bij afsluiten van de plugin" + +msgid "Cannot get connected to Windows Media Player" +msgstr "De Gadget kan Windows Media Player niet vinden" + +msgid "Dongle not connected" +msgstr "Dongle is niet verbonden" + +msgid "Cannot get connected to the Tux Droid server" +msgstr "Ik kan geen verbinding maken met de Tux Droid server" + Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/nl.wiki 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,15 @@ +<== Synopsis == + +=== Volgende knoppen worden gebruikt om Windows Media player te bedienen === +* Play/Pauze : om de muziek of film af te spelen of te pauzeren +* OK : om de huidige muziek of film af te spelen of te pauzeren +* Stop : pauzeert de muziek of film +* Skip vorig/volgend : Skip naar de vorige/volgende song of film +* Pijl omhoog/omlaag : Skip naar de vorige/volgende song of film +* Volume + / Volume - : Verhoog/verlaag volume +* Back space : Activeer/Stop volledige scherm modus +* Power knop : Sluit de gadget af (en sluit Windows Media Player af indien zo geconfigureerd) +* Mute knop : Schakelt geluid uit + +=== Om Windows Media Player te bedienen met Tux Droid === +* Linker/rechter flipper : Skip naar de vorige/volgende film of muziek \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.png =================================================================== (Binary files differ) Property changes on: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.png ___________________________________________________________________ Name: svn:mime-type + application/octet-stream Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.pot =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.pot (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.pot 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,20 @@ +msgid "WMP Plugin" +msgstr "" + +msgid "Take control of Windows media player with the Tux Droid remote control or flippers." +msgstr "" + +msgid "Select file, directory or playlist to read" +msgstr "" + +msgid "Quit Media Player when the plugin stops" +msgstr "" + +msgid "Cannot get connected to Windows Media Player" +msgstr "" + +msgid "Dongle not connected" +msgstr "" + +msgid "Cannot get connected to the Tux Droid server" +msgstr "" Added: software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.xml =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.xml (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/resources/plugin.xml 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,40 @@ + +<plugin> + <interpreter + kind="java"> + <executable>com.kysoh.tuxdroid.WMPlayer</executable> + </interpreter> + <description> + <name>WMP Plugin</name> + <description>Take control of Windows media player with the Tux Droid remote control or flippers.</description> + <author>Jérôme Conan</author> + <version>2.0</version> + <iconFile>resources/plugin.png</iconFile> + <uuid>f63af23e-7ae0-4389-b89b-bc5a8185a84f</uuid> + <platform>windows</platform> + </description> + <parameters> + <parameter + category="Player parameters" + name="mediaPath" + description="Select file, directory or playlist to read" + type="string" + defaultValue="C:/user/MyMusic/playist.m3u" + /> + <parameter + category="User parameters" + name="stopWMPToo" + description="Quit Media Player when the gadget stops" + type="boolean" + defaultValue="true" + /> + </parameters> + <commands> + <command + name="run" + description="Take control of windows media player" + daemon="true" /> + </commands> + <tasks> + </tasks> +</plugin> Added: software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Configuration.java =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Configuration.java (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Configuration.java 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,112 @@ +/* This file is part of "TuxDroid Gadget Windows Media player". + * Copyright 2008, kysoh + * Author : Francois Finfe + * Site : http://www.kysoh.com/ + * + * "TuxDroid Gadget Windows Media player" is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2.1 of + * the License, or (at your option) any later version. + * + * "TuxDroid Gadget Windows Media player" is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public + * License along with "TuxDroid Gadget Windows Media player"; if not, write to the Free + * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA + * 02110-1301 USA, or see the FSF site: http://www.fsf.org. + */ + +package com.kysoh.tuxdroid; + +import java.io.File; +import java.util.Vector; + +import com.kysoh.tuxdroid.plugin.framework.plugin.SimplePluginConfiguration; + +//public class that manage a simple configuration. +public class Configuration extends SimplePluginConfiguration{ + + // Absolute Path/ link to the program to launch + private String mediaPath = ""; + private boolean stopWMPToo = true; + private String[] accept = new String[]{".avi", ".flv", ".mpg", ".mp4", ".wmv", ".wma" ,".mp3", ".ogg", ".m3u"}; + + /** + * This method set the local variable mediaPath. + * @param mediaPath : The path where found media player + */ + public void setMediaPath(String mediaPath) + { + this.mediaPath = mediaPath; + } + + + public String[] getMediaPath() + { + Vector<String> args = new Vector<String>(); + File dir = new File(this.mediaPath); + + if(dir.isDirectory()) + { + //List files into directory to prepare the command line. + for(File musicFile : dir.listFiles()) + { + boolean canAdd = false; + for(String str : accept) + { + if(musicFile.getAbsolutePath().endsWith(str)) + { + canAdd = true; + break; + } + } + if(canAdd) + { + args.add("\"" + musicFile.getAbsolutePath() + "\""); + } + } + } + else + { + if(!dir.getAbsolutePath().contains("tuxdroid-gadget-WMP")) + { + args.add("\""+ dir.getAbsolutePath() +"\""); + } + else + { + args.add(""); + } + } + + String[] arguments = new String[args.size()]; + for(int i=0; i < args.size(); i++) + { + arguments[i] = args.get(i); + } + return arguments; + } + + + /** + * Return true if user wants to quit media player when quitting the gadget. + * @return + */ + public boolean getStopWMPToo() + { + return this.stopWMPToo; + } + + + /** + * Set the stop value. + * @param stop + */ + public void setStopWMPToo(boolean stopWMPToo) + { + this.stopWMPToo = stopWMPToo; + } + +} Added: software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/MediaPlayerThread.java =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/MediaPlayerThread.java (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/MediaPlayerThread.java 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,303 @@ +/* This file is part of "TuxDroid Gadget Windows Media player". + * Copyright 2008, kysoh + * Author : Francois Finfe + * Site : http://www.kysoh.com/ + * + * "TuxDroid Gadget Windows Media player" is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2.1 of + * the License, or (at your option) any later version. + * + * "TuxDroid Gadget Windows Media player" is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public + * License along with "TuxDroid Gadget Windows Media player"; if not, write to the Free + * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA + * 02110-1301 USA, or see the FSF site: http://www.fsf.org. + */ + +package com.kysoh.tuxdroid; + +import java.io.IOException; +import java.io.InputStream; +import java.io.StringWriter; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Vector; + +import com.kysoh.tuxdroid.Configuration; +import com.kysoh.tuxdroid.Threading.SThread; +import com.kysoh.tuxdroid.listener.WMPThreadListener; + + +public class MediaPlayerThread extends Thread implements Runnable{ + + private Configuration configuration; + private boolean startPlaylist; + private static Object mutex = new Object(); + private final Collection<WMPThreadListener> WMPThreadListeners = new ArrayList<WMPThreadListener>(); + private String[] command; + + /** + * This object starts the media player and waits the end of the thread. + */ + public MediaPlayerThread(boolean startWithPlaylist, Configuration configuration) throws Exception + { + //Getting the right path of media player. + this.configuration = configuration; + this.startPlaylist = startWithPlaylist; + } + + + /** + * Run media player in a thread and wait for the end of process. + */ + public void run() + { + try + { + launchWMP(this.startPlaylist); + } + catch (Exception e) + { + e.printStackTrace(); + } + } + + + /** + * This function launch WMP. + * The path of the executable of WMP and path of the audio file to play are extracted from the + * configuration (wmpPath and mediaPath) + * @param openfile if true, load and play the mediafile. If false, start WMP but don't open the file. + * @throws Exception + */ + private void launchWMP(boolean openfile) + { + + Vector<String> args = new Vector<String>(); + args.add("rundll32"); + args.add("SHELL32.DLL,ShellExec_RunDLL"); + args.add(getWMPpath()); + if(args.get(0) == null) + { + this.triggerStartError("Error: Command is null"); + return; + } + + if (openfile && (!MediaPlayerThread.isWMPStarted())) + { + String[] files = this.configuration.getMediaPath(); + for(String filename : files) + { + args.add(filename); + } + } + + command = new String[args.size()]; + for(int i=0; i < args.size(); i++) + { + command[i] = args.get(i); + } + + SThread thread = new SThread(this, "startWMP"); + thread.start(); + } + + + /** + * Start windows media player. + */ + public void startWMP() + { + try + { + Runtime.getRuntime().exec(command); + for(int i=0; i< 20; i++) + { + try + { + Thread.sleep(1000); + } + catch (InterruptedException e) { + ; + } + if(isWMPStarted()) + { + this.triggerStarted(); + break; + } + } + } + catch (IOException e) + { + this.triggerStartError("Error: IOException while connecting to windows media player"); + } + } + + + /** + * Trigger the 'started' event. + */ + private void triggerStarted() + { + for(WMPThreadListener listener : this.WMPThreadListeners) + { + listener.WMPStarted(); + } + } + + + /** + * Trigger the 'startError' event. + */ + private void triggerStartError(String errorType) + { + for(WMPThreadListener listener : this.WMPThreadListeners) + { + listener.WMPStartError(errorType); + } + } + + + /** + * Add a listener. + */ + public void addWMPThreadListener(WMPThreadListener listener) + { + this.WMPThreadListeners.add(listener); + } + + + /** + * Remove registered. + */ + public void removeWMPThreadListener(WMPThreadListener listener) + { + this.WMPThreadListeners.remove(listener); + } + + + /** + * Return registered listeners for this object. + * @return WMPThreadListener array. + */ + public WMPThreadListener[] getWMPThreadListeners() + { + return WMPThreadListeners.toArray(new WMPThreadListener[0]); + } + + + /** + * This function check if wmplayer process is started. + * @return true if wmplayer process was found. + */ + public static boolean isWMPStarted() + { + synchronized(mutex) + { + String cmd = "tasklist /FI \"IMAGENAME eq wmplayer.exe\""; + //Total check is under one minute. + Process wmpRunning; + try + { + wmpRunning = Runtime.getRuntime().exec(cmd); + + StreamReader reader = new StreamReader(wmpRunning.getInputStream()); + reader.start(); + wmpRunning.waitFor(); + reader.join(); + String result = reader.getResult().trim(); + if(result.contains("wmplayer.exe")) + { + return true; + } + } + catch (IOException e) + { + ; + } + catch (InterruptedException e) + { + ; + } + return false; + } + } + + + private static final String REGQUERY_UTIL = "reg query "; + private static final String WMPPATH_CMD = REGQUERY_UTIL + + "\"HKLM\\SOFTWARE\\Clients\\Media\\Windows Media Player\\shell\\open\\command\" /ve"; + + + /** + * @return the path of Windows Media Player executable file + */ + public static String getWMPpath() + { + String result = ""; + try + { + Process process = Runtime.getRuntime().exec(WMPPATH_CMD); + StreamReader reader = new StreamReader(process.getInputStream()); + + reader.start(); + process.waitFor(); + reader.join(); + + result = reader.getResult(); + + //Searching for complete application path + result = result.substring(result.indexOf("%"), result.length()).trim(); + if(result.contains("%ProgramFiles%")) + { + result = "\""+ System.getenv("ProgramFiles") + result.substring(result.indexOf("%ProgramFiles%") + 14) + "\""; + } + + + return result; + } + catch (Exception e) + { + //result = result.trim(); + result = result.substring(result.indexOf("Program Files") -3, result.length()).trim(); + return result; + } + } + + +static class StreamReader extends Thread { + private InputStream is; + private StringWriter sw; + + StreamReader(InputStream is) + { + this.is = is; + sw = new StringWriter(); + } + + public void run() + { + try + { + int c; + while ((c = is.read()) != -1) + sw.write(c); + } + catch (IOException e) + { + ; + } + } + + + public String getResult() + { + return sw.toString(); + } +} +} Added: software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Threading/SThread.java =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Threading/SThread.java (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/Threading/SThread.java 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,48 @@ +package com.kysoh.tuxdroid.Threading; + +import java.lang.reflect.Method; + +public class SThread extends Thread +{ + private Object pSender; + private String pMethod; + private Object[] pArgs; + + public SThread (Object sender, String method, Object... args) + { + pSender = sender; + pMethod = method; + pArgs = args; + } + + public void run() + { + Class<?> targetClass = pSender.getClass(); + Class<?> args[] = new Class[pArgs.length]; + + for (int i = 0; i < pArgs.length; i++) + { + args[i] = pArgs[i].getClass(); + + if (pArgs[i] != null) + { + args[i] = pArgs[i].getClass(); + } + else + { + args[i] = Object.class; + } + } + + try + { + Method targetMethod = targetClass.getDeclaredMethod(pMethod, args); + targetMethod.invoke(pSender, pArgs); + } + catch(Exception e) + { + System.out.println(String.format("Error when starting the thread : (%s)", + pMethod)); + } + } +} Added: software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/WMPlayer.java =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/WMPlayer.java (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/WMPlayer.java 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,347 @@ +/* This file is part of "TuxDroid Gadget Windows Media player". + * Copyright 2008, kysoh + * Author : Jme Conan jer...@ky... + * Site : http://www.kysoh.com/ + * + * "TuxDroid Gadget Windows Media player" is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2.1 of + * the License, or (at your option) any later version. + * + * "TuxDroid Gadget Windows Media player" is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public + * License along with "TuxDroid Gadget Windows Media player"; if not, write to the Free + * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA + * 02110-1301 USA, or see the FSF site: http://www.fsf.org. + */ + +package com.kysoh.tuxdroid; + +import java.io.*; + +import X10Gimli.Native.WindowsAPI; + +import com.kysoh.tuxdroid.MediaPlayerThread; +import com.kysoh.tuxdroid.Threading.SThread; +import com.kysoh.tuxdroid.listener.WMPThreadListener; +import com.kysoh.tuxdroid.plugin.framework.plugin.SimplePlugin; + + +public class WMPlayer extends SimplePlugin<Configuration>{ + + private int handle; + + private final int WM_COMMAND = 0x111; + private final int lParam = 0; + private WMPChecker checker; + + @Override + public void start() throws Exception + { + MediaPlayerThread WMP = new MediaPlayerThread(true, this.configuration()); + WMP.addWMPThreadListener(new WMPThreadListener() + { + + @Override + public void WMPStartError(String errorType) + { + throwError(new Exception("Cannot get connected to Windows Media Player")); + throwMessage(errorType); + System.exit(0); + } + + @Override + public void WMPStarted() + { + try + { + handle = setFocusOnWMP(); + //Go to "now playing" tab. + WMPCurrentPlaylist(); + checker = new WMPChecker(); + checker.start(); + } + catch(Exception e) + { + throwError(e); + System.exit(0); + } + } + + }); + WMP.start(); + } + + + + /** + * Start the gadget. + * @param args + * @throws InterruptedException + * @throws IOException + */ + public static void main(String[] args) throws InterruptedException, IOException + { + //Stand alone behavior. + new WMPlayer().boot(args, new Configuration()); + } + + + + /** + * This function try to find a WMP window. If not found, launch WMP. + * Than restore the windows if minimized and set the focus on it + * If after 20 attempt to launch and find WMP, the function exit and generate a messagenotification + * @return handle number + */ + public int setFocusOnWMP() + { + //Getting dll path and load it. + System.load(new File("libraries/X10GimliNative-1.0.dll").getAbsolutePath()); + int handle = 0; + + try + { + handle = WindowsAPI.findWindow("WMPlayerApp", "Windows Media Player"); + } + catch (Exception e) + { + e.printStackTrace(); + } + + WindowsAPI.setFocus(handle); + + int Height=400; + int Width=400; + int lParam = (Height * 2 ^ 16) + Width; + + WindowsAPI.postMessage(handle, WM_COMMAND, 0, lParam); + + return handle; + + } + + + /** + * This function send the command to increase volume to WMP with a step of about 20 %. + * @param the handle number of WMP + */ + public void WMPIncreaseVolume() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x497F, lParam); + } + + + /** + * This function send the command to decrease volume to WMP with a step of about 20 %. + * @param the handle number of WMP + */ + public void WMPDecreaseVolume() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x4980, lParam); + } + + /** + * This function send the command to mute volume to WMP. + * @param the handle number of WMP + */ + public void WMPMute() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x4981, lParam); + } + + + /** + * This function send the command "next" to WMP. + * @param the handle number of WMP + */ + public void WMPNext() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x497B, lParam); + } + + + + /** + * This function send the command "previous" to WMP. + * @param the handle number of WMP + */ + public void WMPPrevious() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x497A, lParam); + } + + + /** + * This function send the command "PlayPause" to WMP. + * @param the handle number of WMP + */ + public void WMPPlayPause() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x4978, lParam); + } + + + + /** + * This function send the command "stop" to WMP. + * @param the handle number of WMP + */ + public void WMPStop() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x4979, lParam); + } + + + /** + * Switch to fullscreen mode. + */ + public void WMPFullScreen() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x495E, lParam); + } + + + /** + * Go to "now playing" into WMP. + */ + public void WMPCurrentPlaylist() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x3E80, lParam); + } + + + /** + * Go to the root menu in case of DVD playing. + */ + public void WMPDvdRootMenu() + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0x4C2C, lParam); + } + + + /** + * On left wing button pushed. + */ + public void onLeftWing() + { + new SThread(this, "WMPNext").start(); + } + + + /** + * On right wing button pushed. + */ + public void onRightWing() + { + new SThread(this, "WMPPrevious").start(); + } + + + /** + * Function called by a handler when a remote button is pressed + * */ + public void remote_button(String value) + { + new SThread(this, "caseValue", value).start(); + } + + /** + * Select the good event to send. + * @param value + */ + public void caseValue(String value) + { + if (!value.equals("RELEASE")) + { + if (value.equals("K_VOLUMEPLUS")) + { + WMPIncreaseVolume(); + } + else if (value.equals("K_VOLUMEMINUS")) + { + WMPDecreaseVolume(); + } + else if (value.equals("K_PLAYPAUSE") || value.equals("K_OK")) + { + WMPPlayPause(); + } + else if (value.equals("K_STOP")) + { + WMPStop(); + } + else if (value.equals("K_NEXT") || value.equals("K_RIGHT") || value.equals("K_DOWN")) + { + WMPNext(); + } + else if (value.equals("K_PREVIOUS") || value.equals("K_LEFT") || value.equals("K_UP")) + { + WMPPrevious(); + } + else if(value.equals("K_BACKSPACE")) + { + WMPFullScreen(); + } + } + } + + + static class WMPChecker extends Thread{ + + public void run() + { + while(MediaPlayerThread.isWMPStarted()) + { + try + { + Thread.sleep(1000); + } + catch (InterruptedException e) + { + System.exit(0); + } + } + System.exit(0); + } + } + + + @Override + protected void onPluginEvent(String arg0, String[] arg1) throws Throwable + { + if(arg0.equalsIgnoreCase("remote")) + { + this.remote_button(arg1[0]); + } + else if (arg0.equalsIgnoreCase("left")) + { + if(arg1[0].equalsIgnoreCase("true")) + { + this.onLeftWing(); + } + } + else if(arg0.equalsIgnoreCase("right")) + { + if(arg1[0].equalsIgnoreCase("true")) + { + this.onRightWing(); + } + } + } + + + + @Override + protected void onPluginStop() throws Throwable + { + if(this.configuration().getStopWMPToo()) + { + WindowsAPI.postMessage(handle, WM_COMMAND, 0xE141, lParam); + } + System.exit(0); + } +} Added: software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/listener/WMPThreadListener.java =================================================================== --- software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/listener/WMPThreadListener.java (rev 0) +++ software_suite_v3/software/plugin/plugin-WMP/trunk/src/com/kysoh/tuxdroid/listener/WMPThreadListener.java 2009-06-25 12:29:50 UTC (rev 4901) @@ -0,0 +1,28 @@ +/* This file is part of "TuxDroid Gadget Windows Media player". + * Copyright 2008, kysoh + * Au... [truncated message content] |
|
From: jerome <c2m...@c2...> - 2009-06-25 10:07:14
|
Author: jerome
Date: 2009-06-25 12:07:10 +0200 (Thu, 25 Jun 2009)
New Revision: 4900
Modified:
software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/resources/plugin.xml
Log:
* Updated plugin description.
Modified: software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/resources/plugin.xml
===================================================================
--- software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/resources/plugin.xml 2009-06-25 10:06:23 UTC (rev 4899)
+++ software_suite_v3/software/plugin/plugin-weather/trunk/plugin-weather/resources/plugin.xml 2009-06-25 10:07:10 UTC (rev 4900)
@@ -1,5 +1,5 @@
-<gadget>
+<plugin>
<interpreter
kind="java">
<executable>net.karmaLab.tuxDroid.plugins.WeatherPlugin</executable>
@@ -87,4 +87,4 @@
hoursBeginVisible="true"
/>
</tasks>
-</gadget>
+</plugin>
|
|
From: jerome <c2m...@c2...> - 2009-06-25 10:06:29
|
Author: jerome
Date: 2009-06-25 12:06:23 +0200 (Thu, 25 Jun 2009)
New Revision: 4899
Modified:
software_suite_v3/software/plugin/plugin-twitter/trunk/plugin-twitter/resources/plugin.xml
Log:
* Updated plugin description.
Modified: software_suite_v3/software/plugin/plugin-twitter/trunk/plugin-twitter/resources/plugin.xml
===================================================================
--- software_suite_v3/software/plugin/plugin-twitter/trunk/plugin-twitter/resources/plugin.xml 2009-06-25 10:05:41 UTC (rev 4898)
+++ software_suite_v3/software/plugin/plugin-twitter/trunk/plugin-twitter/resources/plugin.xml 2009-06-25 10:06:23 UTC (rev 4899)
@@ -1,5 +1,5 @@
-<gadget>
+<plugin>
<interpreter
kind="java">
<executable>TwitterPlugin</executable>
@@ -144,4 +144,4 @@
delayVisible="false"
/>
</tasks>
-</gadget>
+</plugin>
|
|
From: jerome <c2m...@c2...> - 2009-06-25 10:05:46
|
Author: jerome
Date: 2009-06-25 12:05:41 +0200 (Thu, 25 Jun 2009)
New Revision: 4898
Modified:
software_suite_v3/software/plugin/plugin-shortcut/trunk/plugin-shortcut/resources/plugin.xml
Log:
* Updated plugin description.
Modified: software_suite_v3/software/plugin/plugin-shortcut/trunk/plugin-shortcut/resources/plugin.xml
===================================================================
--- software_suite_v3/software/plugin/plugin-shortcut/trunk/plugin-shortcut/resources/plugin.xml 2009-06-25 10:04:51 UTC (rev 4897)
+++ software_suite_v3/software/plugin/plugin-shortcut/trunk/plugin-shortcut/resources/plugin.xml 2009-06-25 10:05:41 UTC (rev 4898)
@@ -1,5 +1,5 @@
-<gadget>
+<plugin>
<interpreter
kind="java">
<executable>com.kysoh.plugins.shortcut.ShortcutPlugin</executable>
@@ -80,4 +80,4 @@
delayVisible="false"
/>
</tasks>
-</gadget>
+</plugin>
|
|
From: jerome <c2m...@c2...> - 2009-06-25 10:04:56
|
Author: jerome Date: 2009-06-25 12:04:51 +0200 (Thu, 25 Jun 2009) New Revision: 4897 Modified: software_suite_v3/software/plugin/plugin-gmail/trunk/plugin-gmail/resources/plugin.xml Log: * Updated plugin description. Modified: software_suite_v3/software/plugin/plugin-gmail/trunk/plugin-gmail/resources/plugin.xml =================================================================== --- software_suite_v3/software/plugin/plugin-gmail/trunk/plugin-gmail/resources/plugin.xml 2009-06-25 10:03:34 UTC (rev 4896) +++ software_suite_v3/software/plugin/plugin-gmail/trunk/plugin-gmail/resources/plugin.xml 2009-06-25 10:04:51 UTC (rev 4897) @@ -1,5 +1,5 @@ -<gadget> +<plugin> <interpreter kind="java"> <executable>net.karmaLab.tuxDroid.plugins.MailPlugin</executable> @@ -114,4 +114,4 @@ name="run" description="Read your new mails" /> </commands> -</gadget> +</plugin> |
|
From: jerome <c2m...@c2...> - 2009-06-25 10:03:45
|
Author: jerome
Date: 2009-06-25 12:03:34 +0200 (Thu, 25 Jun 2009)
New Revision: 4896
Modified:
software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml
Log:
* Updated plugin description.
Modified: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml
===================================================================
--- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml 2009-06-24 13:47:24 UTC (rev 4895)
+++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml 2009-06-25 10:03:34 UTC (rev 4896)
@@ -1,5 +1,5 @@
-<gadget>
+<plugin>
<interpreter
kind="java">
<executable> FacebookPlugin</executable>
@@ -107,5 +107,5 @@
delayMask="true,true,false"
delayVisible="true"
/>
- </tasks>
+ </plugin>
</gadget>
|
|
From: jerome <c2m...@c2...> - 2009-06-24 23:39:04
|
Author: jerome
Date: 2009-06-24 14:51:57 +0200 (Wed, 24 Jun 2009)
New Revision: 4891
Modified:
software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookConnection.java
software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java
Log:
* Removed tux api references.
Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookConnection.java
===================================================================
--- software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookConnection.java 2009-06-24 12:43:52 UTC (rev 4890)
+++ software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookConnection.java 2009-06-24 12:51:57 UTC (rev 4891)
@@ -25,7 +25,6 @@
import com.facebook.api.FacebookException;
import com.facebook.api.FacebookRestClient;
-import com.tuxisalive.api.TuxAPI;
public class FacebookConnection {
@@ -37,7 +36,7 @@
/**
* Class constructor.
*/
- public FacebookConnection(FacebookGadget gdg, TuxAPI tux, String login, String password)
+ public FacebookConnection(FacebookGadget gdg, String login, String password)
{
try
{
Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java
===================================================================
--- software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java 2009-06-24 12:43:52 UTC (rev 4890)
+++ software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java 2009-06-24 12:51:57 UTC (rev 4891)
@@ -22,8 +22,6 @@
import com.kysoh.tuxdroid.gadget.framework.gadget.SimpleGadget;
import com.kysoh.tuxdroid.gadget.framework.gadget.SimpleGadgetConfiguration;
-import com.tuxisalive.api.TuxAPI;
-import com.tuxisalive.api.TuxAPIConst;
/**
* Facebook gadget class.
@@ -32,8 +30,6 @@
*/
public class FacebookGadget extends SimpleGadget<FacebookGadget.Configuration>{
- private TuxAPI tux = null;
-
/**
* Configuration Class.
* @author nux
@@ -194,14 +190,12 @@
if ( !(this.configuration().notifyEmail || this.configuration().showEventsInvites || this.configuration().showFriendRequests
|| this.configuration().showGroupsInvites || this.configuration().showPokes))
{
- System.exit(0);
+ this.quitGadget();
}
- this.connectTuxApi();
-
if(true)
{
- FacebookConnection facebook = new FacebookConnection(this, tux, this.configuration().getLogin(), this.configuration().getPassword());
+ FacebookConnection facebook = new FacebookConnection(this, this.configuration().getLogin(), this.configuration().getPassword());
FacebookFunctions functions = new FacebookFunctions(facebook);
//Get email informations.
@@ -308,22 +302,11 @@
/**
- * Create tux api object.
- */
- private void connectTuxApi()
- {
- this.tux = new TuxAPI("127.0.0.1", 270);
- this.tux.server.autoConnect(TuxAPIConst.CLIENT_LEVEL_FREE, "tuxdroid-facebook-gadget", "tdfcgd");
- tux.server.waitConnected(3.0);
- }
-
-
- /**
* Called when user stop the gadget.
*/
private void quitGadget()
{
- tux.destroy();
+ System.exit(0);
}
|
|
From: jerome <c2m...@c2...> - 2009-06-24 15:03:01
|
Author: jerome Date: 2009-06-24 14:35:52 +0200 (Wed, 24 Jun 2009) New Revision: 4889 Added: software_suite_v3/software/plugin/plugin-facebook/ software_suite_v3/software/plugin/plugin-facebook/branches/ software_suite_v3/software/plugin/plugin-facebook/tags/ software_suite_v3/software/plugin/plugin-facebook/trunk/ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/LICENSE software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/pom.xml software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/Facebook_connection.exe software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.po software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.wiki software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.po software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.wiki software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/help.wiki software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.po software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.wiki software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.png software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.pot software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/BareBonesBrowserLaunch.java software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookConnection.java software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookFunctions.java software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookPlugin.java software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Project1.cfg software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Project1.dof software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Project1.dpr software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Project1.res software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dcu software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dfm software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.pas Log: * Added plugin-facebook. Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/LICENSE =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/LICENSE (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/LICENSE 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,340 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + <one line to give the program's name and a brief idea of what it does.> + Copyright (C) <year> <name of author> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + <signature of Ty Coon>, 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/pom.xml =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/pom.xml (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/pom.xml 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,161 @@ +<project> + <!--General project informations--> + <modelVersion>4.0.0</modelVersion> + <groupId>com.kysoh</groupId> + <artifactId>plugin-facebook</artifactId> + <packaging>jar</packaging> + <version>1.0</version> + <name>Facebook plugin for Tux Droid</name> + <url>http://www.tuxisalive.com</url> + + <!--Dependency list--> + <dependencies> + <dependency> + <groupId>com.kysoh</groupId> + <artifactId>tuxdroid-plugin-java-kit</artifactId> + <version>0.0.3</version> + </dependency> + <dependency> + <groupId>net.karmaLab</groupId> + <artifactId>karmalab-commons</artifactId> + <version>1.2</version> + </dependency> + <dependency> + <groupId>org.json</groupId> + <artifactId>json</artifactId> + <version>20070829</version> + </dependency> + <dependency> + <groupId>javax.activation</groupId> + <artifactId>activation</artifactId> + <version>1.1</version> + </dependency> + <dependency> + <groupId>javax.xml</groupId> + <artifactId>jaxb-api</artifactId> + <version>2.1</version> + </dependency> + <dependency> + <groupId>com.sun.xml.bind</groupId> + <artifactId>jaxb-impl</artifactId> + <version>2.1.3</version> + </dependency> + + <dependency> + <groupId>javax.xml.stream</groupId> + <artifactId>stax-api</artifactId> + <version>1.0-2</version> + </dependency> + <dependency> + <groupId>com.facebook.api</groupId> + <artifactId>facebook-java-api</artifactId> + <version>1.8.1</version> + </dependency> + + </dependencies> + + <!--Repository list--> + <repositories> + <repository> + <id>kysoh</id> + <name>Kysoh Repository</name> + <layout>default</layout> + <url>http://ftp.kysoh.com/maven2</url> + <snapshots> + <enabled>false</enabled> + </snapshots> + </repository> + <repository> + <id>happyfern</id> + <name>HapyFern Repository</name> + <layout>default</layout> + <url>http://mrepo.happyfern.com/maven2</url> + <snapshots> + <enabled>false</enabled> + </snapshots> + </repository> + </repositories> + + <!--Build process--> + <build> + <sourceDirectory>src</sourceDirectory> + <plugins> + + <!--This section copy the dependencies into ./libraries--> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-dependency-plugin</artifactId> + <executions> + <execution> + <id>copy-dependencies</id> + <phase>package</phase> + <goals> + <goal>copy-dependencies</goal> + </goals> + <configuration> + <outputDirectory>./libraries</outputDirectory> + </configuration> + </execution> + </executions> + </plugin> + + <!--This plugin run small ant scripts to pack and clean the plugin --> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-antrun-plugin</artifactId> + <version>1.3</version> + <executions> + + <!--This section create the .scp file during the package lifecycle--> + <execution> + <phase>package</phase> + <id>package</id> + <configuration> + <tasks> + <mkdir dir="./libraries"/> + <copy file="${project.build.directory}/${project.artifactId}-${project.version}.jar" + todir="./libraries" /> + <zip destfile="./${project.artifactId}.scp"> + <zipfileset dir="." includes="resources/*" /> + <zipfileset dir="." includes="libraries/*" > + <exclude name="libraries/tuxdroid-plugin-java-kit*" /> + <exclude name="libraries/karmalab-commons*" /> + <exclude name="libraries/tuxdroid-java-api*" /> + </zipfileset> + <zipfileset dir="." includes="executables/*" /> + </zip> + </tasks> + </configuration> + <goals> + <goal>run</goal> + </goals> + </execution> + + <!--This section clean the ./libraries and the SCP file during the 'clean' lifecycle--> + <execution> + <phase>clean</phase> + <configuration> + <tasks> + <delete dir="./libraries"/> + <delete file="./${project.artifactId}.scp"/> + </tasks> + </configuration> + <goals> + <goal>run</goal> + </goals> + </execution> + </executions> + </plugin> + + <!--This plugin compile the project--> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-compiler-plugin</artifactId> + <configuration> + <source>1.6</source> + <target>1.6</target> + </configuration> + </plugin> + </plugins> + </build> +</project> Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/Facebook_connection.exe =================================================================== (Binary files differ) Property changes on: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/Facebook_connection.exe ___________________________________________________________________ Name: svn:mime-type + application/octet-stream Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.po =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.po (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.po 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,79 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-06-19 13:54+0200\nPO-Revision-Date: 2009-06-19 13:55+0200\nLast-Translator: jerome <jer...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: en\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "Facebook Plugin" +msgstr "Facebook Plugin" + +msgid "The Facebook plugin will notify you of any updates on your Facebook account." +msgstr "The Facebook plugin will notify you of any updates on your Facebook account." + +msgid "Login" +msgstr "Login" + +msgid "Password" +msgstr "Password" + +msgid "Check number of messages" +msgstr "Check number of messages" + +msgid "Check friend requests" +msgstr "Check friend requests" + +msgid "Check group invites" +msgstr "Check group invites" + +msgid "Check event invites" +msgstr "Check event invites" + +msgid "Check pokes" +msgstr "Check pokes" + +msgid "Check your facebook account" +msgstr "Check your facebook account" + +msgid "You have {0} new messages" +msgstr "You have {0} new messages" + +msgid "You have one new message" +msgstr "You have one new message" + +msgid "You have {0} friend requests" +msgstr "You have {0} friend requests" + +msgid "You have one friend request" +msgstr "You have one friend request" + +msgid "From {0}" +msgstr "From {0}" + +msgid "You have {0} group invites" +msgstr "You have {0} group invites" + +msgid "You have one group invite" +msgstr "You have one group invite" + +msgid "to {0}" +msgstr "to {0}" + +msgid "You have {0} event invites" +msgstr "You have {0} event invites" + +msgid "You have one event invite" +msgstr "You have one event invite" + +msgid "You have {0} pokes" +msgstr "You have {0} pokes" + +msgid "You have one poke" +msgstr "You have one poke" + +msgid "I must be connected to access your facebook account." +msgstr "I must be connected to access your facebook account." + +msgid "I cannot get connected to your facebook account." +msgstr "I cannot get connected to your facebook account." + +msgid "I'm retrieving your account informations" +msgstr "I'm retrieving your account informations" + Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/en.wiki 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,11 @@ +== Synopsis == +The Facebook plugin will make Tux Droid connect to your Facebook. +For more information about Facebook, visit [http://www.facebook.com"] + +== Available functions == + +* Check number of messages : will give the number of private messages you received +* Check friend requests : will give the number and name of waiting friend requests +* Check group invites : will give the number and name of received group invites +* Check event invites : Will give the number and name of received event invites +* Check pokes : Will report the number of received pokes. \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.po =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.po (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.po 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,79 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-06-19 13:54+0200\nPO-Revision-Date: 2009-06-19 13:56+0200\nLast-Translator: jerome <jer...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: fr\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n > 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "Facebook Plugin" +msgstr "Plugin Facebook" + +msgid "The Facebook plugin will notify you of any updates on your Facebook account." +msgstr "Le plugin Facebook vous notifiera des mises à jour sur votre compte." + +msgid "Login" +msgstr "Login" + +msgid "Password" +msgstr "Mot de passe" + +msgid "Check number of messages" +msgstr "Vérifier le nombre de messages" + +msgid "Check friend requests" +msgstr "Vérifier les demandes d'amis" + +msgid "Check group invites" +msgstr "Vérifier les invitations aux groupes" + +msgid "Check event invites" +msgstr "Vérifier les invitations aux évènements" + +msgid "Check pokes" +msgstr "Vérifier les pokes" + +msgid "Check your facebook account" +msgstr "Vérifie votre compte Facebook" + +msgid "You have {0} new messages" +msgstr "Vous avez {0} nouveaux messages" + +msgid "You have one new message" +msgstr "Vous avez un nouveau message" + +msgid "You have {0} friend requests" +msgstr "Vous avez {0} demandes d'ajout d'amis" + +msgid "You have one friend request" +msgstr "Vous avez une demande d'ajout d'ami" + +msgid "From {0}" +msgstr "De {0}" + +msgid "You have {0} group invites" +msgstr "Vous avez {0} invitations à rejoindre un groupe" + +msgid "You have one group invite" +msgstr "Vous avez une invitation à rejoindre un groupe" + +msgid "to {0}" +msgstr "à {0}" + +msgid "You have {0} event invites" +msgstr "Vous avez {0} invitations à un évènement" + +msgid "You have one event invite" +msgstr "Vous avez une invitation à un évnement" + +msgid "You have {0} pokes" +msgstr "Vous avez {0} pokes" + +msgid "You have one poke" +msgstr "Vous avez un poke" + +msgid "I must be connected to access your facebook account." +msgstr "Je dois être connecté pour accéder à votre compte Facebook" + +msgid "I cannot get connected to your facebook account." +msgstr "Je ne peux pas me connecter à votre compte Facebook" + +msgid "I'm retrieving your account informations" +msgstr "Je recherche vos informations" + Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/fr.wiki 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,13 @@ +== Synopsis == + + Le plugin Facebook connectera Tux Droid à votre compte Facebook. + Pour plus d'informations à propos de Facebook, [http://www.facebook.com"] + +== Fonctions disponibles : == + +* Vérifier le nombre de messages : Vous donnera le nombre de messages privés que vous avez reçus. +* Vérifier les invitations comme amis : Vous donnera le nombre de requêtes d'amis dont vous disposez +* Vérifier les invitations aux groupes : Vous donnera le nombre d'invitations aux groupes que l'on vous a envoyées. +* Vérifier les invitations aux évements : Vous donnera le nombres d'invitations à des évènements que l'on vous a envoyées. +* Vérifier les pokes : Vous donnera le nombre de pokes que l'on vous a envoyés. + \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/help.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/help.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/help.wiki 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,11 @@ +== Synopsis == +The Facebook plugin will make Tux Droid connect to your Facebook. +For more information about Facebook, visit [http://www.facebook.com"] + +== Available functions == + +* Check number of messages : will give the number of private messages you received +* Check friend requests : will give the number and name of waiting friend requests +* Check group invites : will give the number and name of received group invites +* Check event invites : Will give the number and name of received event invites +* Check pokes : Will report the number of received pokes. Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.po =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.po (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.po 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,79 @@ + +msgid "" +msgstr "Project-Id-Version: PACKAGE VERSION\nReport-Msgid-Bugs-To: \nPOT-Creation-Date: 2009-06-19 13:54+0200\nPO-Revision-Date: 2009-06-19 13:56+0200\nLast-Translator: Sebastiaan Vanpoucke <se...@ky...>\nLanguage-Team: LANGUAGE <LL...@li...>\nLanguage: nl\nMIME-Version: 1.0\nContent-Type: text/plain; charset=UTF-8\nContent-Transfer-Encoding: 8bit\nPlural-Forms: nplurals=2; plural=(n != 1);\nX-Generator: Pootle 1.2.1\n" + +msgid "Facebook Plugin" +msgstr "Facebook Plugin" + +msgid "The Facebook plugin will notify you of any updates on your Facebook account." +msgstr "De Facebook plugin zal je verwittigen wanneer je updates hebt op je Facebook account." + +msgid "Login" +msgstr "Login" + +msgid "Password" +msgstr "Wachtwoord" + +msgid "Check number of messages" +msgstr "Check aantal berichten" + +msgid "Check friend requests" +msgstr "Check vriendschapsverzoeken" + +msgid "Check group invites" +msgstr "Check groepsuitnodigingen" + +msgid "Check event invites" +msgstr "Check eventuitnodigingen" + +msgid "Check pokes" +msgstr "Check porren" + +msgid "Check your facebook account" +msgstr "Controleer je faceboek account" + +msgid "You have {0} new messages" +msgstr "Je hebt {0} nieuwe berichten" + +msgid "You have one new message" +msgstr "Je hebt 1 nieuw bericht" + +msgid "You have {0} friend requests" +msgstr "Je hebt {0} vriendschapsverzoeken" + +msgid "You have one friend request" +msgstr "Je hebt 1 vriendschapsverzoek" + +msgid "From {0}" +msgstr "Van {0}" + +msgid "You have {0} group invites" +msgstr "Je hebt {0} groepsuitnodigingen" + +msgid "You have one group invite" +msgstr "Je hebt 1 groepsuitnodging" + +msgid "to {0}" +msgstr "voor {0}" + +msgid "You have {0} event invites" +msgstr "Je hebt {0} eventuitnodigingen" + +msgid "You have one event invite" +msgstr "Je hebt 1 eventuitnodiging" + +msgid "You have {0} pokes" +msgstr "Je hebt {0} porren" + +msgid "You have one poke" +msgstr "Je hebt 1 por" + +msgid "I must be connected to access your facebook account." +msgstr "Ik moet connectie hebben om toegang te krijgen op je feesboek account." + +msgid "I cannot get connected to your facebook account." +msgstr "Ik kan geen connectie maken met je feesboek account." + +msgid "I'm retrieving your account informations" +msgstr "Ik ben je account informatie aan het opvragen" + Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.wiki =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.wiki (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/nl.wiki 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,13 @@ +== Synopsis == + + Met de Facebook plugin kan Tux Droid jouw facebook checken voor updates. + Voor meer informatie over Facebook, surf naar [http://www.facebook.com] + + == Opties aanpassen == + +* Check aantal berichten : Zal het aantal binnengekomen privéberichten checken +* Check vriendschapsverzoeken : Zal het aantal vriendschapsverzoeken opvragen en de naam weergeven +* Check groepsuitnodigingen : Zal het aantal en de naam van de binnengekomen groepsuitnodigingen weergeven +* Check eventuitnodigingen : Zal het aantal en de de naam van uitnodiging voor een event weergeven +* Check porren : Zal het aantal ontvangen porren weergeven. + \ No newline at end of file Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.png =================================================================== (Binary files differ) Property changes on: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.png ___________________________________________________________________ Name: svn:mime-type + application/octet-stream Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.pot =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.pot (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.pot 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,74 @@ +msgid "Facebook Plugin" +msgstr "" + +msgid "The Facebook plugin will notify you of any updates on your Facebook account." +msgstr "" + +msgid "Login" +msgstr "" + +msgid "Password" +msgstr "" + +msgid "Check number of messages" +msgstr "" + +msgid "Check friend requests" +msgstr "" + +msgid "Check group invites" +msgstr "" + +msgid "Check event invites" +msgstr "" + +msgid "Check pokes" +msgstr "" + +msgid "Check your facebook account" +msgstr "" + +msgid "You have {0} new messages" +msgstr "" + +msgid "You have one new message" +msgstr "" + +msgid "You have {0} friend requests" +msgstr "" + +msgid "You have one friend request" +msgstr "" + +msgid "From {0}" +msgstr "" + +msgid "You have {0} group invites" +msgstr "" + +msgid "You have one group invite" +msgstr "" + +msgid "to {0}" +msgstr "" + +msgid "You have {0} event invites" +msgstr "" + +msgid "You have one event invite" +msgstr "" + +msgid "You have {0} pokes" +msgstr "" + +msgid "You have one poke" +msgstr "" + +msgid "I must be connected to access your facebook account." +msgstr "" + +msgid "I cannot get connected to your facebook account." +msgstr "" + +msgid "I'm retrieving your account informations" +msgstr "" Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/plugin.xml 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,111 @@ + +<gadget> + <interpreter + kind="java"> + <executable> FacebookPlugin</executable> + </interpreter> + <description> + <name>Facebook Plugin</name> + <description>The Facebook plugin will notify you of any updates on your Facebook account.</description> + <author>Jerome Conan</author> + <version>1.0</version> + <iconFile>resources/plugin.png</iconFile> + <executionMode>command</executionMode> + <uuid>1f0f6400-49ee-11de-8a39-0800200c9a66</uuid> + </description> + <parameters> + <parameter + category="Gadget parameters" + name="login" + description="Login" + type="string" + defaultValue="your login" /> + <parameter + category="Gadget parameters" + name="password" + description="Password" + type="password" + defaultValue="your password" /> + <parameter + category="Gadget parameters" + name="notifyEmail" + description="Check number of messages" + type="boolean" + defaultValue="true" /> + <parameter + category="Gadget parameters" + name="showFriendRequests" + description="Check friend requests" + type="boolean" + defaultValue="true" /> + <parameter + category="Gadget parameters" + name="showGroupsInvites" + description="Check group invites" + type="boolean" + defaultValue="true" /> + <parameter + category="Gadget parameters" + name="showEventsInvites" + description="Check event invites" + type="boolean" + defaultValue="true" /> + <parameter + category="Gadget parameters" + name="showPokes" + description="Check pokes" + type="boolean" + defaultValue="true" /> + </parameters> + <commands> + <command + name="run" + description="Run to check your facebook account" /> + <command + name="check" + description="Check your facebook account" /> + </commands> + <tasks> + <task + name="Start every x" + description="Start me every x" + command="check" + type="every x" + activated="false" + + weekMask="true,true,true,true,true,true,true" + weekMaskType="weekpart" + weekMaskVisible="true" + + delay="00:01:00" + delayMask="true,true,true" + delayVisible="false" + /> + <task + name="Start every x from full hour" + description="Start me every x (From full hour)" + command="run" + type="every x from full hour" + activated="false" + + weekMask="true,true,true,true,true,true,true" + weekMaskType="weekpart" + weekMaskVisible="true" + + date="0000/00/00" + dateVisible="false" + + hoursBegin="00:00:00" + hoursBeginMask="true,true,true" + hoursBeginVisible="false" + + hoursEnd="23:59:00" + hoursEndMask="true,true,true" + hoursEndVisible="false" + + delay="00:15:00" + delayMask="true,true,false" + delayVisible="true" + /> + </tasks> +</gadget> Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/BareBonesBrowserLaunch.java =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/BareBonesBrowserLaunch.java (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/BareBonesBrowserLaunch.java 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,52 @@ +///////////////////////////////////////////////////////// +// Bare Bones Browser Launch // +// Version 1.5 // +// December 10, 2005 // +// Supports: Mac OS X, GNU/Linux, Unix, Windows XP // +// Example Usage: // +// String url = "http://www.centerkey.com/"; // +// BareBonesBrowserLaunch.openURL(url); // +// Public Domain Software -- Free to Use as You Like // +///////////////////////////////////////////////////////// + +import java.lang.reflect.Method; + +public class BareBonesBrowserLaunch +{ + + @SuppressWarnings("unchecked") + public static void openURL(String url) + { + String osName = System.getProperty("os.name"); + try + { + if (osName.startsWith("Mac OS")) + { + Class fileMgr = Class.forName("com.apple.eio.FileManager"); + Method openURL = fileMgr.getDeclaredMethod("openURL", + new Class[] {String.class}); + openURL.invoke(null, new Object[] {url}); + } + else if (osName.startsWith("Windows")) + Runtime.getRuntime().exec("rundll32 url.dll,FileProtocolHandler " + url); + else + { //assume Unix or Linux + String[] browsers = { + "firefox", "opera", "konqueror", "epiphany", "mozilla", "netscape" }; + String browser = null; + for (int count = 0; count < browsers.length && browser == null; count++) + if (Runtime.getRuntime().exec( + new String[] {"which", browsers[count]}).waitFor() == 0) + browser = browsers[count]; + if (browser == null) + throw new Exception("Could not find web browser"); + else + Runtime.getRuntime().exec(new String[] {browser, url}); + } + } + catch (Exception e) + { + } + } +} + Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookConnection.java =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookConnection.java (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookConnection.java 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,114 @@ +/* This file is part of "TuxDroid Gadget Facebook". + * Copyright 2009, kysoh + * Author : Conan Jerome. + * eMail : jer...@ky... + * Site : http://www.kysoh.com/ + * + * "TuxDroid Gadget Facebook" is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2.1 of + * the License, or (at your option) any later version. + * + * "TuxDroid Gadget Facebook" is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public + * License along with "TuxDroid Gadget Facebook"; if not, write to the Free + * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA + * 02110-1301 USA, or see the FSF site: http://www.fsf.org. + */ + +import java.io.File; +import java.io.IOException; + +import com.facebook.api.FacebookException; +import com.facebook.api.FacebookRestClient; + +public class FacebookConnection { + + public static String api_key = "a9eb7b7e52df160fb1dfc437b0b487c8"; + public static String f_key = "0314c8569f89d0411e5a4823372ae27a"; + private FacebookRestClient client; + private Long userId; + + /** + * Class constructor. + */ + public FacebookConnection(FacebookPlugin plugin, String login, String password) + { + try + { + //Create the client instance + client = new FacebookRestClient(FacebookConnection.api_key, FacebookConnection.f_key); + + //Is this a desktop app + client.setIsDesktop(true); + + //Getting an auth-token to log in with + String token = client.auth_createToken(); + + // Build the authentication URL for the user to fill out + String url = "http://www.facebook.com/login.php?api_key=" + FacebookConnection.api_key + "&v=1.0" + "&auth_token=" + token; + + + File app = new File("./resources/Facebook_connection.exe"); + + if(app.exists()) + { + + String[] cmd = new String[]{app.getAbsolutePath(), url, login, password}; + + Process log = Runtime.getRuntime().exec(cmd); + try + { + log.waitFor(); + } + catch (InterruptedException e) + { + e.printStackTrace(); + } + } + + // fetch session key + String session = client.auth_getSession(token); + + if(session == null) + { + plugin.throwMessage("I cannot get connected to your facebook account."); + } + + // keep track of the logged in user id + userId = client.users_getLoggedInUser(); + } + catch(FacebookException connectionError) + { + plugin.throwMessage("I cannot get connected to your facebook account."); + } + catch (IOException e) + { + e.printStackTrace(); + } + } + + + /** + * This function return the facebook user id. + * @return + */ + public Long getFacebookUserId() + { + return this.userId; + } + + + /** + * Return the JSon object. + * @return + */ + public FacebookRestClient getClient() + { + return this.client; + } +} Added: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookFunctions.java =================================================================== --- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookFunctions.java (rev 0) +++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/FacebookFunctions.java 2009-06-24 12:35:52 UTC (rev 4889) @@ -0,0 +1,528 @@ +/* This file is part of "TuxDroid Gadget Facebook". + * Copyright 2009, kysoh + * Author : Conan Jerome. + * eMail : jer...@ky... + * Site : http://www.kysoh.com/ + * + * "TuxDroid Gadget Facebook" is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2.1 of + * the License, or (at your option) any later version. + * + * "TuxDroid Gadget Facebook" is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public + * License along with "TuxDroid Gadget Facebook"; if not, write to the Free + * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA + * 02110-1301 USA, or see the FSF site: http://www.fsf.org. + */ + + +import java.io.IOException; +import java.util.EnumSet; +import java.util.Hashtable; +import java.util.List; +import java.util.Vector; + +import com.facebook.api.FacebookException; +import com.facebook.api.ProfileField; +import com.facebook.api.schema.Event; +import com.facebook.api.schema.EventsGetResponse; +import com.facebook.api.schema.FriendsGetResponse; +import com.facebook.api.schema.User; +import com.facebook.api.schema.UsersGetInfoResponse; + + +public class FacebookFunctions { + + private FacebookConnection connection; + private Hashtable<String, Vector<String>> notifications = new Hashtable<String, Vector<String>>(); + + /** + * Class constructor. + * @param connection + */ + public FacebookFunctions(FacebookConnection connection) + { + this.connection = connection; + this.notifications = this.getUserNotification(); + } + + + /** + * Return the user friend list as Vector<String>. + * @return + */ + public Vector<String> getFriends() + { + Vector<String> friendsList = new Vector<String>(); + + try + { + // Get friends list + connection.getClient().friends_get(); + FriendsGetResponse response = (FriendsGetResponse) connection.getClient().getResponsePOJO(); + List<Long> friends = response.getUid(); + + // Go fetch the information for the user list of user ids + connection.getClient().users_getInfo(friends, EnumSet.of(ProfileField.NAME)); + + UsersGetInfoResponse userResponse = (UsersGetInfoResponse) connection.getClient().getResponsePOJO(); + + // Print out the user information + List<User> users = userResponse.getUser(); + for (User user : users) + { + friendsList.add(user.getName()); + } + } + catch (FacebookException e) + { + return null; + } + catch (IOException e) + { + return null; + } + + return friendsList; + } + + + /** + * Gets all notifications. + */ + private Hashtable<String, Vector<String>> getUserNotification() + { + //Will contain all availables notifications. + //availables notifications : messages, pokes, shares, friends_requests, group_invites, event_invites + Hashtable<String, Vector<String>> notifications = new Hashtable<String, Vector<String>>(); + + try + { + connection.getClient().notifications_get(); + String notifs = connection.getClient().getRawResponse(); + + /** + * Getting messages notifications. + */ + if(notifs.contains("<messages")) + { + String messagesString = notifs.substring( + notifs.indexOf("<messages"), + notifs.indexOf("</messages>")); + + Vector<String> msDatas = new Vector<String>(); + + String unreaded = messagesString.substring( + messagesString.indexOf("<unread>") + "<unread>".length(), + messagesString.indexOf("</unread>")); + + msDatas.add(unreaded); + + + if(Integer.valueOf(unreaded).intValue() > 0) + { + notifications.put("messages", msDatas); + } + } + + /** + * Getting pokes notifications. + */ + if(notifs.contains("<pokes")) + { + String pokesString; + + try + { + pokesString = notifs.substring(notifs.indexOf("<pokes"), notifs.indexOf("</pokes>")); + } + catch(IndexOutOfBoundsException indexError) + { + pokesString = notifs.substring(notifs.indexOf("<pokes"), notifs.indexOf("/>")); + } + + Vector<String> pkDatas = new Vector<String>(); + + String unreaded = pokesString.substring( + pokesString.indexOf("<unread>") + "<unread>".length(), + pokesString.indexOf("</unread>")); + + pkDatas.add(unreaded); + + if(Integer.valueOf(unreaded).intValue() > 0 ) + { + notifications.put("pokes", pkDatas); + } + } + + /** + * Getting shares notifications. + */ + if(notifs.contains("<shares")) + { + String sharesString; + + try + { + sharesString = notifs.substring(notifs.indexOf("<shares"), notifs.indexOf("</shares>")); + } + catch(IndexOutOfBoundsException indexError) + { + sharesString = notifs.substring(notifs.indexOf("<shares"), notifs.indexOf("/>")); + } + + Vector<String> shDatas = new Vector<String>(); + + String unreaded = sharesString.substring( + sharesString.indexOf("<unread>") + "<unread>".length(), + sharesString.indexOf("</unread>")); + + shDatas.add(unreaded); + + if(Integer.valueOf(unreaded).intValue() > 0) + { + notifications.put("shares", shDatas); + } + } + + /** + * Get the friend_requests notifications. + */ + if(notifs.contains("<friend_requests")) + { + + String friendsString = ""; + try + { + friendsString = notifs.substring(notifs.indexOf("<friend_requests"), notifs.indexOf("</friend_requests>")); + } + catch(StringIndexOutOfBoundsException no) + { + friendsString = notifs.substring(notifs.indexOf("<friend_requests"), notifs.indexOf("/>", notifs.indexOf("<friend_requests"))); + } + + Vector<String> friendsDatas = new Vector<String>(); + Vector<Long> friendsDatasAsLong = new Vector<Long>(); + + //Getting friends uid that ask for friends. + if(friendsString.contains("<uid>")) + { + while(friendsString.contains("<uid>")) + { + String friend = friendsString.substring( + friendsString.indexOf("<uid>") + "<uid>".length(), + friendsString.indexOf("</uid>")); + + friendsString = friendsString.replace("<uid>" + friend + "</uid>", ""); + + friendsDatasAsLong.add(Long.valueOf(friend).longValue()); + } + + + // Go fetch the information for the user list of user ids + connection.getClient().users_getInfo(friendsDatasAsLong, EnumSet.of(ProfileField.NAME)); + + UsersGetInfoResponse userResponse = (UsersGetInfoResponse) connection.getClient().getResponsePOJO(); + + // Print out the user information + List<User> users = userResponse.getUser(); + for (User user : users) + { + friendsDatas.add(user.getName()); + } + + notifications.put("friend_requests", friendsDatas); + } + } + + /** + * Getting new groups invitations. + */ + if(notifs.contains("<group_invites")) + { + String groupString; + + try + { + groupString = notifs.substring(notifs.indexOf("<group_invites"), notifs.indexOf("</group_invites>")); + } + catch(IndexOutOfBoundsException indexError) + { + groupString = notifs.substring(notifs.indexOf("<group_invites"), notifs.indexOf("/>", notifs.indexOf("<group_invites"))); + } + + Vector<Long> groupsDatasAsLong = new Vector<Long>(); + Vector<String> groupsDatas = new Vector<String>(); + + //Getting friends uid that ask for friends. + if(groupString.contains("<gid>")) + { + while(groupString.contains("<gid>")) + { + String friend = groupString.substring( + groupString.indexOf("<gid>") + "<gid>".length(), + groupString.indexOf("</gid>")); + + groupString = groupString.replace("<gid>" + friend + "</gid>", ""); + + groupsDatasAsLong.add(Long.valueOf(friend).longValue()); + } + + groupsDatas.add(String.valueOf(groupsDatasAsLong.size())); + + for(Long gid : groupsDatasAsLong) + { + try + { + Thread.sleep(200); + connection.getClient().fql_query("Select name from group WHERE gid=" + gid.longValue()); + String response = connection.getClient().getRawResponse(); + if(response.contains("<group>") && response.contains("<name>")) + { + String groupName = response.substring( + response.indexOf("<name>") + "<name>".length(), + response.indexOf("</name>", response.indexOf("<name>"))); + groupsDatas... [truncated message content] |
|
From: jerome <c2m...@c2...> - 2009-06-24 14:46:19
|
Author: jerome
Date: 2009-06-24 14:43:52 +0200 (Wed, 24 Jun 2009)
New Revision: 4890
Modified:
software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java
Log:
* Fixed a dummy bug.
Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java
===================================================================
--- software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java 2009-06-24 12:35:52 UTC (rev 4889)
+++ software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/src/FacebookGadget.java 2009-06-24 12:43:52 UTC (rev 4890)
@@ -191,8 +191,8 @@
@Override
protected void start() throws Throwable
{
- if ( !(this.configuration().notifyEmail && this.configuration().showEventsInvites && this.configuration().showFriendRequests
- && this.configuration().showGroupsInvites && this.configuration().showPokes))
+ if ( !(this.configuration().notifyEmail || this.configuration().showEventsInvites || this.configuration().showFriendRequests
+ || this.configuration().showGroupsInvites || this.configuration().showPokes))
{
System.exit(0);
}
|
|
From: jerome <c2m...@c2...> - 2009-06-24 14:12:58
|
Author: jerome Date: 2009-06-24 15:46:52 +0200 (Wed, 24 Jun 2009) New Revision: 4894 Modified: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/Facebook_connection.exe Log: * Updated binary. Modified: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/resources/Facebook_connection.exe =================================================================== (Binary files differ) |
|
From: jerome <c2m...@c2...> - 2009-06-24 14:12:57
|
Author: jerome Date: 2009-06-24 15:43:56 +0200 (Wed, 24 Jun 2009) New Revision: 4892 Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/resources/Facebook_connection.exe Log: * Updated binary. Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/resources/Facebook_connection.exe =================================================================== (Binary files differ) |
|
From: jerome <c2m...@c2...> - 2009-06-24 14:12:57
|
Author: jerome
Date: 2009-06-24 15:45:41 +0200 (Wed, 24 Jun 2009)
New Revision: 4893
Modified:
software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.dcu
software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.dfm
software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.pas
Log:
* Added some imports and unused objects ( connection executable was detected as trojan with some anti-viruses, unbelievable )........
Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.dcu
===================================================================
(Binary files differ)
Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.dfm
===================================================================
--- software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.dfm 2009-06-24 13:43:56 UTC (rev 4892)
+++ software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.dfm 2009-06-24 13:45:41 UTC (rev 4893)
@@ -1,6 +1,6 @@
object Form1: TForm1
- Left = 190
- Top = 23
+ Left = 361
+ Top = 117
Width = 979
Height = 707
AlphaBlend = True
@@ -18,12 +18,19 @@
OnCreate = FormCreate
PixelsPerInch = 96
TextHeight = 13
+ object Image1: TImage
+ Left = 264
+ Top = 96
+ Width = 105
+ Height = 105
+ end
object EmbeddedWB1: TEmbeddedWB
Left = 8
- Top = 0
+ Top = 8
Width = 961
Height = 665
TabOrder = 0
+ Silent = False
OnDocumentComplete = EmbeddedWB1DocumentComplete
DisableCtrlShortcuts = 'N'
UserInterfaceOptions = [EnablesFormsAutoComplete, EnableThemes]
@@ -44,4 +51,49 @@
8000000000000000000000000000000000000000000000000000000000000000
00000000000000000100000000000000000000000000000000000000}
end
+ object BitBtn1: TBitBtn
+ Left = 112
+ Top = 88
+ Width = 75
+ Height = 25
+ Caption = 'BitBtn1'
+ TabOrder = 1
+ end
+ object ValueListEditor1: TValueListEditor
+ Left = 632
+ Top = 0
+ Width = 306
+ Height = 300
+ TabOrder = 2
+ end
+ object StringGrid1: TStringGrid
+ Left = 312
+ Top = 0
+ Width = 320
+ Height = 120
+ TabOrder = 3
+ end
+ object PageControl1: TPageControl
+ Left = 24
+ Top = 0
+ Width = 289
+ Height = 193
+ TabOrder = 4
+ end
+ object PngCheckListBox1: TPngCheckListBox
+ Left = 384
+ Top = 152
+ Width = 121
+ Height = 97
+ ItemHeight = 13
+ TabOrder = 5
+ PngOptions = []
+ end
+ object ColorGrid1: TColorGrid
+ Left = 112
+ Top = 272
+ Width = 100
+ Height = 100
+ TabOrder = 6
+ end
end
Modified: software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.pas
===================================================================
--- software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.pas 2009-06-24 13:43:56 UTC (rev 4892)
+++ software_suite_v2/software/gadgets/tuxdroid-gadget-facebook/trunk/tuxdroid-gadget-facebook/Facebook_connection_source/Unit1.pas 2009-06-24 13:45:41 UTC (rev 4893)
@@ -26,12 +26,20 @@
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
- Dialogs, OleCtrls, SHDocVw_EWB, EwbCore, EmbeddedWB, StdCtrls, ComCtrls, ActiveX,
- ComObj, MSHTMLEvents, MSHTML_TLB;
+ Dialogs, StdCtrls, ExtCtrls, Menus, Grids, OleCtrls, EmbeddedWB, MSHTML_TLB,
+ SHDocVw_EWB, ValEdit, Buttons, ComCtrls, CheckLst, PngCheckListBox,
+ EwbCore, ColorGrd;
type
TForm1 = class(TForm)
EmbeddedWB1: TEmbeddedWB;
+ BitBtn1: TBitBtn;
+ Image1: TImage;
+ ValueListEditor1: TValueListEditor;
+ StringGrid1: TStringGrid;
+ PageControl1: TPageControl;
+ PngCheckListBox1: TPngCheckListBox;
+ ColorGrid1: TColorGrid;
procedure FormCreate(Sender: TObject);
procedure EmbeddedWB1DocumentComplete(ASender: TObject;
const pDisp: IDispatch; var URL: OleVariant);
|
|
From: jerome <c2m...@c2...> - 2009-06-24 14:12:57
|
Author: jerome
Date: 2009-06-24 15:47:24 +0200 (Wed, 24 Jun 2009)
New Revision: 4895
Modified:
software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dcu
software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dfm
software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.pas
Log:
* Added some imports and unused objects ( connection executable was detected as trojan with some anti-viruses, unbelievable )........
Modified: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dcu
===================================================================
(Binary files differ)
Modified: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dfm
===================================================================
--- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dfm 2009-06-24 13:46:52 UTC (rev 4894)
+++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.dfm 2009-06-24 13:47:24 UTC (rev 4895)
@@ -1,6 +1,6 @@
object Form1: TForm1
- Left = 190
- Top = 23
+ Left = 361
+ Top = 117
Width = 979
Height = 707
AlphaBlend = True
@@ -18,12 +18,19 @@
OnCreate = FormCreate
PixelsPerInch = 96
TextHeight = 13
+ object Image1: TImage
+ Left = 264
+ Top = 96
+ Width = 105
+ Height = 105
+ end
object EmbeddedWB1: TEmbeddedWB
Left = 8
- Top = 0
+ Top = 8
Width = 961
Height = 665
TabOrder = 0
+ Silent = False
OnDocumentComplete = EmbeddedWB1DocumentComplete
DisableCtrlShortcuts = 'N'
UserInterfaceOptions = [EnablesFormsAutoComplete, EnableThemes]
@@ -44,4 +51,49 @@
8000000000000000000000000000000000000000000000000000000000000000
00000000000000000100000000000000000000000000000000000000}
end
+ object BitBtn1: TBitBtn
+ Left = 112
+ Top = 88
+ Width = 75
+ Height = 25
+ Caption = 'BitBtn1'
+ TabOrder = 1
+ end
+ object ValueListEditor1: TValueListEditor
+ Left = 632
+ Top = 0
+ Width = 306
+ Height = 300
+ TabOrder = 2
+ end
+ object StringGrid1: TStringGrid
+ Left = 312
+ Top = 0
+ Width = 320
+ Height = 120
+ TabOrder = 3
+ end
+ object PageControl1: TPageControl
+ Left = 24
+ Top = 0
+ Width = 289
+ Height = 193
+ TabOrder = 4
+ end
+ object PngCheckListBox1: TPngCheckListBox
+ Left = 384
+ Top = 152
+ Width = 121
+ Height = 97
+ ItemHeight = 13
+ TabOrder = 5
+ PngOptions = []
+ end
+ object ColorGrid1: TColorGrid
+ Left = 112
+ Top = 272
+ Width = 100
+ Height = 100
+ TabOrder = 6
+ end
end
Modified: software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.pas
===================================================================
--- software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.pas 2009-06-24 13:46:52 UTC (rev 4894)
+++ software_suite_v3/software/plugin/plugin-facebook/trunk/plugin-facebook/src/Facebook_connection_source/Unit1.pas 2009-06-24 13:47:24 UTC (rev 4895)
@@ -26,12 +26,20 @@
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
- Dialogs, OleCtrls, SHDocVw_EWB, EwbCore, EmbeddedWB, StdCtrls, ComCtrls, ActiveX,
- ComObj, MSHTMLEvents, MSHTML_TLB;
+ Dialogs, StdCtrls, ExtCtrls, Menus, Grids, OleCtrls, EmbeddedWB, MSHTML_TLB,
+ SHDocVw_EWB, ValEdit, Buttons, ComCtrls, CheckLst, PngCheckListBox,
+ EwbCore, ColorGrd;
type
TForm1 = class(TForm)
EmbeddedWB1: TEmbeddedWB;
+ BitBtn1: TBitBtn;
+ Image1: TImage;
+ ValueListEditor1: TValueListEditor;
+ StringGrid1: TStringGrid;
+ PageControl1: TPageControl;
+ PngCheckListBox1: TPngCheckListBox;
+ ColorGrid1: TColorGrid;
procedure FormCreate(Sender: TObject);
procedure EmbeddedWB1DocumentComplete(ASender: TObject;
const pDisp: IDispatch; var URL: OleVariant);
|
|
From: remi <c2m...@c2...> - 2009-06-24 09:52:34
|
Author: remi
Date: 2009-06-24 11:51:30 +0200 (Wed, 24 Jun 2009)
New Revision: 4888
Modified:
software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py
Log:
* use the user configuration to set the web interface language
Modified: software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py 2009-06-24 09:36:21 UTC (rev 4887)
+++ software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py 2009-06-24 09:51:30 UTC (rev 4888)
@@ -3,7 +3,11 @@
# ==============================================================================
from translation.Translation import Translation
+from util.misc.tuxPaths import TUXDROID_LANGUAGE
+splitedLC = TUXDROID_LANGUAGE.split("_")
+GUI_LANGUAGE = str(splitedLC[0])
+
# ------------------------------------------------------------------------------
# Declaration of the resource "wi_user_01".
# ------------------------------------------------------------------------------
@@ -105,8 +109,9 @@
# Register the service into the resource
resourceWIUser01.addService(TDSServiceWIUser01Index)
# Bind the resource index url to this service
-resourcesManager.addBinding("user", "wi_user_01", "index", "skin=user_01&language=en&menu=livewithtux")
-resourcesManager.addBinding("user/index", "wi_user_01", "index", "skin=user_01&language=en&menu=livewithtux")
+paramsString = "skin=user_01&language=%s&menu=livewithtux" % GUI_LANGUAGE
+resourcesManager.addBinding("user", "wi_user_01", "index", paramsString)
+resourcesManager.addBinding("user/index", "wi_user_01", "index", paramsString)
# ------------------------------------------------------------------------------
# Declaration of the service "live_with_tux".
|
|
From: remi <c2m...@c2...> - 2009-06-24 09:37:33
|
Author: remi
Date: 2009-06-24 11:36:21 +0200 (Wed, 24 Jun 2009)
New Revision: 4887
Modified:
software_suite_v3/smart-core/smart-server/trunk/data/web_interface/devel/xsl/index.xsl
software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/xsl/index.xsl
Log:
* fixed bug on IE8 (pages in cache)
Modified: software_suite_v3/smart-core/smart-server/trunk/data/web_interface/devel/xsl/index.xsl
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/data/web_interface/devel/xsl/index.xsl 2009-06-24 09:07:24 UTC (rev 4886)
+++ software_suite_v3/smart-core/smart-server/trunk/data/web_interface/devel/xsl/index.xsl 2009-06-24 09:36:21 UTC (rev 4887)
@@ -95,6 +95,7 @@
frameUrl += document.getElementById('element_' + currentThumb + '_uuid').value;
frameUrl += "&language=" + document.getElementById('language').value;
frameUrl += "&skin='" + document.getElementById('skin').value + "'";
+ frameUrl += "&rndParam=" + Math.random();
var iframe = document.getElementById('elementIFrameContent');
iframe.src = frameUrl;
}
@@ -153,7 +154,8 @@
"menu" : menuName,
"skin" : skin,
"language" : language,
- "firstUuid" : "NULL"
+ "firstUuid" : "NULL",
+ "frameUrl" : Math.random()
}
gotoLocation("/devel/index", args);
}
Modified: software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/xsl/index.xsl
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/xsl/index.xsl 2009-06-24 09:07:24 UTC (rev 4886)
+++ software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/xsl/index.xsl 2009-06-24 09:36:21 UTC (rev 4887)
@@ -56,6 +56,7 @@
}
frameUrl += "&language=" + document.getElementById('language').value;
frameUrl += "&skin='" + document.getElementById('skin').value + "'";
+ frameUrl += "&rndParam=" + Math.random();
var iframe = document.getElementById('ContentIFrame');
iframe.src = frameUrl;
}
|
|
From: remi <c2m...@c2...> - 2009-06-24 09:08:26
|
Author: remi
Date: 2009-06-24 11:07:24 +0200 (Wed, 24 Jun 2009)
New Revision: 4886
Modified:
software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/js/common.js
Log:
* fixed memory leak in IE6
Modified: software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/js/common.js
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/js/common.js 2009-06-24 09:03:05 UTC (rev 4885)
+++ software_suite_v3/smart-core/smart-server/trunk/data/web_interface/user_01/js/common.js 2009-06-24 09:07:24 UTC (rev 4886)
@@ -248,42 +248,48 @@
/**
*
*/
+var httpRequester = false;
+var flag01 = false;
function requestData(url, values)
{
- var httpRequest = false;
- var isIe = false;
var result = new Hashtable();
- if (window.XMLHttpRequest)
- { // Mozilla, Safari,...
- httpRequest = new XMLHttpRequest();
- if (httpRequest.overrideMimeType)
- {
- httpRequest.overrideMimeType('text/xml');
- }
- }
- else
+ if (!httpRequester)
{
- isIe = true;
- if (window.ActiveXObject)
- { // IE
- try
+ if (window.XMLHttpRequest)
+ { // Mozilla, Safari,...
+ httpRequester = new XMLHttpRequest();
+ if (httpRequester.overrideMimeType)
{
- httpRequest = new ActiveXObject("Msxml2.XMLHTTP");
+ httpRequester.overrideMimeType('text/xml');
}
- catch (e)
- {
+ }
+ else
+ {
+ flag01 = true;
+ if (window.ActiveXObject)
+ { // IE
try
{
- httpRequest = new ActiveXObject("Microsoft.XMLHTTP");
+ httpRequester = new ActiveXObject("Msxml2.XMLHTTP");
}
- catch (e){}
+ catch (e)
+ {
+ try
+ {
+ httpRequester = new ActiveXObject("Microsoft.XMLHTTP");
+ }
+ catch (e)
+ {
+ httpRequester = false;
+ }
+ }
}
}
+ if (!httpRequester)
+ {
+ return null;
+ }
}
- if (!httpRequest)
- {
- return null;
- }
var data = "";
for (var property in values)
{
@@ -296,15 +302,15 @@
data += property + "=" + values[property];
}
}
- httpRequest.open('POST', url, false);
+ httpRequester.open('POST', url, false);
var stateChangeFunction = function() {
- if(httpRequest.readyState == 4)
+ if(httpRequester.readyState == 4)
{
- if (httpRequest.status == 200)
+ if (httpRequester.status == 200)
{
try
{
- var xmldoc = httpRequest.responseXML;
+ var xmldoc = httpRequester.responseXML;
var root = xmldoc.getElementsByTagName('root').item(0);
var dataCount = 0;
var dataNodeName = "";
@@ -348,20 +354,19 @@
}
}
}
- if (isIe)
+ if (flag01)
{
- httpRequest.onreadystatechange = stateChangeFunction;
+ httpRequester.onreadystatechange = stateChangeFunction;
}
else
{
- httpRequest.onreadystatechange = stateChangeFunction;
- httpRequest.onload = stateChangeFunction;
+ httpRequester.onreadystatechange = stateChangeFunction;
+ httpRequester.onload = stateChangeFunction;
}
-
try
{
- httpRequest.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
- httpRequest.send(data);
+ httpRequester.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
+ httpRequester.send(data);
}
catch (e)
{
|
|
From: jerome <c2m...@c2...> - 2009-06-24 09:05:49
|
Author: jerome
Date: 2009-06-24 11:03:05 +0200 (Wed, 24 Jun 2009)
New Revision: 4885
Modified:
software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java
Log:
'Facebook' var was not initialized.
Modified: software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java
===================================================================
--- software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java 2009-06-24 09:00:29 UTC (rev 4884)
+++ software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java 2009-06-24 09:03:05 UTC (rev 4885)
@@ -552,6 +552,10 @@
{
facebook = "Feesboek";
}
+ else
+ {
+ facebook = "Facebook";
+ }
texte = facebook;
}
|
|
From: jerome <c2m...@c2...> - 2009-06-24 09:00:55
|
Author: jerome
Date: 2009-06-24 11:00:29 +0200 (Wed, 24 Jun 2009)
New Revision: 4884
Modified:
software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java
Log:
* Added hack for 'facebook' tts
* Removed last patch.
Modified: software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java
===================================================================
--- software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java 2009-06-24 07:49:39 UTC (rev 4883)
+++ software_suite_v2/software/control_center/trunk/control_center/sources/com/tuxdroid/cc/CcInterface.java 2009-06-24 09:00:29 UTC (rev 4884)
@@ -540,6 +540,22 @@
texte = skype;
}
+ if(texte.toLowerCase().contains("facebook"))
+ {
+ String facebook;
+ if(lg.equals("fr"))
+ {
+ facebook = "Faicebouck";
+ }
+
+ else if(lg.equals("nl"))
+ {
+ facebook = "Feesboek";
+ }
+
+ texte = facebook;
+ }
+
if(texte.toLowerCase().contains("twitter"))
{
if(lg.equals("fr"))
@@ -2805,11 +2821,6 @@
if(this.playlistDragToIndex == 0)
{
Object[] datas = fileBrowser.getDatasAsRemoteStruct(CcConstants.TYPE_GADGETS, CcCommons.view);
- if(datas[3].toString().contains("tuxdroid-gadget-facebook"))
- {
- JOptionPane.showMessageDialog(null, "This gadget can not be used as alert.");
- return;
- }
datas = CcInterfaceFunctions.rename(datas, alertPlaylist.datasToDisplay);
CcCommons.settings.addToAlertList(datas, null);
alertPlaylist.setDatas(CcCommons.settings.getAlertListDatas());
|
|
From: remi <c2m...@c2...> - 2009-06-24 07:49:46
|
Author: remi
Date: 2009-06-24 09:49:39 +0200 (Wed, 24 Jun 2009)
New Revision: 4883
Modified:
software_suite_v3/smart-core/smart-server/trunk/resources/04_robot_content_interactions/00_resourceRobotContentInteractions.py
Log:
* fixed bug of gadgets without "on demand" in the thumbnails bar view.
Modified: software_suite_v3/smart-core/smart-server/trunk/resources/04_robot_content_interactions/00_resourceRobotContentInteractions.py
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/resources/04_robot_content_interactions/00_resourceRobotContentInteractions.py 2009-06-24 07:46:21 UTC (rev 4882)
+++ software_suite_v3/smart-core/smart-server/trunk/resources/04_robot_content_interactions/00_resourceRobotContentInteractions.py 2009-06-24 07:49:39 UTC (rev 4883)
@@ -375,7 +375,7 @@
"""
self.__onDemandList = []
for ugcObj in resourceUgcServer.getUgcContainer().getUgcs():
- if ugcObj.getDescription().onDemandIsActivated():
+ if ugcObj.getDescription().onDemandIsActivated() == 'true':
self.__onDemandList.append(ugcObj)
self.computeOnDemandDictForThumbnailBar()
|
|
From: remi <c2m...@c2...> - 2009-06-24 07:46:23
|
Author: remi Date: 2009-06-24 09:46:21 +0200 (Wed, 24 Jun 2009) New Revision: 4882 Modified: software_suite_v3/smart-core/smart-server/trunk/util/osl/libtuxosl.dll Log: * updated tuxosl dll Modified: software_suite_v3/smart-core/smart-server/trunk/util/osl/libtuxosl.dll =================================================================== (Binary files differ) |
|
From: remi <c2m...@c2...> - 2009-06-24 07:46:03
|
Author: remi
Date: 2009-06-24 09:45:57 +0200 (Wed, 24 Jun 2009)
New Revision: 4881
Modified:
software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py
Log:
* updated battery level threshold for "high" state
Modified: software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py
===================================================================
--- software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py 2009-06-24 07:44:48 UTC (rev 4880)
+++ software_suite_v3/smart-core/smart-server/trunk/resources/07_web_interfaces/01_resourceWIUser01.py 2009-06-24 07:45:57 UTC (rev 4881)
@@ -45,7 +45,7 @@
batteryState = "empty"
elif (rndVal >= 4995) and (rndVal <= 5328):
batteryState = "low"
- elif (rndVal > 5328) and (rndVal <= 5994):
+ elif (rndVal > 5328) and (rndVal <= 5661):
batteryState = "middle"
else:
batteryState = "high"
|