rhodes 3.3.3.beta.4 → 3.3.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (497) hide show
  1. data/CHANGELOG +7 -5
  2. data/CREDITS +2215 -0
  3. data/Rakefile +225 -59
  4. data/bin/c2dm.rb +0 -0
  5. data/bin/get-rhodes-info.bat +0 -0
  6. data/bin/migrate-rhodes-app +0 -0
  7. data/bin/migrate-rhodes-app.bat +0 -0
  8. data/bin/rhodes +0 -0
  9. data/bin/rhodes-setup +0 -0
  10. data/bin/rhodes-setup.bat +0 -0
  11. data/bin/rhogen +0 -0
  12. data/bin/rhogen.bat +0 -0
  13. data/bin/set-rhodes-sdk +0 -0
  14. data/bin/set-rhodes-sdk.bat +0 -0
  15. data/bin/upgrade-rhodes-app +0 -0
  16. data/bin/upgrade-rhodes-app.bat +0 -0
  17. data/doc/build.txt +20 -9
  18. data/doc/configuration.txt +8 -8
  19. data/doc/connect-to-web-services.txt +1 -1
  20. data/doc/device-caps.txt +63 -26
  21. data/doc/extensions.txt +14 -2
  22. data/doc/install.txt +28 -19
  23. data/doc/introduction.txt +6 -3
  24. data/doc/jqt-jqm-transition.txt +10 -9
  25. data/doc/release.txt +5 -1
  26. data/doc/rhodes-command-line.txt +130 -0
  27. data/doc/rhom.txt +16 -11
  28. data/doc/rhostudio-eclipse.txt +3 -3
  29. data/doc/simulator.txt +28 -31
  30. data/doc/syncengine-ajax-api.txt +246 -0
  31. data/doc/synchronization.txt +21 -3
  32. data/doc/test-log-debug.txt +3 -1
  33. data/doc/ui.txt +16 -16
  34. data/ext/extconf.rb +8 -0
  35. data/lib/build/jake.rb +5 -5
  36. data/lib/extensions/barcode/ext/barcode/platform/android/Rakefile +9 -9
  37. data/lib/extensions/barcode/ext/barcode/platform/android/jni/src/barcode.cpp +81 -1
  38. data/lib/extensions/barcode/ext/barcode/platform/android/src/com/google/zxing/client/android/CaptureActivityHandler.java +6 -13
  39. data/lib/extensions/barcode/ext/barcode/platform/android/src/com/google/zxing/client/android/DecodeHandler.java +2 -6
  40. data/lib/extensions/barcode/ext/barcode/platform/android/src/com/rhomobile/barcode/Barcode.java +12 -1
  41. data/lib/extensions/barcode/ext/barcode/platform/bb/run.bat +0 -0
  42. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeCallbackHelper.h +2 -0
  43. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeCallbackHelper.mm +36 -0
  44. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeViewController.h +0 -0
  45. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeViewController.m +15 -5
  46. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/barcode.m +64 -1
  47. data/lib/extensions/barcode/ext/barcode/shared/ruby/barcode.i +35 -1
  48. data/lib/extensions/barcode/ext/barcode/shared/ruby/barcode_wrap.c +126 -2
  49. data/lib/extensions/barcode/ext/barcode/shared/src/zbar.c +18 -1
  50. data/lib/extensions/barcode/ext/build +0 -0
  51. data/lib/extensions/barcode/ext/build.bat +0 -0
  52. data/lib/extensions/digest-md5/ext/Rakefile +12 -10
  53. data/lib/extensions/digest-md5/ext/build +0 -0
  54. data/lib/extensions/digest-md5/ext/build.bat +0 -0
  55. data/lib/extensions/digest-md5/ext/digest-md5.sln +2 -2
  56. data/lib/extensions/digest-md5/ext/digest-md5.vcproj +41 -28
  57. data/lib/extensions/digest-sha1/ext/Rakefile +11 -10
  58. data/lib/extensions/digest-sha1/ext/build +0 -0
  59. data/lib/extensions/digest-sha1/ext/build.bat +0 -0
  60. data/lib/extensions/digest-sha1/ext/digest-sha1.sln +2 -2
  61. data/lib/extensions/digest-sha1/ext/digest-sha1.vcproj +41 -28
  62. data/lib/extensions/digest/ext/Rakefile +12 -11
  63. data/lib/extensions/digest/ext/build +0 -0
  64. data/lib/extensions/digest/ext/build.bat +0 -0
  65. data/lib/extensions/digest/ext/digest.sln +44 -0
  66. data/lib/extensions/digest/ext/digest.vcproj +40 -27
  67. data/lib/extensions/esri/ext/build +0 -0
  68. data/lib/extensions/esri/ext/build.bat +0 -0
  69. data/lib/extensions/fcntl/ext/Rakefile +10 -9
  70. data/lib/extensions/fcntl/ext/build +0 -0
  71. data/lib/extensions/fcntl/ext/build.bat +0 -0
  72. data/lib/extensions/fcntl/ext/fcntl.vcproj +1 -1
  73. data/lib/extensions/nfc/ext/build +0 -0
  74. data/lib/extensions/nfc/ext/build.bat +0 -0
  75. data/lib/extensions/nfc/ext/nfc/platform/android/Rakefile +11 -11
  76. data/lib/extensions/nfc/ext/nfc/platform/android/jni/src/nfc.cpp +0 -0
  77. data/lib/extensions/nfc/ext/nfc/platform/android/src/com/rhomobile/nfc/Nfc.java +12 -10
  78. data/lib/extensions/nfc/ext/nfc/shared/ruby/nfc_wrap.c +16 -9
  79. data/lib/extensions/pdf-writer/color.rb +145 -0
  80. data/lib/extensions/pdf-writer/color/cmyk.rb +279 -0
  81. data/lib/extensions/pdf-writer/color/css.rb +28 -0
  82. data/lib/extensions/pdf-writer/color/grayscale.rb +212 -0
  83. data/lib/extensions/pdf-writer/color/hsl.rb +221 -0
  84. data/lib/extensions/pdf-writer/color/palette.rb +16 -0
  85. data/lib/extensions/pdf-writer/color/palette/adobecolor.rb +272 -0
  86. data/lib/extensions/pdf-writer/color/palette/gimp.rb +116 -0
  87. data/lib/extensions/pdf-writer/color/palette/monocontrast.rb +180 -0
  88. data/lib/extensions/pdf-writer/color/rgb-colors.rb +355 -0
  89. data/lib/extensions/pdf-writer/color/rgb.rb +453 -0
  90. data/lib/extensions/pdf-writer/color/rgb/metallic.rb +43 -0
  91. data/lib/extensions/pdf-writer/color/yiq.rb +84 -0
  92. data/lib/extensions/pdf-writer/ext/LICENSES/color/Licence.txt +27 -0
  93. data/lib/extensions/pdf-writer/ext/LICENSES/color/README.txt +32 -0
  94. data/lib/extensions/pdf-writer/ext/LICENSES/pdf-writer/LICENCE +131 -0
  95. data/lib/extensions/pdf-writer/ext/LICENSES/pdf-writer/README +33 -0
  96. data/lib/extensions/pdf-writer/ext/LICENSES/transaction-simple/Licence.txt +25 -0
  97. data/lib/extensions/pdf-writer/ext/LICENSES/transaction-simple/Readme.txt +204 -0
  98. data/lib/extensions/pdf-writer/pdf/charts.rb +13 -0
  99. data/lib/extensions/pdf-writer/pdf/charts/stddev.rb +430 -0
  100. data/lib/extensions/pdf-writer/pdf/math.rb +108 -0
  101. data/lib/extensions/pdf-writer/pdf/quickref.rb +332 -0
  102. data/lib/extensions/pdf-writer/pdf/simpletable.rb +947 -0
  103. data/lib/extensions/pdf-writer/pdf/techbook.rb +901 -0
  104. data/lib/extensions/pdf-writer/pdf/writer.rb +2729 -0
  105. data/lib/extensions/pdf-writer/pdf/writer/arc4.rb +63 -0
  106. data/lib/extensions/pdf-writer/pdf/writer/fontmetrics.rb +203 -0
  107. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-Bold.afm +342 -0
  108. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-BoldOblique.afm +342 -0
  109. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-Oblique.afm +342 -0
  110. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier.afm +342 -0
  111. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-Bold.afm +2827 -0
  112. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-BoldOblique.afm +2827 -0
  113. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-Oblique.afm +3051 -0
  114. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica.afm +3051 -0
  115. data/lib/extensions/pdf-writer/pdf/writer/fonts/MustRead.html +19 -0
  116. data/lib/extensions/pdf-writer/pdf/writer/fonts/Symbol.afm +213 -0
  117. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Bold.afm +2588 -0
  118. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-BoldItalic.afm +2384 -0
  119. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Italic.afm +2667 -0
  120. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Roman.afm +2419 -0
  121. data/lib/extensions/pdf-writer/pdf/writer/fonts/ZapfDingbats.afm +225 -0
  122. data/lib/extensions/pdf-writer/pdf/writer/graphics.rb +813 -0
  123. data/lib/extensions/pdf-writer/pdf/writer/graphics/imageinfo.rb +365 -0
  124. data/lib/extensions/pdf-writer/pdf/writer/lang.rb +43 -0
  125. data/lib/extensions/pdf-writer/pdf/writer/lang/en.rb +99 -0
  126. data/lib/extensions/pdf-writer/pdf/writer/object.rb +23 -0
  127. data/lib/extensions/pdf-writer/pdf/writer/object/action.rb +35 -0
  128. data/lib/extensions/pdf-writer/pdf/writer/object/annotation.rb +42 -0
  129. data/lib/extensions/pdf-writer/pdf/writer/object/catalog.rb +39 -0
  130. data/lib/extensions/pdf-writer/pdf/writer/object/contents.rb +65 -0
  131. data/lib/extensions/pdf-writer/pdf/writer/object/destination.rb +40 -0
  132. data/lib/extensions/pdf-writer/pdf/writer/object/encryption.rb +53 -0
  133. data/lib/extensions/pdf-writer/pdf/writer/object/font.rb +72 -0
  134. data/lib/extensions/pdf-writer/pdf/writer/object/fontdescriptor.rb +34 -0
  135. data/lib/extensions/pdf-writer/pdf/writer/object/fontencoding.rb +40 -0
  136. data/lib/extensions/pdf-writer/pdf/writer/object/image.rb +304 -0
  137. data/lib/extensions/pdf-writer/pdf/writer/object/info.rb +51 -0
  138. data/lib/extensions/pdf-writer/pdf/writer/object/outline.rb +30 -0
  139. data/lib/extensions/pdf-writer/pdf/writer/object/outlines.rb +30 -0
  140. data/lib/extensions/pdf-writer/pdf/writer/object/page.rb +195 -0
  141. data/lib/extensions/pdf-writer/pdf/writer/object/pages.rb +115 -0
  142. data/lib/extensions/pdf-writer/pdf/writer/object/procset.rb +46 -0
  143. data/lib/extensions/pdf-writer/pdf/writer/object/viewerpreferences.rb +74 -0
  144. data/lib/extensions/pdf-writer/pdf/writer/ohash.rb +58 -0
  145. data/lib/extensions/pdf-writer/pdf/writer/oreader.rb +25 -0
  146. data/lib/extensions/pdf-writer/pdf/writer/state.rb +48 -0
  147. data/lib/extensions/pdf-writer/pdf/writer/strokestyle.rb +138 -0
  148. data/lib/extensions/pdf-writer/transaction/simple.rb +486 -0
  149. data/lib/extensions/pdf-writer/transaction/simple/group.rb +146 -0
  150. data/lib/extensions/pdf-writer/transaction/simple/threadsafe.rb +68 -0
  151. data/lib/extensions/pdf-writer/transaction/simple/threadsafe/group.rb +36 -0
  152. data/lib/framework/builtinME.rb +0 -0
  153. data/lib/framework/dateOrig.rb +8 -2
  154. data/lib/framework/rational.rb +0 -0
  155. data/lib/framework/res/esri.wm.png +0 -0
  156. data/lib/framework/rho/rho.rb +6 -0
  157. data/lib/framework/rho/rhobluetooth.rb +0 -0
  158. data/lib/framework/rho/rhofsconnector.rb +0 -0
  159. data/lib/framework/rho/rhonativeviewmanager.rb +0 -0
  160. data/lib/framework/rhofsconnector.rb +0 -0
  161. data/lib/framework/rhom/rhom_object_factory.rb +8 -0
  162. data/lib/framework/rhomotoapi.rb +3 -2
  163. data/platform/android/Rhodes/jni/include/rhodes/JNIRhodes.h +9 -1
  164. data/platform/android/Rhodes/jni/include/rhodes/details/rhojava.inc +1 -0
  165. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_file_RhoFileApi.h +26 -2
  166. data/platform/android/Rhodes/jni/src/callbacks.cpp +0 -5
  167. data/platform/android/Rhodes/jni/src/camera.cpp +1 -1
  168. data/platform/android/Rhodes/jni/src/fileapi.cpp +39 -19
  169. data/platform/android/Rhodes/jni/src/geolocation.cpp +3 -3
  170. data/platform/android/Rhodes/jni/src/mapview.cpp +206 -64
  171. data/platform/android/Rhodes/jni/src/nativeview.cpp +1 -1
  172. data/platform/android/Rhodes/jni/src/rhodes.cpp +13 -0
  173. data/platform/android/Rhodes/jni/src/rhodesapp.cpp +20 -0
  174. data/platform/android/Rhodes/jni/src/rhodessystem.cpp +36 -3
  175. data/platform/android/Rhodes/jni/src/signature.cpp +22 -2
  176. data/platform/android/Rhodes/res/drawable/alert_info.png +0 -0
  177. data/platform/android/Rhodes/res/drawable/esri.png +0 -0
  178. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Capabilities.java +17 -16
  179. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Logger.java +4 -1
  180. data/platform/android/Rhodes/src/com/rhomobile/rhodes/MemoryInfoCollector.java +67 -0
  181. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +139 -114
  182. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +106 -13
  183. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +11 -3
  184. data/platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java +71 -16
  185. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraNewService.java +4 -1
  186. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraSemiService.java +4 -1
  187. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoExtension.java +22 -1
  188. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/Config.java +243 -0
  189. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtManager.java +19 -1
  190. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtension.java +9 -1
  191. data/platform/android/Rhodes/src/com/rhomobile/rhodes/{RhodesActivityListener.java → extmanager/IRhoListener.java} +16 -12
  192. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManager.java +63 -1
  193. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManagerImpl.java +239 -14
  194. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhodesStartupListeners.java +9 -0
  195. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/WebkitExtension.java +53 -0
  196. data/platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java +27 -12
  197. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocation.java +124 -62
  198. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java +49 -137
  199. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +84 -114
  200. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SplashScreen.java +75 -82
  201. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java +3 -2
  202. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/Callout.java +4 -0
  203. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapBitmapManager.java +124 -0
  204. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java +232 -43
  205. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/Request.java +193 -0
  206. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/IRhoCustomView.java +13 -0
  207. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoNativeViewManager.java +32 -23
  208. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoVideoView.java +74 -0
  209. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality.java +6 -7
  210. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality01.java +37 -0
  211. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality03.java +14 -1
  212. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality05.java +51 -38
  213. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality07.java +9 -1
  214. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality08.java +48 -31
  215. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionalityManager.java +15 -16
  216. data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/Signature.java +52 -15
  217. data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/LocalFileHandler.java +20 -2
  218. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientOld.java +1 -0
  219. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/GoogleWebView.java +77 -34
  220. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/IRhoWebView.java +9 -0
  221. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebChromeClient.java +105 -0
  222. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebViewClient.java +1 -1
  223. data/platform/android/build/RhodesSRC_build.files +8 -7
  224. data/platform/android/build/android.rake +326 -216
  225. data/platform/android/build/androidcommon.rb +27 -13
  226. data/platform/bb/RubyVM/src/com/rho/file/SimpleFile.java +27 -1
  227. data/platform/bb/RubyVM/src/j2me/io/File.java +104 -38
  228. data/platform/bb/build/bb.rake +1 -0
  229. data/platform/bb/build/runRAPC.bat +0 -0
  230. data/platform/bb/rhodes/resources/background.png +0 -0
  231. data/platform/bb/rhodes/resources/esri.png +0 -0
  232. data/platform/bb/rhodes/resources/mappin.png +0 -0
  233. data/platform/bb/rhodes/src/com/rho/rubyext/System.java +5 -1
  234. data/platform/bb/rhodes/src/rhomobile/PushListeningThread.java +2 -2
  235. data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapField.java +0 -0
  236. data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapProvider.java +0 -0
  237. data/platform/bb/rhodes/src/rhomobile/mapview/GeoCoding.java +0 -0
  238. data/platform/bb/rhodes/src/rhomobile/mapview/GoogleGeoCoding.java +0 -0
  239. data/platform/bb/rhodes/src/rhomobile/mapview/MapTools.java +0 -0
  240. data/platform/iphone/Classes/AppManager/AppManager.m +7 -1
  241. data/platform/iphone/Classes/Camera/PickImageDelegate.h +9 -0
  242. data/platform/iphone/Classes/Camera/PickImageDelegate.m +75 -4
  243. data/platform/iphone/Classes/GeoLocation/LocationController.h +8 -2
  244. data/platform/iphone/Classes/GeoLocation/LocationController.m +74 -76
  245. data/platform/iphone/Classes/InitMemoryInfoCollector.h +33 -0
  246. data/platform/iphone/Classes/InitMemoryInfoCollector.mm +52 -0
  247. data/platform/iphone/Classes/NativeView/NVViewController.h +0 -0
  248. data/platform/iphone/Classes/NativeView/NVViewController.m +34 -2
  249. data/platform/iphone/Classes/Rhodes.m +22 -2
  250. data/platform/iphone/Classes/Signature/SignatureDelegate.m +19 -0
  251. data/platform/iphone/Classes/Signature/SignatureViewController.h +0 -0
  252. data/platform/iphone/Classes/Signature/SignatureViewController.m +0 -0
  253. data/platform/iphone/Classes/SimpleMainView.h +0 -0
  254. data/platform/iphone/Classes/SimpleMainView.m +3 -3
  255. data/platform/iphone/ESRI/BluePushpin.png +0 -0
  256. data/platform/iphone/ESRI/BluePushpin@2x.png +0 -0
  257. data/platform/iphone/ESRI/esri.png +0 -0
  258. data/platform/iphone/ESRI/esri@2x.png +0 -0
  259. data/platform/iphone/rbuild/iphone.rake +75 -7
  260. data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +13 -4
  261. data/platform/linux/target/compiler/rubylinux +0 -0
  262. data/platform/mac/target/compiler/RubyMac +0 -0
  263. data/platform/osx/Rhodes Launcher/rhorunner.app/rhorunner b/data/platform/osx/Rhodes → Launcher/rhorunner.app/rhorunner +0 -0
  264. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtCore.framework/Versions/4/QtCore +0 -0
  265. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtGui.framework/Resources/qt_menu.nib/keyedobjects.nib +0 -0
  266. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtGui.framework/Versions/4/QtGui +0 -0
  267. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtNetwork.framework/Versions/4/QtNetwork +0 -0
  268. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtWebKit.framework/Versions/4/QtWebKit +0 -0
  269. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Info.plist +1 -1
  270. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/MacOS/RhoSimulator +0 -0
  271. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/accessible/libqtaccessiblewidgets.dylib +0 -0
  272. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqcorewlanbearer.dylib +0 -0
  273. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqgenericbearer.dylib +0 -0
  274. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqcncodecs.dylib +0 -0
  275. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqjpcodecs.dylib +0 -0
  276. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqkrcodecs.dylib +0 -0
  277. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqtwcodecs.dylib +0 -0
  278. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/graphicssystems/libqtracegraphicssystem.dylib +0 -0
  279. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqgif.dylib +0 -0
  280. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqico.dylib +0 -0
  281. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqjpeg.dylib +0 -0
  282. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqmng.dylib +0 -0
  283. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtga.dylib +0 -0
  284. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtiff.dylib +0 -0
  285. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_inspector.dylib +0 -0
  286. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_tcp.dylib +0 -0
  287. data/platform/osx/build/osx.rake +6 -8
  288. data/platform/shared/RhoConnectClient/RhoConnectClient.cpp +165 -33
  289. data/platform/shared/RhoConnectClient/RhoConnectClient.h +10 -1
  290. data/platform/shared/common/BundleManager.cpp +27 -16
  291. data/platform/shared/common/ExtManager.h +15 -2
  292. data/platform/shared/common/RhoConf.cpp +17 -2
  293. data/platform/shared/common/RhoConf.h +3 -1
  294. data/platform/shared/common/RhoDefs.h +6 -6
  295. data/platform/shared/common/RhoFatalError.h +1 -1
  296. data/platform/shared/common/RhoFile.cpp +9 -9
  297. data/platform/shared/common/RhoFilePath.h +7 -3
  298. data/platform/shared/common/RhoPort.h +3 -3
  299. data/platform/shared/common/RhoSystem.h +1 -1
  300. data/platform/shared/common/RhodesApp.cpp +426 -26
  301. data/platform/shared/common/RhodesApp.h +11 -3
  302. data/platform/shared/common/RhodesAppBase.cpp +4 -1
  303. data/platform/shared/common/StringConverter.h +3 -3
  304. data/platform/shared/common/app_build_capabilities.h +8 -0
  305. data/platform/shared/common/map/BaseMapEngine.cpp +302 -21
  306. data/platform/shared/common/map/BaseMapEngine.h +132 -6
  307. data/platform/shared/common/map/ESRIMapEngine.cpp +2 -1
  308. data/platform/shared/common/map/GeocodingMapEngine.cpp +22 -4
  309. data/platform/shared/common/map/GeocodingMapEngine.h +40 -0
  310. data/platform/shared/common/map/GoogleMapEngine.cpp +13 -1
  311. data/platform/shared/common/map/MapEngine.h +7 -0
  312. data/platform/shared/common/map/OSMMapEngine.cpp +12 -1
  313. data/platform/shared/json/JSONIterator.cpp +1 -1
  314. data/platform/shared/json/RJSONTokener.c +2 -0
  315. data/platform/shared/json/config.h +3 -3
  316. data/platform/shared/logging/RhoLog.cpp +12 -3
  317. data/platform/shared/logging/RhoLog.h +2 -1
  318. data/platform/shared/logging/RhoLogConf.cpp +147 -11
  319. data/platform/shared/logging/RhoLogConf.h +39 -1
  320. data/platform/shared/logging/RhoLogSink.cpp +1 -1
  321. data/platform/shared/net/HttpServer.cpp +8 -4
  322. data/platform/shared/net/INetRequest.cpp +7 -0
  323. data/platform/shared/net/INetRequest.h +2 -0
  324. data/platform/shared/net/RawSocket.cpp +1 -1
  325. data/platform/shared/qt/pbxproj2pro.pl +0 -0
  326. data/platform/shared/qt/pro_vcproj_diff.pl +0 -0
  327. data/platform/shared/qt/rhodes/QtMainWindow.cpp +1 -1
  328. data/platform/shared/qt/rhodes/impl/RhoClassFactoryImpl.h +2 -2
  329. data/platform/shared/qt/rhodes/impl/RhoThreadImpl.cpp +2 -2
  330. data/platform/shared/qt/rhodes/impl/SystemImpl.cpp +11 -1
  331. data/platform/shared/qt/rhodes/main.cpp +5 -5
  332. data/platform/shared/ruby/ext/alert/alert_wrap.c +8 -8
  333. data/platform/shared/ruby/ext/bluetooth/bluetooth.i +0 -0
  334. data/platform/shared/ruby/ext/bluetooth/bluetooth_wrap.c +16 -9
  335. data/platform/shared/ruby/ext/camera/camera.i +2 -2
  336. data/platform/shared/ruby/ext/camera/camera_wrap.c +18 -3
  337. data/platform/shared/ruby/ext/datetimepicker/datetimepicker_wrap.c +37 -8
  338. data/platform/shared/ruby/ext/geolocation/geolocation_wrap.c +8 -8
  339. data/platform/shared/ruby/ext/mapview/mapview_wrap.c +16 -9
  340. data/platform/shared/ruby/ext/nativebar/nativebar_wrap.c +16 -9
  341. data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager.i +0 -0
  342. data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager_wrap.c +16 -9
  343. data/platform/shared/ruby/ext/phonebook/phonebook_wrap.c +8 -1
  344. data/platform/shared/ruby/ext/rho/rhoruby.c +7 -1
  345. data/platform/shared/ruby/ext/rho/rhoruby.h +1 -0
  346. data/platform/shared/ruby/ext/rhoconf/rhoconf_wrap.c +16 -9
  347. data/platform/shared/ruby/ext/signature/signature.i +0 -0
  348. data/platform/shared/ruby/ext/signature/signature_wrap.c +9 -9
  349. data/platform/shared/ruby/ext/syncengine/syncengine_wrap.c +16 -9
  350. data/platform/shared/ruby/ext/system/system_wrap.c +16 -9
  351. data/platform/shared/ruby/ext/webview/webview_wrap.c +16 -9
  352. data/platform/shared/ruby/gc.c +1 -0
  353. data/platform/shared/ruby/regint.h +6 -4
  354. data/platform/shared/ruby/vm.c +1 -0
  355. data/platform/shared/ruby/wince/wince.h +1 -1
  356. data/platform/shared/rubyext/System.cpp +1 -1
  357. data/platform/shared/shttpd/src/rdispatcher.c +3 -3
  358. data/platform/shared/shttpd/src/std_includes.h +1 -1
  359. data/platform/shared/sqlite/sqlite3.c +1 -0
  360. data/platform/shared/statistic/test/TestProfiling.cpp +1 -1
  361. data/platform/shared/stlport/build/lib/configure +0 -0
  362. data/platform/shared/stlport/build/lib/configure.bat +0 -0
  363. data/platform/shared/sync/SyncEngine.cpp +9 -12
  364. data/platform/shared/sync/SyncNotify.cpp +36 -3
  365. data/platform/shared/sync/SyncNotify.h +11 -4
  366. data/platform/shared/sync/SyncSource.cpp +32 -16
  367. data/platform/shared/sync/SyncSource.h +2 -3
  368. data/platform/shared/sync/SyncThread.cpp +13 -4
  369. data/platform/shared/sync/SyncThread.h +4 -0
  370. data/platform/shared/tcmalloc/page_heap.h +1 -1
  371. data/platform/shared/tcmalloc/rhomem.h +1 -1
  372. data/platform/shared/tcmalloc/windows/port.cpp +12 -3
  373. data/platform/shared/test/Tests.cpp +4 -4
  374. data/platform/shared/test/test_helper.cpp +4 -4
  375. data/platform/symbian/sqlite3/src/sqlite3.h +1 -1
  376. data/platform/win32/RhoSimulator/Microsoft.VC90.CRT.manifest +6 -0
  377. data/platform/win32/RhoSimulator/Microsoft.VC90.OpenMP.manifest +6 -0
  378. data/platform/win32/RhoSimulator/QtCore4.dll +0 -0
  379. data/platform/win32/RhoSimulator/QtGui4.dll +0 -0
  380. data/platform/win32/RhoSimulator/QtNetwork4.dll +0 -0
  381. data/platform/win32/RhoSimulator/QtWebKit4.dll +0 -0
  382. data/platform/win32/RhoSimulator/RhoSimulator.exe +0 -0
  383. data/platform/win32/RhoSimulator/imageformats/qgif4.dll +0 -0
  384. data/platform/win32/RhoSimulator/imageformats/qico4.dll +0 -0
  385. data/platform/win32/RhoSimulator/imageformats/qjpeg4.dll +0 -0
  386. data/platform/win32/RhoSimulator/imageformats/qmng4.dll +0 -0
  387. data/platform/win32/RhoSimulator/imageformats/qsvg4.dll +0 -0
  388. data/platform/win32/RhoSimulator/imageformats/qtiff4.dll +0 -0
  389. data/platform/win32/RhoSimulator/libeay32.dll +0 -0
  390. data/platform/win32/RhoSimulator/msvcm90.dll +0 -0
  391. data/platform/win32/RhoSimulator/msvcp90.dll +0 -0
  392. data/platform/win32/RhoSimulator/msvcr90.dll +0 -0
  393. data/platform/win32/RhoSimulator/phonon4.dll +0 -0
  394. data/platform/win32/RhoSimulator/ssleay32.dll +0 -0
  395. data/platform/win32/RhoSimulator/vcomp90.dll +0 -0
  396. data/platform/win32/target/replaceicon/replaceicon.exe +0 -0
  397. data/platform/win32/target/updateresstring/updateresstring.exe +0 -0
  398. data/platform/wm/RhoLib/RhoLib.vcproj +394 -69
  399. data/platform/wm/build/build_inf.js +83 -23
  400. data/platform/wm/build/wm.rake +127 -81
  401. data/platform/wm/rhodes.sln +6 -6
  402. data/platform/wm/rhodes/DateTimePicker.h +2 -2
  403. data/platform/wm/rhodes/IBrowserEngine.h +3 -0
  404. data/platform/wm/rhodes/IEBrowserEngine.cpp +34 -2
  405. data/platform/wm/rhodes/IEBrowserEngine.h +4 -1
  406. data/platform/wm/rhodes/LicenseStub.cpp +73 -0
  407. data/platform/{android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientNew.java → wm/rhodes/LogMemory.cpp} +32 -20
  408. data/platform/{android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettings.java → wm/rhodes/LogMemory.h} +11 -8
  409. data/platform/wm/rhodes/LogOptionsDlg.h +1 -1
  410. data/platform/wm/rhodes/LogView.cpp +10 -10
  411. data/platform/wm/rhodes/LogView.h +10 -10
  412. data/platform/wm/rhodes/MainWindow.cpp +431 -173
  413. data/platform/wm/rhodes/MainWindow.h +37 -19
  414. data/platform/wm/rhodes/MapView/MapViewManager.h +1 -1
  415. data/platform/wm/rhodes/OkCancelModalDialog.h +1 -1
  416. data/platform/wm/rhodes/Rhodes.cpp +210 -47
  417. data/platform/wm/rhodes/Rhodes.rc +38 -0
  418. data/platform/wm/rhodes/bluetooth/Bluetooth.cpp +2 -2
  419. data/platform/wm/rhodes/bluetooth/Bluetooth.h +3 -3
  420. data/platform/wm/rhodes/camera/Camera.cpp +2 -1
  421. data/platform/wm/rhodes/camera/Camera.h +1 -1
  422. data/platform/wm/rhodes/resource.h +1 -1
  423. data/platform/wm/rhodes/rho/common/ExtManager.cpp +93 -5
  424. data/platform/wm/rhodes/rho/net/NetRequestImpl.cpp +2 -2
  425. data/platform/wm/rhodes/rho/rubyext/NativeToolbar.cpp +2 -2
  426. data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +13 -7
  427. data/platform/wm/rhodes/rhodes.vcproj +1409 -1008
  428. data/platform/wm/rhodes/simulator/MainWindowQt.h +1 -1
  429. data/platform/wm/rhodes/stdafx.h +2 -2
  430. data/platform/wm/rhoelements.sln +7 -9
  431. data/platform/wm/rubylib/rubylib.vcproj +62 -1
  432. data/platform/wm/sqlite3/sqlite3.vcproj +62 -1
  433. data/platform/wm/syncengine/syncengine.vcproj +62 -1
  434. data/platform/wm/tcmalloc/tcmalloc.vcproj +72 -53
  435. data/platform/wm/tools/detool/detool.cpp +1435 -1357
  436. data/platform/wp7/RhoRubyExtGen/GenerateInitializers.cmd +0 -0
  437. data/platform/wp7/RhoRubyLib/common/RhoLicense.cs +105 -0
  438. data/platform/wp7/RhoRubyLib/common/RhodesApp.cs +23 -5
  439. data/platform/wp7/RhoRubyLib/sync/SyncNotify.cs +5 -0
  440. data/platform/wp7/RhoRubyLib/views/RhoView.xaml.cs +22 -3
  441. data/platform/wp7/build/wp.rake +1 -0
  442. data/platform/wp7/rhodes/MainPage.xaml.cs +11 -0
  443. data/rakefile.rb +225 -59
  444. data/res/build-tools/7za.exe +0 -0
  445. data/res/build-tools/RhoAppRunner.exe +0 -0
  446. data/res/build-tools/RhoLogServer.exe +0 -0
  447. data/res/build-tools/RhoRuby.exe +0 -0
  448. data/res/build-tools/RubyMac +0 -0
  449. data/res/build-tools/detool.exe +0 -0
  450. data/res/build-tools/iphonesim/Source/iPhoneSimulator.m +1 -1
  451. data/res/build-tools/iphonesim/build/Release/iphonesim +0 -0
  452. data/res/build-tools/iphonesim/build/Release/iphonesim_43 +0 -0
  453. data/res/build-tools/license_rc.dll +0 -0
  454. data/res/build-tools/make.exe +0 -0
  455. data/res/build-tools/rubylinux +0 -0
  456. data/res/build-tools/swig_patch/Lib/typemaps/fragments.swg +235 -0
  457. data/res/build-tools/wmdc_connect.exe +0 -0
  458. data/res/build-tools/wp7explorer.exe +0 -0
  459. data/res/generators/rhogen.rb +2 -2
  460. data/res/generators/templates/application/app/Settings/controller.rb +1 -1
  461. data/res/generators/templates/application/app/layout.erb +1 -1
  462. data/res/generators/templates/application/app/loading.png +0 -0
  463. data/res/generators/templates/application/public/css/re_webkit.css +736 -0
  464. data/res/generators/templates/application/public/css/windows_mobile.css +0 -0
  465. data/res/generators/templates/application/public/images/listArrow.png +0 -0
  466. data/res/generators/templates/application/public/jqmobile/images/ajax-loader.png +0 -0
  467. data/res/generators/templates/application/public/jqmobile/images/icons-18-black.png +0 -0
  468. data/res/generators/templates/application/public/jqmobile/images/icons-18-white.png +0 -0
  469. data/res/generators/templates/application/public/jqmobile/images/icons-36-black.png +0 -0
  470. data/res/generators/templates/application/public/jqmobile/images/icons-36-white.png +0 -0
  471. data/res/generators/templates/application/public/js/syncengine.js +409 -52
  472. data/res/generators/templates/extension/extensions/montana/ext/build +0 -0
  473. data/res/generators/templates/extension/extensions/montana/ext/build.bat +0 -0
  474. data/res/generators/templates/extension/extensions/montana/ext/montana/platform/android/Rakefile +10 -10
  475. data/res/generators/templates/spec/app/SpecRunner/controller.rb +2 -0
  476. data/res/libs/motorolalicence/android/MotorolaLicence.h +13 -0
  477. data/res/libs/motorolalicence/android/libMotorolaLicence.a +0 -0
  478. data/res/libs/motorolalicence/iphone/MotorolaLicence.h +13 -0
  479. data/res/libs/motorolalicence/iphone/libMotorolaLicence.a +0 -0
  480. data/rhodes.gemspec +1 -1
  481. data/spec/framework_spec/app/SpecRunner/controller.rb +2 -0
  482. data/spec/phone_spec/app/SpecRunner/controller.rb +2 -0
  483. data/version +1 -1
  484. metadata +487 -412
  485. data/Manifest.txt +0 -7960
  486. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivityStartupListeners.java +0 -12
  487. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsNew.java +0 -52
  488. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsOld.java +0 -62
  489. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/phonon.framework/Versions/4/phonon +0 -0
  490. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/phonon_backend/libphonon_qt7.dylib +0 -0
  491. data/platform/win32/RhoSimulator/Microsoft.VC80.CRT.manifest +0 -8
  492. data/platform/win32/RhoSimulator/Microsoft.VC80.OpenMP.manifest +0 -7
  493. data/platform/win32/RhoSimulator/msvcm80.dll +0 -0
  494. data/platform/win32/RhoSimulator/msvcp80.dll +0 -0
  495. data/platform/win32/RhoSimulator/msvcr80.dll +0 -0
  496. data/platform/win32/RhoSimulator/vcomp.dll +0 -0
  497. data/rhomobile-debug-1.0.6.gem +0 -0
@@ -0,0 +1,9 @@
1
+ // WARNING! THIS FILE IS GENERATED AUTOMATICALLY! DO NOT EDIT IT MANUALLY!
2
+ package com.rhomobile.rhodes.extmanager;
3
+
4
+ class RhodesStartupListeners {
5
+
6
+ public static final String[] ourRunnableList = { ""
7
+ };
8
+
9
+ }
@@ -0,0 +1,53 @@
1
+ package com.rhomobile.rhodes.extmanager;
2
+
3
+ import android.content.Context;
4
+ import android.graphics.Rect;
5
+ import android.view.inputmethod.InputMethodManager;
6
+
7
+ import com.rhomobile.rhodes.Logger;
8
+ import com.rhomobile.rhodes.util.ContextFactory;
9
+
10
+ public class WebkitExtension extends AbstractRhoExtension implements IRhoExtension {
11
+ public static final String EXTNAME = "MotorolaWebkit";
12
+ private static final String TAG = WebkitExtension.class.getSimpleName();
13
+
14
+ private static WebkitExtension mInstance;
15
+
16
+ private Config mConfig;
17
+
18
+ public static WebkitExtension getInstance() {
19
+ return mInstance;
20
+ }
21
+
22
+ private WebkitExtension(Config config) {
23
+ mConfig = config;
24
+ }
25
+
26
+ public Config getConfig() {
27
+ return mConfig;
28
+ }
29
+
30
+ @Override
31
+ public void onInputMethod(IRhoExtManager extManager, boolean enabled, String type, Rect rect, IRhoExtData ext) {
32
+ InputMethodManager imm = (InputMethodManager) ContextFactory.getUiContext().getSystemService(Context.INPUT_METHOD_SERVICE);
33
+ if (enabled) {
34
+ imm.showSoftInput(ext.getWebView(), 0);
35
+ } else {
36
+ imm.hideSoftInputFromWindow(ext.getWebView().getApplicationWindowToken(), 0);
37
+ }
38
+ }
39
+
40
+ @Override
41
+ public void startLocationUpdates(IRhoExtManager extManager, boolean highAccuracy, IRhoExtData ext) {
42
+ }
43
+
44
+ @Override
45
+ public void stopLocationUpdates(IRhoExtManager extManager, IRhoExtData ext) {
46
+ }
47
+
48
+ public static void registerWebkitExtension(Config config) {
49
+ mInstance = new WebkitExtension(config);
50
+ RhoExtManager.getInstance().registerExtension(EXTNAME, mInstance);
51
+ }
52
+
53
+ }
@@ -60,7 +60,8 @@ public class RhoFileApi {
60
60
  private static final String DB_FILES_FOLDER = "db/db-files";
61
61
  private static final String TMP_FOLDER = "tmp";
62
62
 
63
- private static native void nativeInitPath(String rootPath, String sqliteJournalsPath, String apkPath);
63
+ private static native void nativeInitPath(String rootPath, String sqliteJournalsPath, String apkPath, String sharedPath);
64
+ private static native void nativeInitLogPath(String path);
64
65
  private static native void nativeInit();
65
66
  private static native void updateStatTable(String path, String type, long size, long mtime);
66
67
 
@@ -69,6 +70,9 @@ public class RhoFileApi {
69
70
 
70
71
  private static native boolean needEmulate(String path);
71
72
  private static native String makeRelativePath(String path);
73
+
74
+ public static native void setFsModeTransparrent(boolean transparrent);
75
+ public static native void removeBundleUpgrade();
72
76
 
73
77
  private static void fillStatTable() throws IOException {
74
78
  InputStream is = null;
@@ -127,12 +131,10 @@ public class RhoFileApi {
127
131
  }
128
132
  }
129
133
 
130
- public static String initRootPath(String dataDir, String sourceDir) {
134
+ public static String initRootPath(String dataDir, String sourceDir, String sharedDir) {
131
135
 
132
136
  root = dataDir + "/rhodata/";
133
137
  String sqliteJournals = dataDir + "/sqlite_stmt_journals/";
134
- Log.d(TAG, "App root path: " + root);
135
- Log.d(TAG, "Sqlite journals path: " + sqliteJournals);
136
138
 
137
139
  File f = new File(getRootPath());
138
140
  f.mkdirs();
@@ -145,9 +147,21 @@ public class RhoFileApi {
145
147
 
146
148
  String apkPath = sourceDir;
147
149
 
148
- nativeInitPath(root, sqliteJournals, apkPath);
149
- return root;
150
- }
150
+ if (sharedDir == null || sharedDir.length() == 0) {
151
+ sharedDir = root;
152
+ }
153
+
154
+ Log.d(TAG, "App root path: " + root);
155
+ Log.d(TAG, "Sqlite journals path: " + sqliteJournals);
156
+ Log.d(TAG, "Shared path: " + sharedDir);
157
+
158
+ nativeInitPath(root, sqliteJournals, apkPath, sharedDir);
159
+ return root;
160
+ }
161
+
162
+ public static void initLogPath(String path) {
163
+ nativeInitLogPath(path);
164
+ }
151
165
 
152
166
  public static String getRootPath() { return root; }
153
167
  public static String getDbFilesUriPath() { return DB_FILES_FOLDER; }
@@ -163,10 +177,13 @@ public class RhoFileApi {
163
177
  fillStatTable();
164
178
  }
165
179
 
166
- public static void initCopy(Context ctx, String assets[])
180
+ public static void initialCopy(Context ctx, String assets[])
167
181
  {
168
182
  am = ctx.getAssets();
169
- copyAssets(assets);
183
+ for(String asset: assets)
184
+ {
185
+ forceFile(getRootPath() + asset);
186
+ }
170
187
  }
171
188
 
172
189
  public static boolean copy(String path)
@@ -175,8 +192,6 @@ public class RhoFileApi {
175
192
  InputStream is = null;
176
193
  OutputStream os = null;
177
194
  try {
178
- //RhodesService r = RhodesService.getInstance();
179
-
180
195
  is = am.open(path);
181
196
 
182
197
  File dst = new File(root, path);
@@ -272,7 +287,7 @@ public class RhoFileApi {
272
287
  return is;
273
288
  }
274
289
  catch (IOException e) {
275
- //Log.e(TAG, "Can not open " + path);
290
+ Log.e(TAG, e.getMessage());
276
291
  return null;
277
292
  }
278
293
  }
@@ -25,6 +25,8 @@
25
25
  *------------------------------------------------------------------------*/
26
26
  package com.rhomobile.rhodes.geolocation;
27
27
 
28
+ import android.location.Location;
29
+
28
30
  import com.rhomobile.rhodes.Capabilities;
29
31
  import com.rhomobile.rhodes.Logger;
30
32
  import com.rhomobile.rhodes.RhoConf;
@@ -33,75 +35,89 @@ import com.rhomobile.rhodes.util.PerformOnUiThread;
33
35
  public class GeoLocation {
34
36
 
35
37
  private static final String TAG = "GeoLocation";
36
- private static final String inactivityTimeoutName = "geo_location_inactivity_timeout";
37
- private static final String updatePeriodName = "gps_ping_timeout_sec";
38
38
  private static volatile GeoLocationImpl locImpl = null;
39
- private static volatile int inactivityTimerId = 0;
40
- private static long updatePeriod = -1;
41
39
 
42
- static long getInactivityTimeout() {
43
- long upd = getUpdatePeriod();
44
- long ret = 0;
45
- if (RhoConf.isExist(inactivityTimeoutName))
46
- ret = RhoConf.getInt(inactivityTimeoutName) * 1000;
47
-
48
- if (ret <= upd) {
49
- ret = upd*10;
50
- Logger.W(TAG, "Inactivity time out less then position update period, override configured value: " + ret);
40
+ private static final String CALLBACK_UPDATE_INTERVAL = "gps_ping_timeout_sec";
41
+
42
+ private static double ourLatitude = 0;
43
+ private static double ourLongitude = 0;
44
+ private static double ourAccuracy = 0;
45
+ private static boolean ourIsKnownPosition = false;
46
+ private static boolean ourIsEnable = true;
47
+ private static boolean ourIsErrorState = false;
48
+
49
+ public static native void geoCallback();
50
+ public static native void geoCallbackError();
51
+
52
+
53
+ public static void onUpdateLocation() {
54
+ Location loc = getImpl().getLocation();
55
+ synchronized (GeoLocation.class) {
56
+ if (loc != null) {
57
+ ourLatitude = loc.getLatitude();
58
+ ourLongitude = loc.getLongitude();
59
+ ourAccuracy = loc.getAccuracy();
60
+ ourIsKnownPosition = true;
61
+ }
62
+ else {
63
+ ourLatitude = 0;
64
+ ourLongitude = 0;
65
+ ourAccuracy = 0;
66
+ ourIsKnownPosition = false;
67
+ }
51
68
  }
52
-
53
- return ret;
54
69
  }
55
70
 
56
- static long getUpdatePeriod() {
57
- if (updatePeriod != -1) {
58
- return updatePeriod;
59
- }
60
- if (RhoConf.isExist(updatePeriodName)) {
61
- long ret = RhoConf.getInt(updatePeriodName) * 1000;
62
- return ret;
63
- } else
64
- return 30000; // 30 sec
71
+ public static void onGeoCallback() {
72
+ Logger.T(TAG, "onGeoCallback()");
73
+ if (ourIsEnable && !ourIsErrorState) {
74
+ Logger.T(TAG, "onGeoCallback() run native Callback");
75
+ geoCallback();
76
+ }
77
+ else {
78
+ Logger.T(TAG, "onGeoCallback() SKIP");
79
+ }
80
+ }
81
+
82
+ public static void onGeoCallbackError() {
83
+ if (ourIsEnable && !ourIsErrorState) {
84
+ Logger.T(TAG, "onGeoCallbackError() run native Callback");
85
+ ourIsErrorState = true;
86
+ geoCallbackError();
87
+ ourIsErrorState = false;
88
+ }
89
+ else {
90
+ Logger.T(TAG, "onGeoCallbackError() SKIP");
91
+ }
65
92
  }
66
93
 
94
+ private static Thread ourCallbackThread = null;
95
+
67
96
  private static void checkState() throws IllegalAccessException {
68
97
  if (!Capabilities.GPS_ENABLED)
69
98
  throw new IllegalAccessException("Capability GPS disabled");
70
99
  }
71
100
 
72
- private static void updateInactivityTimer() {
73
- final long inactivityTimeout = getInactivityTimeout();
74
- Logger.T(TAG, "Updating inactivity timer: " + inactivityTimeout + "ms");
75
- PerformOnUiThread.exec(new Runnable() {
76
- int lastId = ++inactivityTimerId;
77
- public void run() {
78
- if ((inactivityTimerId != lastId) || (locImpl == null))
79
- return;
80
-
81
- Logger.T(TAG, "Stop geolocation by inactivity timeout: " + inactivityTimeout + "ms");
82
- stop();
83
- }
84
- }, inactivityTimeout);
85
- }
86
-
87
101
  private static GeoLocationImpl getImpl() {
88
102
  if (locImpl == null) {
89
103
  synchronized (GeoLocation.class) {
90
104
  if (locImpl == null) {
91
105
  Logger.T(TAG, "Creating GeoLocationImpl instance.");
92
- locImpl = new GeoLocationImpl(getUpdatePeriod());
106
+ locImpl = new GeoLocationImpl();
93
107
  Logger.T(TAG, "GeoLocationImpl instance has created.");
108
+ //ourIsFirstUpdate = true;
94
109
  locImpl.start();
95
110
  Logger.T(TAG, "GeoLocation has started.");
96
111
  }
97
112
  }
98
113
  }
99
- updateInactivityTimer();
100
114
  return locImpl;
101
115
  }
102
116
 
103
117
  public static void stop() {
104
118
  Logger.T(TAG, "stop");
119
+ ourIsEnable = false;
120
+ resetCallbackThread(0);
105
121
  try {
106
122
  if (locImpl == null)
107
123
  return;
@@ -117,18 +133,6 @@ public class GeoLocation {
117
133
  }
118
134
  }
119
135
 
120
- public static void restart() {
121
- try {
122
- checkState();
123
- Logger.T(TAG, "restart");
124
- if (updatePeriod != -1)
125
- getImpl().setTimeout(getUpdatePeriod());
126
- }
127
- catch (Exception e) {
128
- Logger.E(TAG, e);
129
- }
130
- }
131
-
132
136
  public static boolean isAvailable() {
133
137
  Logger.T(TAG, "isAvailable...");
134
138
  try {
@@ -147,10 +151,11 @@ public class GeoLocation {
147
151
  }
148
152
 
149
153
  public static double getLatitude() {
154
+ onUpdateLocation();
150
155
  try {
151
156
  checkState();
152
157
  Logger.T(TAG, "getLatitude");
153
- return getImpl().getLatitude();
158
+ return ourLatitude;
154
159
  }
155
160
  catch (Exception e) {
156
161
  Logger.E(TAG, e);
@@ -159,10 +164,11 @@ public class GeoLocation {
159
164
  }
160
165
 
161
166
  public static double getLongitude() {
167
+ onUpdateLocation();
162
168
  try {
163
169
  checkState();
164
170
  Logger.T(TAG, "getLongitude");
165
- return getImpl().getLongitude();
171
+ return ourLongitude;
166
172
  }
167
173
  catch (Exception e) {
168
174
  Logger.E(TAG, e);
@@ -171,10 +177,11 @@ public class GeoLocation {
171
177
  }
172
178
 
173
179
  public static float getAccuracy() {
180
+ onUpdateLocation();
174
181
  try {
175
182
  checkState();
176
183
  Logger.T(TAG, "getAccuracy");
177
- return getImpl().getAccuracy();
184
+ return (float)ourAccuracy;
178
185
  }
179
186
  catch (Exception e) {
180
187
  Logger.E(TAG, e);
@@ -183,10 +190,11 @@ public class GeoLocation {
183
190
  }
184
191
 
185
192
  public static boolean isKnownPosition() {
193
+ onUpdateLocation();
186
194
  try {
187
195
  checkState();
188
196
  Logger.T(TAG, "isKnownPosition");
189
- return getImpl().isKnownPosition();
197
+ return ourIsKnownPosition;
190
198
  }
191
199
  catch (Exception e) {
192
200
  Logger.E(TAG, e);
@@ -194,17 +202,71 @@ public class GeoLocation {
194
202
  return false;
195
203
  }
196
204
 
205
+ private static void resetCallbackThread(int period) {
206
+ Logger.T(TAG, "resetCallbackThread: " + period + "s");
207
+ if (ourCallbackThread != null) {
208
+ ourCallbackThread.interrupt();
209
+ ourCallbackThread = null;
210
+ }
211
+ if (period > 0) {
212
+ final int sleep_period = period;
213
+ ourCallbackThread = new Thread(new Runnable() {
214
+ private boolean ourLastCommandProcessed = true;
215
+ public void run() {
216
+ Logger.I(TAG, "\"callback\" thread started");
217
+ for (;;) {
218
+ if (!ourIsEnable) {
219
+ break;
220
+ }
221
+ try {
222
+ if (ourLastCommandProcessed) {
223
+ ourLastCommandProcessed = false;
224
+ Logger.T(TAG, "callback thread: perform callback in UI thread");
225
+ PerformOnUiThread.exec(new Runnable() {
226
+ public void run() {
227
+ Logger.T(TAG, "callback thread: callback in UI thread START");
228
+ onGeoCallback();
229
+ Logger.T(TAG, "callback thread: callback in UI thread FINISH");
230
+ ourLastCommandProcessed = true;
231
+ }
232
+ });
233
+ }
234
+ else {
235
+ Logger.T(TAG, "callback thread: previous command not processed - skip current callback");
236
+ }
237
+ Thread.sleep(sleep_period);
238
+ }
239
+ catch (InterruptedException e) {
240
+ Logger.T(TAG, "\"callback\" thread interrupted");
241
+ break;
242
+ }
243
+ }
244
+ }
245
+ });
246
+ ourCallbackThread.start();
247
+ }
248
+ else {
249
+ Logger.T(TAG, "resetCallbackThread: zero period - not make any thread");
250
+ }
251
+
252
+ }
253
+
197
254
  public static void setTimeout(int nsec) {
198
255
  try {
199
- if (nsec < 0) {
200
- Logger.E(TAG, "setTimeout: wrong parameter: " + nsec);
201
- return;
256
+ int p = nsec*1000;
257
+ if (p < 0) {
258
+ p = RhoConf.getInt(CALLBACK_UPDATE_INTERVAL) * 1000;
202
259
  }
203
260
 
204
261
  checkState();
205
262
  Logger.T(TAG, "setTimeout: " + nsec + "s");
206
- updatePeriod = nsec * 1000;
207
- getImpl().setTimeout(getUpdatePeriod());
263
+
264
+ ourIsEnable = true;
265
+ if (p <= 0) {
266
+ p = 250;
267
+ }
268
+ resetCallbackThread(p);
269
+
208
270
  }
209
271
  catch (Exception e) {
210
272
  Logger.E(TAG, e);
@@ -44,14 +44,11 @@ import android.os.Looper;
44
44
  public class GeoLocationImpl {
45
45
 
46
46
  private static final String TAG = "GeoLocationImpl";
47
- private static final long TIMEOUT_STOP = -1;
48
47
 
49
- private LocationManager locationManager = null;
50
- private volatile Location lastLocation;
48
+ private static final int UPDATE_PERIOD_IN_MILLISECONDS = 250;
51
49
 
52
- // These two values should be equal in most cases but explicit request to GeoLocation without call to setTimeout
53
- private long invalidateLocationPeriod;
54
- private volatile long pingTimeout = Long.MAX_VALUE;
50
+ private LocationManager locationManager = null;
51
+ private volatile Location lastLocation = null;
55
52
 
56
53
  private List<RhoLocationListener> mListeners = new LinkedList<RhoLocationListener>();
57
54
  private List<RhoLocationListener> mSwitchedOffListeners = new LinkedList<RhoLocationListener>();
@@ -60,7 +57,6 @@ public class GeoLocationImpl {
60
57
  private String providerName;
61
58
  private LocationManager manager;
62
59
  private LocationProvider provider;
63
- private long updatePeriod = 0;
64
60
  private boolean available = false;
65
61
 
66
62
  boolean isAvailable() { return available; }
@@ -72,7 +68,7 @@ public class GeoLocationImpl {
72
68
 
73
69
  String getProviderName() { return this.providerName; }
74
70
 
75
- synchronized boolean register(long updatePeriod) {
71
+ synchronized boolean register() {
76
72
  Logger.T(TAG, "Registering location listener for '" + this.providerName + "'.");
77
73
  if (this.provider != null) {
78
74
  this.manager.removeUpdates(this);
@@ -80,8 +76,7 @@ public class GeoLocationImpl {
80
76
  this.provider = this.manager.getProvider(this.providerName);
81
77
  }
82
78
  if(this.provider != null) {
83
- this.updatePeriod = updatePeriod;
84
- this.manager.requestLocationUpdates(providerName, this.updatePeriod, 0, this, Looper.getMainLooper());
79
+ this.manager.requestLocationUpdates(providerName, UPDATE_PERIOD_IN_MILLISECONDS, 0, this, Looper.getMainLooper());
85
80
  available = this.manager.isProviderEnabled(this.providerName);
86
81
  }
87
82
  return available;
@@ -102,28 +97,14 @@ public class GeoLocationImpl {
102
97
  void requestLastLocation() {
103
98
  if (this.provider != null && this.manager != null) {
104
99
  Location location = this.manager.getLastKnownLocation(this.providerName);
105
- if (location != null) {
106
- long time = location.getTime();
107
- StringBuilder message = new StringBuilder();
108
- message.append("Last known location from ").append(location.getProvider());
109
- if((System.currentTimeMillis() - time) > invalidateLocationPeriod) {
110
- message.append(" time is very old: ").append(location.getTime());
111
- message.append(". Current time: ").append(System.currentTimeMillis());
112
- message.append(". Invalitate period: ").append(invalidateLocationPeriod).append(".");
113
- } else {
114
- message.append(" time os ok: ").append(location.getTime());
115
- message.append(". Current time: ").append(System.currentTimeMillis());
116
- message.append(". Invalidate period: ").append(invalidateLocationPeriod).append(".");
117
- onLocationChanged(location);
118
- }
119
- Logger.T(TAG, message.toString());
120
- }
100
+ onLocationChanged(location);
121
101
  }
122
102
  }
123
103
 
124
104
  @Override
125
105
  public void onStatusChanged(String provider, int status, Bundle extras) {
126
106
  Logger.T(TAG, "onStatusChanged: provider=" + provider + ", status=" + status);
107
+ requestLastLocation();
127
108
  }
128
109
 
129
110
  @Override
@@ -147,62 +128,21 @@ public class GeoLocationImpl {
147
128
  }
148
129
  };
149
130
 
150
- private Thread thWatchdog = new Thread(new Runnable() {
151
- public void run() {
152
- Logger.I(TAG, "\"watchdog\" thread started");
153
- for (;;) {
154
- if (pingTimeout < 0)
155
- break;
156
- try {
157
- final long curTimeout = errorTimeout(pingTimeout);
158
- Logger.T(TAG, "\"watchdog\" thread waits (" + curTimeout + "ms)...");
159
- Thread.sleep(curTimeout);
160
- }
161
- catch (InterruptedException e) {
162
- Logger.T(TAG, "\"watchdog\" thread interrupted");
163
- continue;
164
- }
165
- Logger.I(TAG, "Watchdog timed out.");
166
- if (isKnownPosition()) {
167
- if (System.currentTimeMillis() - getTime() > invalidateLocationPeriod) {
168
- Logger.T(TAG, "Position became very old. Invalidate and call back to inform.");
169
- clearLocation();
170
- } else {
171
- Logger.I(TAG, "Lost signal but position still up to date. Call back with error to inform.");
172
- }
173
- } else {
174
- Logger.T(TAG, "Position is still unknown. Call back to inform.");
175
- }
176
-
177
- PerformOnUiThread.exec(new Runnable() {
178
- public void run() {
179
- geoCallbackError();
180
- }
181
- });
182
- }
183
- PerformOnUiThread.exec(new Runnable() { public void run() { geoCallbackStop();} });
184
- Logger.I(TAG, "\"watchdog\" thread stopped");
185
- }
186
- });
187
-
188
- // Sleep greater then ping time to do not interfere with real location updates
189
- private static long errorTimeout(long time) { return (time == Long.MAX_VALUE) ? time : (time * 5); }
190
-
191
- private static native void geoCallback();
192
- private static native void geoCallbackError();
193
- private static native void geoCallbackStop();
194
-
195
- GeoLocationImpl(long invalidateLocationPeriod) {
196
- this.invalidateLocationPeriod = invalidateLocationPeriod;
131
+ GeoLocationImpl() {
197
132
  Logger.T(TAG, "GeoLocationImpl instance created");
198
133
  Context ctx = ContextFactory.getContext();
199
134
  locationManager = (LocationManager)ctx.getSystemService(Context.LOCATION_SERVICE);
200
135
  createListeners();
201
- thWatchdog.start();
202
136
  }
203
137
 
204
138
  private void createListeners() {
205
- List<String> providers = locationManager.getAllProviders();
139
+ LocationManager man = locationManager;
140
+ if (man == null) {
141
+ Logger.E(TAG, "createListeners() : Location Manager is NULL !");
142
+ return;
143
+ }
144
+
145
+ List<String> providers = man.getAllProviders();
206
146
  Iterator<String> it = providers.iterator();
207
147
 
208
148
  synchronized (mListeners) {
@@ -211,7 +151,7 @@ public class GeoLocationImpl {
211
151
  if (provider.equals(LocationManager.PASSIVE_PROVIDER))
212
152
  continue;
213
153
 
214
- RhoLocationListener listener = new RhoLocationListener(provider, locationManager);
154
+ RhoLocationListener listener = new RhoLocationListener(provider, man);
215
155
  mSwitchedOffListeners.add(listener);
216
156
  }
217
157
  }
@@ -226,7 +166,7 @@ public class GeoLocationImpl {
226
166
 
227
167
  Logger.T(TAG, "Registering location listener: " + listener.getProviderName());
228
168
 
229
- listener.register(pingTimeout);
169
+ listener.register();
230
170
  mListeners.add(listener);
231
171
  }
232
172
  mSwitchedOffListeners.removeAll(mListeners);
@@ -259,6 +199,11 @@ public class GeoLocationImpl {
259
199
  }
260
200
  }
261
201
 
202
+
203
+ public void doUpdate() {
204
+
205
+ }
206
+
262
207
  private void checkProviderEnabled(RhoLocationListener listener) {
263
208
  }
264
209
 
@@ -273,29 +218,11 @@ public class GeoLocationImpl {
273
218
  }
274
219
  }
275
220
 
276
- private static boolean isLocationsEqual(Location prev, Location current) {
277
- if (prev == null && current != null)
278
- return false;
279
- if (prev != null && current == null)
280
- return true;
281
-
282
- do {
283
- if (prev.getLatitude() != current.getLatitude() ||
284
- prev.getLongitude() == current.getLongitude())
285
- break;
286
-
287
- if(current.hasAccuracy()) {
288
- if(!prev.hasAccuracy())
289
- break;
290
- if (prev.getAccuracy() != current.getAccuracy())
291
- break;
292
- }
293
- return true;
294
- } while(false);
295
- return false;
296
- }
297
-
298
221
  private synchronized void setLocation(Location location) {
222
+ if (location == null) {
223
+ Logger.T(TAG, "setCurrentGpsLocation: location = null");
224
+ return;
225
+ }
299
226
  Logger.T(TAG, "setCurrentGpsLocation: location=" + location);
300
227
  try {
301
228
  // We've received location update
@@ -307,21 +234,25 @@ public class GeoLocationImpl {
307
234
  unregisterListeners(LocationManager.GPS_PROVIDER);
308
235
  }
309
236
 
310
- dumpStatus(locationManager.getAllProviders());
311
-
312
- if (!isLocationsEqual(lastLocation, location)) {
313
- Logger.T(TAG, "Geo location information changed, notify about that");
314
- lastLocation = location;
315
- PerformOnUiThread.exec(new Runnable() { public void run() { geoCallback();} }, 10);
237
+ LocationManager man = locationManager;
238
+ if (man != null) {
239
+ dumpStatus(man.getAllProviders());
316
240
  }
317
-
241
+
242
+ lastLocation = location;
318
243
  } catch (Exception e) {
319
244
  lastLocation = null;
245
+ GeoLocation.onGeoCallbackError();
320
246
  Logger.E(TAG, e);
321
247
  }
322
248
  }
323
249
 
324
250
  private void dumpStatus(List<String> providers) {
251
+ LocationManager man = locationManager;
252
+ if (man == null) {
253
+ Logger.E(TAG, "dumpStatus() : Location Manager is NULL !");
254
+ return;
255
+ }
325
256
  StringBuffer log = new StringBuffer();
326
257
  log.append("Status of location providers: ");
327
258
  Iterator<String> it = providers.iterator();
@@ -335,7 +266,7 @@ public class GeoLocationImpl {
335
266
  log.append("\"");
336
267
  log.append(provider);
337
268
  log.append("\" - ");
338
- if (locationManager.isProviderEnabled(provider))
269
+ if (man.isProviderEnabled(provider))
339
270
  log.append("enabled");
340
271
  else
341
272
  log.append("disabled");
@@ -343,18 +274,19 @@ public class GeoLocationImpl {
343
274
  Logger.T(TAG, log.toString());
344
275
  log = new StringBuffer();
345
276
  log.append("location is");
346
- if (lastLocation == null) {
277
+ Location ll = lastLocation;
278
+ if (ll == null) {
347
279
  log.append(" not determined");
348
280
  } else {
349
281
  log.append(" determined");
350
- log.append(": longitude=").append(Double.toString(lastLocation.getLongitude()));
351
- log.append(", latitude=").append(Double.toString(lastLocation.getLatitude()));
282
+ log.append(": longitude=").append(Double.toString(ll.getLongitude()));
283
+ log.append(", latitude=").append(Double.toString(ll.getLatitude()));
352
284
  if (lastLocation.hasAccuracy())
353
- log.append(", accuracy=").append(Float.toString(lastLocation.getAccuracy()));
285
+ log.append(", accuracy=").append(Float.toString(ll.getAccuracy()));
354
286
  if (lastLocation.hasSpeed())
355
- log.append(", speed=").append(Float.toString(lastLocation.getSpeed()));
287
+ log.append(", speed=").append(Float.toString(ll.getSpeed()));
356
288
  if (lastLocation.hasAltitude())
357
- log.append(", altitude=").append(Double.toString(lastLocation.getAltitude()));
289
+ log.append(", altitude=").append(Double.toString(ll.getAltitude()));
358
290
  }
359
291
  Logger.T(TAG, log.toString());
360
292
  }
@@ -365,16 +297,7 @@ public class GeoLocationImpl {
365
297
 
366
298
 
367
299
  synchronized void stop() {
368
- // Stop thCancel thread
369
- pingTimeout = TIMEOUT_STOP;
370
- thWatchdog.interrupt();
371
-
372
- if (locationManager == null)
373
- return;
374
-
375
300
  unregisterListeners(null);
376
-
377
- locationManager = null;
378
301
  }
379
302
 
380
303
  synchronized boolean isAvailable() {
@@ -390,6 +313,10 @@ public class GeoLocationImpl {
390
313
  return available > 0;
391
314
  }
392
315
 
316
+ synchronized Location getLocation() {
317
+ return lastLocation;
318
+ }
319
+
393
320
  synchronized double getLatitude() {
394
321
  return lastLocation != null ? lastLocation.getLatitude() : 0;
395
322
  }
@@ -418,20 +345,5 @@ public class GeoLocationImpl {
418
345
  return lastLocation != null;
419
346
  }
420
347
 
421
- synchronized void clearLocation() {
422
- lastLocation = null;
423
- }
424
348
 
425
- synchronized void setTimeout(long msec) {
426
- if (pingTimeout != msec) {
427
- pingTimeout = msec;
428
- thWatchdog.interrupt();
429
- registerListeners();// do reregister for new timeout
430
- Logger.T(TAG, "Set new ping timeout: " + pingTimeout + "ms");
431
- } else {
432
- // Just renew timer in case same value
433
- thWatchdog.interrupt();
434
- }
435
-
436
- }
437
349
  }