rhodes 2.2.6 → 2.3.0.beta.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (486) hide show
  1. data/CHANGELOG +20 -0
  2. data/README.md +46 -0
  3. data/Rakefile +85 -80
  4. data/bin/rhodes +2 -2
  5. data/bin/rhogen +1 -1
  6. data/doc/application.txt +277 -0
  7. data/doc/bb-css.txt +209 -0
  8. data/doc/build.txt +785 -0
  9. data/doc/configuration.txt +236 -0
  10. data/doc/connect-to-web-services.txt +282 -0
  11. data/doc/contributing.txt +64 -0
  12. data/doc/css-framework.txt +144 -0
  13. data/doc/device-caps.txt +1152 -0
  14. data/doc/extensions.txt +528 -0
  15. data/doc/files.txt +4 -0
  16. data/doc/generator.txt +141 -0
  17. data/doc/install.txt +35 -0
  18. data/doc/introduction.txt +88 -0
  19. data/doc/rhom.txt +826 -0
  20. data/doc/standard-css.txt +392 -0
  21. data/doc/synchronization.txt +542 -0
  22. data/doc/test-log-debug.txt +148 -0
  23. data/doc/tutorial.txt +136 -0
  24. data/doc/ui.txt +766 -0
  25. data/installer/EnvVarUpdate.nsh +328 -0
  26. data/installer/README.html +81 -0
  27. data/installer/RHOSYNC-LICENSE.txt +675 -0
  28. data/installer/icon.ico +0 -0
  29. data/installer/instant-rhodes.nsi +427 -0
  30. data/lib/build/jake.rb +15 -1
  31. data/lib/extensions/barcode/ext/barcode/platform/android/jni/src/imageprovider.cpp +1 -1
  32. data/lib/extensions/barcode/ext/barcode/platform/bb/Barcode6.files +45 -0
  33. data/lib/extensions/barcode/ext/barcode/platform/bb/Rakefile +6 -0
  34. data/lib/extensions/barcode/ext/barcode/platform/bb/barcode6.jdp +92 -0
  35. data/lib/extensions/barcode/ext/barcode/platform/iphone/Barcode.xcodeproj/project.pbxproj +7 -4
  36. data/lib/extensions/barcode/ext/barcode/platform/iphone/Rakefile +2 -1
  37. data/lib/extensions/barcode/ext/barcode/platform/wm/src/wm_imageprovider.cpp +1 -1
  38. data/lib/extensions/digest-sha1/ext/build.bat +1 -0
  39. data/lib/extensions/digest-sha1/ext/digest-sha1.vcproj +335 -0
  40. data/lib/extensions/esri/ext/build +17 -0
  41. data/lib/extensions/esri/ext/build.bat +29 -0
  42. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/ESRIViewFactory.h +7 -0
  43. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/ESRIViewFactory.mm +58 -0
  44. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/ESRIViewFactoryRegister.mm +22 -0
  45. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/ESRIViewManager.h +21 -0
  46. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/ESRIViewManager.mm +32 -0
  47. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/InitESRI.c +5 -0
  48. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/MapViewControllerESRI.h +143 -0
  49. data/lib/extensions/esri/ext/esri/platform/iphone/Classes/MapViewControllerESRI.m +919 -0
  50. data/lib/extensions/esri/ext/esri/platform/iphone/ESRI.xcodeproj/project.pbxproj +320 -0
  51. data/lib/extensions/esri/ext/esri/platform/iphone/ESRI_Prefix.pch +7 -0
  52. data/lib/extensions/esri/ext/esri/platform/iphone/Rakefile +76 -0
  53. data/lib/extensions/esri/ext.yml +3 -0
  54. data/lib/extensions/net-http/monitor.rb +265 -0
  55. data/lib/extensions/net-http/net/ftp.rb +981 -0
  56. data/lib/extensions/net-http/thread.rb +367 -0
  57. data/lib/extensions/rhocgi/cgi.rb +16 -0
  58. data/lib/extensions/rhospec/rhospec.rb +118 -0
  59. data/lib/framework/base64.rb +91 -0
  60. data/lib/framework/builtinME.rb +13 -10
  61. data/lib/framework/ostruct.rb +145 -0
  62. data/lib/framework/res/back_btn.wm.png +0 -0
  63. data/lib/framework/res/blue_pushpin.wm.png +0 -0
  64. data/lib/framework/res/blue_pushpin_small.wm.png +0 -0
  65. data/lib/framework/res/callout.wm.png +0 -0
  66. data/lib/framework/res/callout_link.wm.png +0 -0
  67. data/lib/framework/res/forward_btn.wm.png +0 -0
  68. data/lib/framework/res/home_btn.wm.png +0 -0
  69. data/lib/framework/res/options_btn.wm.png +0 -0
  70. data/lib/framework/res/refresh_btn.wm.png +0 -0
  71. data/lib/framework/rho/render.rb +5 -2
  72. data/lib/framework/rho/rho.rb +320 -50
  73. data/lib/framework/rho/rhoapplication.rb +48 -10
  74. data/lib/framework/rho/rhonativeviewmanager.rb +73 -0
  75. data/lib/framework/rho/rhosupport.rb +15 -1
  76. data/lib/framework/rho/rhotabbar.rb +29 -0
  77. data/lib/framework/rho/rhotoolbar.rb +17 -0
  78. data/lib/framework/rho/rhoutils.rb +22 -6
  79. data/lib/framework/rhodes.rb +1 -1
  80. data/lib/framework/rholang/rhomsg_de.rb +4 -3
  81. data/lib/framework/rholang/rhomsg_en.rb +1 -0
  82. data/lib/framework/rholang/rhomsg_es.rb +1 -0
  83. data/lib/framework/rholang/rhomsg_it.rb +1 -0
  84. data/lib/framework/rhom/rhom.rb +31 -10
  85. data/lib/framework/rhom/rhom_db_adapter.rb +33 -23
  86. data/lib/framework/rhom/rhom_object_factory.rb +465 -249
  87. data/lib/framework/rhom/rhom_source.rb +22 -7
  88. data/lib/framework/version.rb +1 -1
  89. data/lib/rhodes.rb +1 -1
  90. data/platform/android/Rhodes/AndroidManifest.xml +83 -20
  91. data/platform/android/Rhodes/gen/com/rhomobile/rhodes/R.java +5 -0
  92. data/platform/android/Rhodes/jni/include/rhodes/RhoClassFactory.h +2 -0
  93. data/platform/android/Rhodes/jni/include/rhodes/details/rhojava.inc +9 -5
  94. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_RhodesAppOptions.h +53 -0
  95. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_RhodesService.h +46 -56
  96. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_SplashScreen.h +10 -0
  97. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_mapview_MapView.h +93 -0
  98. data/platform/android/Rhodes/jni/include/rhodes/rhocryptimpl.h +38 -0
  99. data/platform/android/Rhodes/jni/include/rhodes.h +64 -8
  100. data/platform/android/Rhodes/jni/src/RhoClassFactory.cpp +6 -0
  101. data/platform/android/Rhodes/jni/src/alert.cpp +5 -11
  102. data/platform/android/Rhodes/jni/src/bluetooth.cpp +66 -29
  103. data/platform/android/Rhodes/jni/src/callbacks.cpp +24 -21
  104. data/platform/android/Rhodes/jni/src/camera.cpp +2 -6
  105. data/platform/android/Rhodes/jni/src/datetimepicker.cpp +13 -11
  106. data/platform/android/Rhodes/jni/src/event.cpp +9 -15
  107. data/platform/android/Rhodes/jni/src/fileapi.cpp +13 -27
  108. data/platform/android/Rhodes/jni/src/logconf.cpp +3 -3
  109. data/platform/android/Rhodes/jni/src/mapview.cpp +696 -16
  110. data/platform/android/Rhodes/jni/src/menu.cpp +3 -3
  111. data/platform/android/Rhodes/jni/src/nativebar.cpp +55 -4
  112. data/platform/android/Rhodes/jni/src/nativeview.cpp +33 -0
  113. data/platform/android/Rhodes/jni/src/phonebook.cpp +6 -11
  114. data/platform/android/Rhodes/jni/src/rhoconf.cpp +4 -4
  115. data/platform/android/Rhodes/jni/src/rhocryptimpl.cpp +87 -0
  116. data/platform/android/Rhodes/jni/src/rhodes.cpp +55 -34
  117. data/platform/android/Rhodes/jni/src/ringtones.cpp +2 -3
  118. data/platform/android/Rhodes/jni/src/signature.cpp +3 -5
  119. data/platform/android/Rhodes/jni/src/splashscreen.cpp +7 -0
  120. data/platform/android/Rhodes/jni/src/sslimpl.cpp +17 -20
  121. data/platform/android/Rhodes/jni/src/webview.cpp +13 -12
  122. data/platform/android/Rhodes/res/drawable/callout.png +0 -0
  123. data/platform/android/Rhodes/res/drawable/callout_link.png +0 -0
  124. data/platform/android/Rhodes/res/drawable/signature_cancel.png +0 -0
  125. data/platform/android/Rhodes/res/drawable/signature_clear.png +0 -0
  126. data/platform/android/Rhodes/res/drawable/signature_ok.png +0 -0
  127. data/platform/android/Rhodes/res/layout/datetime.xml +4 -0
  128. data/platform/android/Rhodes/res/layout/signature.xml +24 -17
  129. data/platform/android/Rhodes/res/layout/status_bar_ongoing_event_progress_bar.xml +102 -0
  130. data/platform/android/Rhodes/res/values/strings.xml +1 -1
  131. data/platform/android/Rhodes/src/com/rhomobile/rhodes/AndroidR.java +6 -0
  132. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Base64.java +575 -0
  133. data/platform/android/Rhodes/src/com/rhomobile/rhodes/BaseActivity.java +83 -0
  134. data/platform/android/Rhodes/src/com/rhomobile/rhodes/NativeBar.java +21 -3
  135. data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushReceiver.java +23 -15
  136. data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushService.java +2 -2
  137. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhoCryptImpl.java +151 -0
  138. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhoMenu.java +2 -2
  139. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +372 -0
  140. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesAppOptions.java +11 -0
  141. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +58 -0
  142. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +705 -523
  143. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RingtoneManager.java +1 -1
  144. data/platform/android/Rhodes/src/com/rhomobile/rhodes/SplashScreen.java +167 -85
  145. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Utils.java +36 -1
  146. data/platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java +4 -2
  147. data/platform/android/Rhodes/src/com/rhomobile/rhodes/alert/Alert.java +33 -20
  148. data/platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/IRhoBluetoothManager.java +2 -6
  149. data/platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothManager.java +2 -24
  150. data/platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothManagerNew.java +106 -36
  151. data/platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothManagerOld.java +15 -58
  152. data/platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothSession.java +0 -7
  153. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/Camera.java +6 -4
  154. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/FileList.java +4 -3
  155. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/ImageCapture.java +91 -27
  156. data/platform/android/Rhodes/src/com/rhomobile/rhodes/datetime/DateTimePicker.java +6 -3
  157. data/platform/android/Rhodes/src/com/rhomobile/rhodes/datetime/DateTimePickerScreen.java +275 -42
  158. data/platform/android/Rhodes/src/com/rhomobile/rhodes/event/EventStore.java +1 -1
  159. data/platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java +1 -3
  160. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java +1 -1
  161. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/MainView.java +1 -0
  162. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +120 -43
  163. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java +518 -28
  164. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/AnnotationsOverlay.java +2 -2
  165. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/GoogleMapView.java +434 -0
  166. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapTouch.java +20 -0
  167. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java +296 -336
  168. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MultiTouchHandler.java +111 -0
  169. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/OneTouchHandler.java +77 -0
  170. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/TouchHandler.java +10 -0
  171. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoNativeViewManager.java +0 -1
  172. data/platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/Contact.java +5 -1
  173. data/platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactAccessorNew.java +1 -1
  174. data/platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactAccessorOld.java +1 -1
  175. data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/ImageCapture.java +6 -11
  176. data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/Signature.java +6 -4
  177. data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/SignatureView.java +0 -7
  178. data/platform/android/Rhodes/src/com/rhomobile/rhodes/ui/LogViewDialog.java +9 -4
  179. data/platform/android/Rhodes/src/com/rhomobile/rhodes/util/PerformOnUiThread.java +8 -8
  180. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientNew.java +5 -1
  181. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientOld.java +11 -7
  182. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsNew.java +3 -5
  183. data/platform/android/build/RhodesSRC_build.files +32 -23
  184. data/platform/android/build/android.rake +28 -11
  185. data/platform/android/build/androidcommon.rb +2 -0
  186. data/platform/android/build/librhocommon_build.files +9 -5
  187. data/platform/android/build/librhodes_build.files +1 -0
  188. data/platform/android/build/libruby_build.files +1 -0
  189. data/platform/bb/Hsqldb/Hsqldb.jdp +0 -2
  190. data/platform/bb/Hsqldb/src/com/rho/db/HsqlDBResult.java +10 -2
  191. data/platform/bb/Hsqldb/src/com/rho/db/HsqlDBStorage.java +37 -5
  192. data/platform/bb/Hsqldb/src/org/hsqldb/Column.java +5 -5
  193. data/platform/bb/Hsqldb/src/org/hsqldb/Expression.java +1 -1
  194. data/platform/bb/Hsqldb/src/org/hsqldb/Function.java +73 -78
  195. data/platform/bb/Hsqldb/src/org/hsqldb/Library.java +288 -8
  196. data/platform/bb/RubyVM/RubyVM.jdp +3 -0
  197. data/platform/bb/RubyVM/src/com/rho/FilePath.java +13 -1
  198. data/platform/bb/RubyVM/src/com/rho/IRhoRubyHelper.java +2 -2
  199. data/platform/bb/RubyVM/src/com/rho/RhoAppAdapter.java +12 -0
  200. data/platform/bb/RubyVM/src/com/rho/RhoClassFactory.java +18 -1
  201. data/platform/bb/RubyVM/src/com/rho/RhoConf.java +128 -108
  202. data/platform/bb/RubyVM/src/com/rho/RhoLogConf.java +9 -10
  203. data/platform/bb/RubyVM/src/com/rho/RhoLogger.java +16 -1
  204. data/platform/bb/RubyVM/src/com/rho/RhoProfiler.java +1 -1
  205. data/platform/bb/RubyVM/src/com/rho/RhoRuby.java +20 -0
  206. data/platform/bb/RubyVM/src/com/rho/RhodesApp.java +5 -2
  207. data/platform/bb/RubyVM/src/com/rho/ThreadQueue.java +65 -46
  208. data/platform/bb/RubyVM/src/com/rho/db/DBAdapter.java +192 -50
  209. data/platform/bb/RubyVM/src/com/rho/db/DBAttrManager.java +8 -114
  210. data/platform/bb/RubyVM/src/com/rho/db/DBException.java +1 -1
  211. data/platform/bb/RubyVM/src/com/rho/db/IDBCallback.java +1 -1
  212. data/platform/bb/RubyVM/src/com/rho/db/IDBResult.java +5 -3
  213. data/platform/bb/RubyVM/src/com/rho/db/IDBStorage.java +5 -1
  214. data/platform/bb/RubyVM/src/com/rho/file/FileAccessBB.java +109 -0
  215. data/platform/bb/RubyVM/src/com/rho/file/RhoFile.java +85 -0
  216. data/platform/bb/RubyVM/src/com/rho/net/NetRequest.java +12 -4
  217. data/platform/bb/RubyVM/src/com/rho/net/NetResponse.java +5 -0
  218. data/platform/bb/RubyVM/src/com/rho/net/RhoConnection.java +37 -23
  219. data/platform/bb/RubyVM/src/com/rho/net/URI.java +84 -0
  220. data/platform/bb/RubyVM/src/com/rho/sync/ClientRegister.java +1 -1
  221. data/platform/bb/RubyVM/src/com/rho/sync/SyncEngine.java +119 -61
  222. data/platform/bb/RubyVM/src/com/rho/sync/SyncNotify.java +61 -24
  223. data/platform/bb/RubyVM/src/com/rho/sync/SyncSource.java +108 -54
  224. data/platform/bb/RubyVM/src/com/rho/sync/SyncThread.java +121 -163
  225. data/platform/bb/RubyVM/src/com/xruby/GeneratedMethods/RubyString_Methods.java +23 -0
  226. data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyMutex.java +1 -1
  227. data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyRange.java +3 -1
  228. data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyRegexp.java +3 -1
  229. data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyString.java +208 -25
  230. data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyTime.java +3 -1
  231. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RhoSupport.java +5 -1
  232. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyAPI.java +12 -5
  233. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyID.java +1 -0
  234. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyKernelModule.java +16 -0
  235. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyKernelModule_Methods.java +5 -0
  236. data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyValue.java +1 -1
  237. data/platform/bb/RubyVM/src/com/xruby/runtime/stdlib/RubyStringIO.java +4 -1
  238. data/platform/bb/{Hsqldb → RubyVM}/src/j2me/math/Number.java +33 -0
  239. data/platform/bb/build/RubyVM_build.files +3 -0
  240. data/platform/bb/build/bb.rake +140 -62
  241. data/platform/bb/build/hsqldb_build.files +0 -2
  242. data/platform/bb/build/rhodes_build.files +5 -0
  243. data/platform/bb/rhodes/platform/4.7/com/rho/RhoMainScreen.java +43 -7
  244. data/platform/bb/rhodes/platform/5.0/com/rho/BrowserAdapter5.java +23 -2
  245. data/platform/bb/rhodes/platform/5.0/com/rho/RhodesApplicationPlatform.java +5 -0
  246. data/platform/bb/rhodes/platform/5.0/com/rho/db/SqliteCopyResult.java +143 -0
  247. data/platform/bb/rhodes/platform/5.0/com/rho/db/SqliteResult.java +269 -0
  248. data/platform/bb/rhodes/platform/5.0/com/rho/db/SqliteStorage.java +446 -0
  249. data/platform/bb/rhodes/platform/common/com/rho/BrowserAdapter5.java +3 -0
  250. data/platform/bb/rhodes/platform/common/com/rho/RhoMainScreen.java +12 -2
  251. data/platform/bb/rhodes/platform/common/com/rho/db/SqliteCopyResult.java +2 -0
  252. data/platform/bb/rhodes/platform/common/com/rho/db/SqliteResult.java +2 -0
  253. data/platform/bb/rhodes/platform/common/com/rho/db/SqliteStorage.java +2 -0
  254. data/platform/bb/rhodes/resources/mappin.png +0 -0
  255. data/platform/bb/rhodes/rhodes.jdp +3 -0
  256. data/platform/bb/rhodes/src/com/rho/BrowserAdapter.java +21 -18
  257. data/platform/bb/rhodes/src/com/rho/BrowserAdapter5.java +150 -0
  258. data/platform/bb/rhodes/src/com/rho/IBrowserAdapter.java +1 -0
  259. data/platform/bb/rhodes/src/com/rho/RhoMainScreen.java +63 -4
  260. data/platform/bb/rhodes/src/com/rho/RhoRubyHelper.java +6 -5
  261. data/platform/bb/rhodes/src/com/rho/RhodesApplicationPlatform.java +242 -2
  262. data/platform/bb/rhodes/src/com/rho/db/SqliteCopyResult.java +143 -0
  263. data/platform/bb/rhodes/src/com/rho/db/SqliteResult.java +269 -0
  264. data/platform/bb/rhodes/src/com/rho/db/SqliteStorage.java +446 -0
  265. data/platform/bb/rhodes/src/com/rho/file/Jsr75File.java +1 -1
  266. data/platform/bb/rhodes/src/com/rho/net/NetworkAccess.java +71 -14
  267. data/platform/bb/rhodes/src/com/rho/net/bb/BBHttpConnection.java +4 -2
  268. data/platform/bb/rhodes/src/com/rho/rubyext/Alert.java +28 -12
  269. data/platform/bb/rhodes/src/com/rho/rubyext/System.java +100 -4
  270. data/platform/bb/rhodes/src/com/rho/rubyext/WebView.java +3 -2
  271. data/platform/bb/rhodes/src/com/rho/rubyext/XMLParser.java +1 -1
  272. data/platform/bb/rhodes/src/rhomobile/NativeBar.java +32 -0
  273. data/platform/bb/rhodes/src/rhomobile/PushListeningThread.java +9 -2
  274. data/platform/bb/rhodes/src/rhomobile/RhodesApplication.java +174 -41
  275. data/platform/bb/rhodes/src/rhomobile/datetime/DateTimePicker.java +52 -3
  276. data/platform/bb/rhodes/src/rhomobile/datetime/DateTimeScreen.java +33 -1
  277. data/platform/bb/rhodes/src/rhomobile/mapview/Annotation.java +2 -14
  278. data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapField.java +686 -0
  279. data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapProvider.java +14 -0
  280. data/platform/bb/rhodes/src/rhomobile/mapview/GeoCoding.java +13 -0
  281. data/platform/bb/rhodes/src/rhomobile/mapview/GoogleGeoCoding.java +174 -0
  282. data/platform/bb/rhodes/src/rhomobile/mapview/GoogleMapField.java +104 -330
  283. data/platform/bb/rhodes/src/rhomobile/mapview/MapTools.java +79 -0
  284. data/platform/bb/rhodes/src/rhomobile/mapview/MapView.java +35 -12
  285. data/platform/bb/rhodes/src/rhomobile/mapview/MapViewParent.java +2 -1
  286. data/platform/bb/rhodes/src/rhomobile/mapview/MapViewScreen.java +336 -44
  287. data/platform/bb/rhodes/src/rhomobile/mapview/RhoMapField.java +3 -6
  288. data/platform/iphone/Classes/AppManager/AppManager.m +19 -4
  289. data/platform/iphone/Classes/DateTime.h +4 -0
  290. data/platform/iphone/Classes/DateTime.m +1 -1
  291. data/platform/iphone/Classes/DateTimePicker.m +8 -1
  292. data/platform/iphone/Classes/DateTimePickerDelegate.m +7 -1
  293. data/platform/iphone/Classes/Event/Event.m +2 -2
  294. data/platform/iphone/Classes/MapView/MapViewController.h +4 -1
  295. data/platform/iphone/Classes/MapView/MapViewController.m +6 -46
  296. data/platform/iphone/Classes/MapView/MapViewManager.h +26 -0
  297. data/platform/iphone/Classes/MapView/MapViewManager.m +172 -0
  298. data/platform/iphone/Classes/NativeBar.h +34 -0
  299. data/platform/iphone/Classes/NativeBar.m +131 -26
  300. data/platform/iphone/Classes/NativeView/NVDelegate.h +26 -0
  301. data/platform/iphone/Classes/NativeView/NVDelegate.m +40 -0
  302. data/platform/iphone/Classes/NativeView/NVViewController.h +24 -0
  303. data/platform/iphone/Classes/NativeView/NVViewController.m +90 -0
  304. data/platform/iphone/Classes/NativeView/RhoNativeViewManager.mm +449 -0
  305. data/platform/iphone/Classes/{RhoNativeViewManagerOC.h → NativeView/RhoNativeViewManagerOC.h} +15 -0
  306. data/platform/iphone/Classes/RhoAlert.m +3 -3
  307. data/platform/iphone/Classes/RhoMainView.h +3 -0
  308. data/platform/iphone/Classes/Rhodes.h +6 -2
  309. data/platform/iphone/Classes/Rhodes.m +47 -79
  310. data/platform/iphone/Classes/Signature/SignatureViewController.m +1 -0
  311. data/platform/iphone/Classes/SimpleMainView.h +18 -1
  312. data/platform/iphone/Classes/SimpleMainView.m +180 -35
  313. data/platform/iphone/Classes/SplitView/LeftViewController.h +1 -1
  314. data/platform/iphone/Classes/SplitView/LeftViewController.m +13 -7
  315. data/platform/iphone/Classes/SplitView/RightViewController.h +1 -1
  316. data/platform/iphone/Classes/SplitView/RightViewController.m +26 -11
  317. data/platform/iphone/Classes/SplitView/SplittedMainView.h +1 -6
  318. data/platform/iphone/Classes/SplitView/SplittedMainView.m +14 -52
  319. data/platform/iphone/Classes/TabbedMainView.h +25 -3
  320. data/platform/iphone/Classes/TabbedMainView.m +340 -14
  321. data/platform/iphone/ESRI/BluePushpin.png +0 -0
  322. data/platform/iphone/ESRI/BluePushpin@2x.png +0 -0
  323. data/platform/iphone/ESRI/esri.png +0 -0
  324. data/platform/iphone/ESRI/esri@2x.png +0 -0
  325. data/platform/iphone/Info.plist +1 -1
  326. data/platform/iphone/RhoLib/RhoLib.xcodeproj/project.pbxproj +26 -3
  327. data/platform/iphone/rbuild/iphone.rake +100 -4
  328. data/platform/iphone/rhorubylib/rhorubylib.xcodeproj/project.pbxproj +12 -0
  329. data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +116 -12
  330. data/platform/shared/SyncClient/SyncClient.cpp +29 -3
  331. data/platform/shared/SyncClient/SyncClient.h +2 -1
  332. data/platform/shared/common/IRhoClassFactory.h +3 -0
  333. data/platform/shared/common/IRhoCrypt.h +16 -0
  334. data/platform/shared/common/IRhoThreadImpl.h +1 -0
  335. data/platform/shared/common/RhoAppAdapter.h +2 -0
  336. data/platform/shared/common/RhoConf.cpp +97 -46
  337. data/platform/shared/common/RhoConf.h +14 -13
  338. data/platform/shared/common/RhoFile.cpp +10 -0
  339. data/platform/shared/common/RhoFile.h +1 -0
  340. data/platform/shared/common/RhoMath.cpp +43 -0
  341. data/platform/shared/common/RhoMath.h +27 -0
  342. data/platform/shared/common/RhoNativeViewManager.h +27 -1
  343. data/platform/shared/common/RhoPort.h +11 -0
  344. data/platform/shared/common/RhoStd.h +5 -0
  345. data/platform/shared/common/RhoThread.cpp +1 -1
  346. data/platform/shared/common/RhoThread.h +1 -1
  347. data/platform/shared/common/RhodesApp.cpp +381 -139
  348. data/platform/shared/common/RhodesApp.h +24 -10
  349. data/platform/shared/common/RhodesAppBase.cpp +72 -1
  350. data/platform/shared/common/RhodesAppBase.h +5 -1
  351. data/platform/shared/common/SplashScreen.h +4 -4
  352. data/platform/shared/common/ThreadQueue.cpp +44 -17
  353. data/platform/shared/common/ThreadQueue.h +4 -0
  354. data/platform/shared/common/app_build_configs.c +0 -1
  355. data/platform/shared/common/iphone/RhoClassfactory.h +6 -0
  356. data/platform/shared/common/iphone/RhoCryptImpl.h +47 -0
  357. data/platform/shared/common/iphone/RhoCryptImpl.mm +286 -0
  358. data/platform/shared/common/map/ESRIMapEngine.cpp +921 -0
  359. data/platform/shared/common/map/ESRIMapEngine.h +255 -0
  360. data/platform/shared/common/map/GoogleMapEngine.cpp +160 -0
  361. data/platform/shared/common/map/GoogleMapEngine.h +52 -0
  362. data/platform/shared/common/map/MapEngine.cpp +304 -0
  363. data/platform/shared/common/map/MapEngine.h +214 -0
  364. data/platform/shared/db/DBAdapter.cpp +147 -18
  365. data/platform/shared/db/DBAdapter.h +38 -12
  366. data/platform/shared/db/DBAttrManager.cpp +4 -3
  367. data/platform/shared/db/DBAttrManager.h +7 -7
  368. data/platform/shared/db/res/db/syncdb.triggers +0 -5
  369. data/platform/shared/db/res/db/syncdb_java.triggers +21 -0
  370. data/platform/shared/json/JSONIterator.cpp +11 -1
  371. data/platform/shared/json/JSONIterator.h +1 -0
  372. data/platform/shared/logging/RhoLogConf.cpp +29 -12
  373. data/platform/shared/net/CURLNetRequest.cpp +80 -25
  374. data/platform/shared/net/CURLNetRequest.h +6 -2
  375. data/platform/shared/net/HttpServer.cpp +12 -6
  376. data/platform/shared/net/HttpServer.h +2 -1
  377. data/platform/shared/net/INetRequest.h +1 -0
  378. data/platform/shared/ruby/ext/alert/alert.i +5 -0
  379. data/platform/shared/ruby/ext/alert/alert_wrap.c +439 -108
  380. data/platform/shared/ruby/ext/datetimepicker/datetimepicker.i +42 -0
  381. data/platform/shared/ruby/ext/datetimepicker/datetimepicker_wrap.c +521 -120
  382. data/platform/shared/ruby/ext/nativebar/nativebar.i +16 -0
  383. data/platform/shared/ruby/ext/nativebar/nativebar_wrap.c +623 -128
  384. data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager.i +18 -0
  385. data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager_wrap.c +2321 -0
  386. data/platform/shared/ruby/ext/rho/extensions.c +0 -1
  387. data/platform/shared/ruby/ext/rho/rhoruby.c +53 -0
  388. data/platform/shared/ruby/ext/rho/rhoruby.h +6 -0
  389. data/platform/shared/ruby/ext/sqlite3_api/sqlite3_api_wrap.c +6 -3
  390. data/platform/shared/ruby/ext/syncengine/syncengine.i +9 -1
  391. data/platform/shared/ruby/ext/syncengine/syncengine_wrap.c +61 -0
  392. data/platform/shared/ruby/ext/system/system.i +4 -0
  393. data/platform/shared/ruby/ext/system/system_wrap.c +33 -5
  394. data/platform/shared/rubyext/RhoAppAdapter.cpp +11 -1
  395. data/platform/shared/rubyext/System.cpp +9 -0
  396. data/platform/shared/rubyext/WebView.h +1 -0
  397. data/platform/shared/sqlite/crypto.c +907 -0
  398. data/platform/shared/sqlite/sqlite3.c +6 -0
  399. data/platform/shared/sync/SyncEngine.cpp +49 -19
  400. data/platform/shared/sync/SyncEngine.h +0 -1
  401. data/platform/shared/sync/SyncNotify.cpp +14 -5
  402. data/platform/shared/sync/SyncNotify.h +2 -2
  403. data/platform/shared/sync/SyncSource.cpp +79 -33
  404. data/platform/shared/sync/SyncSource.h +1 -0
  405. data/platform/shared/sync/SyncThread.cpp +26 -11
  406. data/platform/shared/xruby/src/com/xruby/compiler/codedom/StringExpression.java +4 -2
  407. data/platform/wm/RhoLib/RhoLib.vcproj +108 -72
  408. data/platform/wm/build/wm.rake +6 -0
  409. data/platform/wm/rhodes/Alert.cpp +4 -3
  410. data/platform/wm/rhodes/Alert.h +1 -1
  411. data/platform/wm/rhodes/DateTimePicker.cpp +30 -3
  412. data/platform/wm/rhodes/DateTimePicker.h +9 -1
  413. data/platform/wm/rhodes/MainWindow.cpp +121 -61
  414. data/platform/wm/rhodes/MainWindow.h +29 -4
  415. data/platform/wm/rhodes/MapView/Graphics.cpp +547 -0
  416. data/platform/wm/rhodes/MapView/Graphics.h +136 -0
  417. data/platform/wm/rhodes/MapView/MapViewManager.cpp +391 -0
  418. data/platform/wm/rhodes/MapView/MapViewManager.h +158 -0
  419. data/platform/wm/rhodes/RhoCryptImpl.cpp +248 -0
  420. data/platform/wm/rhodes/RhoCryptImpl.h +51 -0
  421. data/platform/wm/rhodes/RhoNativeViewManager.cpp +208 -0
  422. data/platform/wm/rhodes/Rhodes.cpp +94 -102
  423. data/platform/wm/rhodes/Rhodes.rc +27 -0
  424. data/platform/wm/rhodes/SyncStatusDlg.cpp +1 -0
  425. data/platform/wm/rhodes/SyncStatusDlg.h +2 -1
  426. data/platform/wm/rhodes/bluetooth/Bluetooth.cpp +7 -4
  427. data/platform/wm/rhodes/camera/Camera.cpp +36 -15
  428. data/platform/wm/rhodes/camera/Camera.h +0 -4
  429. data/platform/wm/rhodes/resource.h +10 -2
  430. data/platform/wm/rhodes/rho/common/RhoClassFactory.cpp +7 -0
  431. data/platform/wm/rhodes/rho/common/RhoClassFactory.h +1 -0
  432. data/platform/wm/rhodes/rho/net/NetRequestImpl.cpp +10 -2
  433. data/platform/wm/rhodes/rho/net/NetRequestImpl.h +10 -0
  434. data/platform/wm/rhodes/rho/rubyext/NativeToolbar.cpp +513 -0
  435. data/platform/wm/rhodes/rho/rubyext/NativeToolbar.h +74 -0
  436. data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +22 -10
  437. data/platform/wm/rhodes/rho/rubyext/WebView.cpp +5 -0
  438. data/platform/wm/rhodes/rhodes.vcproj +38 -2
  439. data/platform/wm/rhodes/stdafx.h +2 -1
  440. data/platform/wm/rubylib/rubylib.vcproj +12 -0
  441. data/rakefile.rb +85 -80
  442. data/res/build-tools/iphonesim/Source/iPhoneSimulator.m +14 -3
  443. data/res/build-tools/iphonesim/build/Release/iphonesim +0 -0
  444. data/res/build-tools/iphonesim/iphonesim.xcodeproj/project.pbxproj +2 -0
  445. data/res/build-tools/xruby-0.3.3.jar +0 -0
  446. data/res/generators/templates/application/app/application.rb +2 -2
  447. data/res/generators/templates/application/app/helpers/application_helper.rb +1 -1
  448. data/res/generators/templates/application/public/css/android.css +1 -0
  449. data/res/generators/templates/application/public/jqtouch/jquery.1.3.2.min.js +1 -1
  450. data/res/generators/templates/application/rhoconfig.txt +66 -14
  451. data/rhodes.gemspec +3 -3
  452. data/spec/framework_spec/app/spec/core/file/expand_path_spec.rb +7 -3
  453. data/spec/framework_spec/build.yml +1 -1
  454. data/spec/phone_spec/Rakefile +1 -0
  455. data/spec/phone_spec/app/Account/account.rb +2 -0
  456. data/spec/phone_spec/app/Account_s/account_s.rb +7 -0
  457. data/spec/phone_spec/app/spec/{fixtures → array/fixtures}/classes.rb +0 -0
  458. data/spec/phone_spec/app/spec/{array_pack_spec.rb → array/pack_spec.rb} +2 -1
  459. data/spec/phone_spec/app/spec/bulksync_spec.rb +1 -0
  460. data/spec/phone_spec/app/spec/contacts_spec.rb +2 -0
  461. data/spec/phone_spec/app/spec/rho_spec.rb +34 -233
  462. data/spec/phone_spec/app/spec/rhom_object_spec.rb +396 -87
  463. data/spec/phone_spec/app/spec/string/element_set_spec.rb +251 -0
  464. data/spec/phone_spec/app/spec/string/end_with_spec.rb +49 -0
  465. data/spec/phone_spec/app/spec/string/fixtures/classes.rb +27 -0
  466. data/spec/phone_spec/app/spec/{lstrip_spec.rb → string/lstrip_spec.rb} +0 -0
  467. data/spec/phone_spec/app/spec/string/replace_spec.rb +52 -0
  468. data/spec/phone_spec/app/spec/{rstrip_spec.rb → string/rstrip_spec.rb} +0 -0
  469. data/spec/phone_spec/app/spec/string/slice_spec.rb +473 -0
  470. data/spec/phone_spec/app/spec/string/split_spec.rb +302 -0
  471. data/spec/phone_spec/app/spec/string/start_with_spec.rb +48 -0
  472. data/spec/phone_spec/app/spec/{strip_spec.rb → string/strip_spec.rb} +0 -0
  473. data/spec/phone_spec/app/spec/syncengine_spec.rb +30 -1
  474. data/spec/phone_spec/app/spec_runner.rb +15 -7
  475. data/spec/phone_spec/build.yml +2 -2
  476. metadata +154 -25
  477. data/README.textile +0 -45
  478. data/platform/android/Rhodes/AndroidManifest.full.xml +0 -62
  479. data/platform/android/Rhodes/gen/com/rhomobile/rhodes/Manifest.java +0 -14
  480. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhoActivity.java +0 -20
  481. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Rhodes.java +0 -193
  482. data/platform/bb/Hsqldb/src/com/rho/file/FileAccessBB.java +0 -25
  483. data/platform/bb/RubyVM/src/com/rho/AppBuildConfig.java +0 -22
  484. data/platform/bb/RubyVM/src/com/rho/Capabilities.java +0 -6
  485. data/platform/bb/RubyVM/src/com/rho/Extensions.java +0 -11
  486. data/platform/iphone/Classes/RhoNativeViewManager.mm +0 -226
@@ -27,6 +27,7 @@ import com.rho.RhoProfiler;
27
27
  import com.rho.RhoAppAdapter;
28
28
  import com.rho.TimeInterval;
29
29
  import com.rho.db.*;
30
+ import com.rho.file.IFileAccess;
30
31
  import com.rho.net.*;
31
32
  import com.rho.*;
32
33
  import java.io.IOException;
@@ -39,6 +40,7 @@ public class SyncEngine implements NetRequest.IRhoSession
39
40
  new RhoLogger("Sync");
40
41
  private static final RhoProfiler PROF = RhoProfiler.RHO_STRIP_PROFILER ? new RhoEmptyProfiler() :
41
42
  new RhoProfiler();
43
+ RhoConf RHOCONF(){ return RhoConf.getInstance(); }
42
44
 
43
45
  public static final int esNone = 0, esSyncAllSources = 1, esSyncSource = 2, esSearch=3, esStop = 4, esExit = 5;
44
46
 
@@ -111,7 +113,6 @@ public class SyncEngine implements NetRequest.IRhoSession
111
113
  };
112
114
 
113
115
  Vector/*<SyncSource*>*/ m_sources = new Vector();
114
- Vector/*<String>*/ m_arPartitions = new Vector();
115
116
  NetRequest m_NetRequest;
116
117
  ISyncProtocol m_SyncProtocol;
117
118
  int m_syncState;
@@ -476,7 +477,7 @@ public class SyncEngine implements NetRequest.IRhoSession
476
477
  {
477
478
  int nSrcID = resSrc.getIntByIdx(0);
478
479
  IDBResult res = db.executeSQL("SELECT source_id,sync_type,name, partition from sources WHERE source_id=?", nSrcID);
479
- if ( res.isEnd() )
480
+ if ( res.isOneEnd() )
480
481
  continue;
481
482
 
482
483
  SyncSource src = new SyncSource( res.getIntByIdx(0), res.getStringByIdx(2), "none", db, this );
@@ -485,25 +486,32 @@ public class SyncEngine implements NetRequest.IRhoSession
485
486
  }
486
487
  }
487
488
 
488
- void loadAllSources()throws DBException
489
+ void loadAllSources()throws Exception
489
490
  {
491
+ if (isNoThreadedMode())
492
+ RhoAppAdapter.loadAllSyncSources();
493
+ else
494
+ {
495
+ getNet().pushData( getNet().resolveUrl("/system/loadallsyncsources"), "", null );
496
+ }
497
+
490
498
  m_sources.removeAllElements();
491
- m_arPartitions.removeAllElements();
492
-
493
- IDBResult res = getUserDB().executeSQL("SELECT source_id,sync_type,name, partition from sources ORDER BY sync_priority");
494
- for ( ; !res.isEnd(); res.next() )
495
- {
496
- String strShouldSync = res.getStringByIdx(1);
497
- if ( strShouldSync.compareTo("none") == 0)
498
- continue;
499
+ Vector/*<String>*/ arPartNames = DBAdapter.getDBAllPartitionNames();
499
500
 
500
- String strName = res.getStringByIdx(2);
501
- String strPartition = res.getStringByIdx(3);
502
-
503
- if ( m_arPartitions.indexOf(strPartition) < 0 )
504
- m_arPartitions.addElement(strPartition);
505
-
506
- m_sources.addElement( new SyncSource( res.getIntByIdx(0), strName, strShouldSync, getDB(strPartition), this) );
501
+ for( int i = 0; i < (int)arPartNames.size(); i++ )
502
+ {
503
+ DBAdapter dbPart = DBAdapter.getDB((String)arPartNames.elementAt(i));
504
+ IDBResult res = dbPart.executeSQL("SELECT source_id,sync_type,name from sources ORDER BY sync_priority");
505
+ for ( ; !res.isEnd(); res.next() )
506
+ {
507
+ String strShouldSync = res.getStringByIdx(1);
508
+ if ( strShouldSync.compareTo("none") == 0)
509
+ continue;
510
+
511
+ String strName = res.getStringByIdx(2);
512
+
513
+ m_sources.addElement( new SyncSource( res.getIntByIdx(0), strName, strShouldSync, dbPart, this) );
514
+ }
507
515
  }
508
516
 
509
517
  checkSourceAssociations();
@@ -557,7 +565,7 @@ public class SyncEngine implements NetRequest.IRhoSession
557
565
  synchronized( m_mxLoadClientID )
558
566
  {
559
567
  IDBResult res = getUserDB().executeSQL("SELECT client_id,reset from client_info");
560
- if ( !res.isEnd() )
568
+ if ( !res.isOneEnd() )
561
569
  clientID = res.getStringByIdx(0);
562
570
  }
563
571
 
@@ -573,7 +581,7 @@ public class SyncEngine implements NetRequest.IRhoSession
573
581
  boolean bResetClient = false;
574
582
  {
575
583
  IDBResult res = getUserDB().executeSQL("SELECT client_id,reset from client_info");
576
- if ( !res.isEnd() )
584
+ if ( !res.isOneEnd() )
577
585
  {
578
586
  clientID = res.getStringByIdx(0);
579
587
  bResetClient = res.getIntByIdx(1) > 0;
@@ -585,7 +593,7 @@ public class SyncEngine implements NetRequest.IRhoSession
585
593
  clientID = requestClientIDByNet();
586
594
 
587
595
  IDBResult res = getUserDB().executeSQL("SELECT * FROM client_info");
588
- if ( !res.isEnd() )
596
+ if ( !res.isOneEnd() )
589
597
  getUserDB().executeSQL("UPDATE client_info SET client_id=?", clientID);
590
598
  else
591
599
  getUserDB().executeSQL("INSERT INTO client_info (client_id) values (?)", clientID);
@@ -613,7 +621,7 @@ public class SyncEngine implements NetRequest.IRhoSession
613
621
  RhoAppAdapter.loadServerSources(strSources);
614
622
  else
615
623
  {
616
- NetResponse resp = getNet().pushData( getNet().resolveUrl("/system/loadserversources"), strSources, null);
624
+ getNet().pushData( getNet().resolveUrl("/system/loadserversources"), strSources, null);
617
625
  }
618
626
 
619
627
  loadAllSources();
@@ -697,8 +705,9 @@ public class SyncEngine implements NetRequest.IRhoSession
697
705
  LOG.INFO("Bulk sync: start");
698
706
  getNotify().fireBulkSyncNotification(false, "start", "", RhoAppAdapter.ERR_NONE);
699
707
 
700
- for (int i = 0; i < (int)m_arPartitions.size() && isContinueSync(); i++)
701
- loadBulkPartition( (String)m_arPartitions.elementAt(i));
708
+ Vector/*<String>*/ arPartNames = DBAdapter.getDBAllPartitionNames();
709
+ for( int i = 0; i < (int)arPartNames.size()&& isContinueSync(); i++ )
710
+ loadBulkPartition( (String)arPartNames.elementAt(i));
702
711
 
703
712
  if (isContinueSync())
704
713
  {
@@ -760,44 +769,74 @@ public class SyncEngine implements NetRequest.IRhoSession
760
769
  getNotify().fireBulkSyncNotification(false, "download", strPartition, RhoAppAdapter.ERR_NONE);
761
770
 
762
771
  String fDataName = makeBulkDataFileName(strDataUrl, dbPartition.getDBPath(), "_bulk.data");
763
- String strHsqlDataUrl = FilePath.join(getHostFromUrl(serverUrl), strDataUrl) + ".hsqldb.data";
764
- LOG.INFO("Bulk sync: download data from server: " + strHsqlDataUrl);
772
+ String fScriptName = makeBulkDataFileName(strDataUrl, dbPartition.getDBPath(), "_bulk.script" );
773
+
774
+ String strZip = ".gzip";
775
+ if (Capabilities.USE_SQLITE)
765
776
  {
766
- NetResponse resp1 = getNet().pullFile(strHsqlDataUrl, fDataName, this, null);
767
- if ( !resp1.isOK() )
777
+ String strHsqlDataUrl = FilePath.join(getHostFromUrl(serverUrl), strDataUrl) + strZip;
778
+ downloadBulkDataAndUnzip(strHsqlDataUrl, fDataName+strZip, strPartition);
779
+ }
780
+ else
781
+ {
782
+ String strHsqlDataUrl = FilePath.join(getHostFromUrl(serverUrl), strDataUrl) + ".hsqldb.data" + strZip;
783
+ downloadBulkDataAndUnzip(strHsqlDataUrl, fDataName+strZip, strPartition);
784
+ if ( !isContinueSync() )
785
+ return;
786
+
787
+ String strHsqlScriptUrl = FilePath.join(getHostFromUrl(serverUrl), strDataUrl) + ".hsqldb.script";
788
+ LOG.INFO("Bulk sync: download script from server: " + strHsqlScriptUrl);
768
789
  {
769
- LOG.ERROR("Bulk sync failed: cannot download database file: " + resp1.getRespCode() );
770
- stopSync();
771
- getNotify().fireBulkSyncNotification(true, "", strPartition, RhoAppAdapter.getErrorFromResponse(resp1));
772
- return;
790
+ NetResponse resp1 = getNet().pullFile(strHsqlScriptUrl, fScriptName, this, null);
791
+ if ( !resp1.isOK() )
792
+ {
793
+ LOG.ERROR("Bulk sync failed: cannot download database file.");
794
+ stopSync();
795
+ getNotify().fireBulkSyncNotification(true, "", strPartition, RhoAppAdapter.getErrorFromResponse(resp1));
796
+ }
773
797
  }
774
798
  }
775
-
776
799
  if ( !isContinueSync() )
777
800
  return;
778
801
 
779
- String fScriptName = makeBulkDataFileName(strDataUrl, dbPartition.getDBPath(), "_bulk.script" );
780
- String strHsqlScriptUrl = FilePath.join(getHostFromUrl(serverUrl), strDataUrl) + ".hsqldb.script";
781
- LOG.INFO("Bulk sync: download script from server: " + strHsqlScriptUrl);
802
+ LOG.INFO("Bulk sync: start change db");
803
+ getNotify().fireBulkSyncNotification(false, "change_db", strPartition, RhoAppAdapter.ERR_NONE);
804
+
805
+ dbPartition.setBulkSyncDB(fDataName, fScriptName);
806
+ processServerSources("{\"partition\":\"" + strPartition + "\"}");
807
+
808
+ LOG.INFO("Bulk sync: end change db");
809
+ getNotify().fireBulkSyncNotification(false, "", strPartition, RhoAppAdapter.ERR_NONE);
810
+ }
811
+
812
+ void downloadBulkDataAndUnzip(String strDataUrl, String fDataName, String strPartition)throws Exception
813
+ {
814
+ LOG.INFO("Bulk sync: download data from server: " + strDataUrl);
782
815
  {
783
- NetResponse resp1 = getNet().pullFile(strHsqlScriptUrl, fScriptName, this, null);
816
+ NetResponse resp1 = getNet().pullFile(strDataUrl, fDataName, this, null);
784
817
  if ( !resp1.isOK() )
785
818
  {
786
- LOG.ERROR("Bulk sync failed: cannot download database file.");
819
+ LOG.ERROR("Bulk sync failed: cannot download database file: " + resp1.getRespCode() );
787
820
  stopSync();
788
821
  getNotify().fireBulkSyncNotification(true, "", strPartition, RhoAppAdapter.getErrorFromResponse(resp1));
789
822
  return;
790
823
  }
791
824
  }
792
-
793
- LOG.INFO("Bulk sync: start change db");
794
- getNotify().fireBulkSyncNotification(false, "change_db", strPartition, RhoAppAdapter.ERR_NONE);
795
825
 
796
- dbPartition.setBulkSyncDB(fDataName, fScriptName);
797
- processServerSources("{\"partition\":\"" + strPartition + "\"}");
826
+ LOG.INFO("Bulk sync: unzip db");
827
+
828
+ try
829
+ {
830
+ RhoClassFactory.createRhoRubyHelper().unzip_file(fDataName);
831
+ }catch(Exception exc)
832
+ {
833
+ LOG.ERROR("Bulk sync failed: cannot unzip database file.", exc);
834
+ stopSync();
835
+ getNotify().fireBulkSyncNotification(true, "", strPartition, RhoAppAdapter.ERR_UNEXPECTEDSERVERRESPONSE);
836
+ }
798
837
 
799
- LOG.INFO("Bulk sync: end change db");
800
- getNotify().fireBulkSyncNotification(false, "", strPartition, RhoAppAdapter.ERR_NONE);
838
+ IFileAccess fs = RhoClassFactory.createFileAccess();
839
+ fs.delete(fDataName);
801
840
  }
802
841
 
803
842
  String makeBulkDataFileName(String strDataUrl, String strDbPath, String strExt)throws Exception
@@ -879,7 +918,7 @@ public class SyncEngine implements NetRequest.IRhoSession
879
918
  getNotify().fireSyncNotification(null, true, RhoAppAdapter.ERR_NONE, RhoAppAdapter.getMessageText("sync_completed"));
880
919
  }
881
920
 
882
- void login(String name, String password, String callback)
921
+ void login(String name, String password, SyncNotify.SyncNotification oNotify)
883
922
  {
884
923
  try {
885
924
  /*
@@ -900,13 +939,13 @@ public class SyncEngine implements NetRequest.IRhoSession
900
939
  int nErrCode = RhoAppAdapter.getErrorFromResponse(resp);
901
940
  if ( nErrCode != RhoAppAdapter.ERR_NONE )
902
941
  {
903
- getNotify().callLoginCallback(callback, nErrCode, resp.getCharData());
942
+ getNotify().callLoginCallback(oNotify, nErrCode, resp.getCharData());
904
943
  return;
905
944
  }
906
945
  }catch(IOException exc)
907
946
  {
908
947
  LOG.ERROR("Login failed.", exc);
909
- getNotify().callLoginCallback(callback, RhoAppAdapter.getNetErrorCode(exc), "" );
948
+ getNotify().callLoginCallback(oNotify, RhoAppAdapter.getNetErrorCode(exc), "" );
910
949
  return;
911
950
  }
912
951
 
@@ -914,7 +953,7 @@ public class SyncEngine implements NetRequest.IRhoSession
914
953
  if ( strSession == null || strSession.length() == 0 )
915
954
  {
916
955
  LOG.ERROR("Return empty session.");
917
- getNotify().callLoginCallback(callback, RhoAppAdapter.ERR_UNEXPECTEDSERVERRESPONSE, "" );
956
+ getNotify().callLoginCallback(oNotify, RhoAppAdapter.ERR_UNEXPECTEDSERVERRESPONSE, "" );
918
957
  return;
919
958
  }
920
959
 
@@ -922,12 +961,27 @@ public class SyncEngine implements NetRequest.IRhoSession
922
961
  return;
923
962
 
924
963
  IDBResult res = getUserDB().executeSQL("SELECT * FROM client_info");
925
- if ( !res.isEnd() )
964
+ if ( !res.isOneEnd() )
926
965
  getUserDB().executeSQL( "UPDATE client_info SET session=?", strSession );
927
966
  else
928
967
  getUserDB().executeSQL("INSERT INTO client_info (session) values (?)", strSession);
929
968
 
930
- getNotify().callLoginCallback(callback, RhoAppAdapter.ERR_NONE, "" );
969
+ if ( RHOCONF().isExist("rho_sync_user") )
970
+ {
971
+ String strOldUser = RHOCONF().getString("rho_sync_user");
972
+ if ( name.compareTo(strOldUser) != 0 )
973
+ {
974
+ if (isNoThreadedMode())
975
+ RhoAppAdapter.resetDBOnSyncUserChanged();
976
+ else
977
+ {
978
+ NetResponse resp1 = getNet().pushData( getNet().resolveUrl("/system/resetDBOnSyncUserChanged"), "", null );
979
+ }
980
+ }
981
+ }
982
+ RHOCONF().setString("rho_sync_user", name, true);
983
+
984
+ getNotify().callLoginCallback(oNotify, RhoAppAdapter.ERR_NONE, "" );
931
985
 
932
986
  if ( ClientRegister.getInstance() != null )
933
987
  ClientRegister.getInstance().startUp();
@@ -935,7 +989,7 @@ public class SyncEngine implements NetRequest.IRhoSession
935
989
  }catch(Exception exc)
936
990
  {
937
991
  LOG.ERROR("Login failed.", exc);
938
- getNotify().callLoginCallback(callback, RhoAppAdapter.ERR_RUNTIME, "" );
992
+ getNotify().callLoginCallback(oNotify, RhoAppAdapter.ERR_RUNTIME, "" );
939
993
  }
940
994
  }
941
995
 
@@ -944,7 +998,7 @@ public class SyncEngine implements NetRequest.IRhoSession
944
998
  String strRes = "";
945
999
  IDBResult res = getUserDB().executeSQL("SELECT session FROM client_info");
946
1000
 
947
- if ( !res.isEnd() )
1001
+ if ( !res.isOneEnd() )
948
1002
  strRes = res.getStringByIdx(0);
949
1003
 
950
1004
  return strRes.length() > 0;
@@ -955,7 +1009,7 @@ public class SyncEngine implements NetRequest.IRhoSession
955
1009
  m_strSession = "";
956
1010
  IDBResult res = getUserDB().executeSQL("SELECT session FROM client_info");
957
1011
 
958
- if ( !res.isEnd() )
1012
+ if ( !res.isOneEnd() )
959
1013
  m_strSession = res.getStringByIdx(0);
960
1014
 
961
1015
  return m_strSession;
@@ -972,15 +1026,19 @@ public class SyncEngine implements NetRequest.IRhoSession
972
1026
  //loadAllSources();
973
1027
  }
974
1028
 
975
- public void setSyncServer(String url)throws Exception
1029
+ public void setSyncServer(String syncserver)throws Exception
976
1030
  {
977
- RhoConf.getInstance().setPropertyByName("syncserver", url);
978
- RhoConf.getInstance().saveToFile();
979
- RhoConf.getInstance().loadConf();
980
-
981
- getUserDB().executeSQL("DELETE FROM client_info");
1031
+ String strOldSrv = RhoConf.getInstance().getString("syncserver");
1032
+ String strNewSrv = syncserver != null ? syncserver : "";
982
1033
 
983
- logout();
1034
+ if ( strOldSrv.compareTo(strNewSrv) != 0)
1035
+ {
1036
+ RhoConf.getInstance().setString("syncserver", syncserver, true);
1037
+
1038
+ getUserDB().executeSQL("DELETE FROM client_info");
1039
+
1040
+ logout();
1041
+ }
984
1042
  }
985
1043
 
986
1044
  static String getHostFromUrl( String strUrl )
@@ -18,7 +18,7 @@ public class SyncNotify {
18
18
  private static final RhoLogger LOG = RhoLogger.RHO_STRIP_LOG ? new RhoEmptyLogger() :
19
19
  new RhoLogger("Sync");
20
20
 
21
- static class SyncNotification
21
+ public static class SyncNotification
22
22
  {
23
23
  String m_strUrl ="", m_strParams="";
24
24
  boolean m_bRemoveAfterFire;
@@ -26,7 +26,13 @@ public class SyncNotify {
26
26
  SyncNotification(){m_bRemoveAfterFire = false;}
27
27
 
28
28
  SyncNotification(String strUrl, String strParams, boolean bRemoveAfterFire)
29
- { m_strUrl = strUrl; m_strParams = strParams; m_bRemoveAfterFire = bRemoveAfterFire; }
29
+ {
30
+ if ( strUrl.length() > 0 )
31
+ m_strUrl = RhodesApp.getInstance().canonicalizeRhoUrl(strUrl);
32
+
33
+ m_strParams = strParams;
34
+ m_bRemoveAfterFire = bRemoveAfterFire;
35
+ }
30
36
  };
31
37
 
32
38
  public static final Integer enNone = new Integer(0), enDelete=new Integer(1), enUpdate=new Integer(2), enCreate=new Integer(3);
@@ -164,7 +170,7 @@ public class SyncNotify {
164
170
  if ( nNotifyType == enDelete.intValue() )
165
171
  {
166
172
  IDBResult res = getDB().executeSQL("SELECT object FROM object_values where object=? LIMIT 1 OFFSET 0", strObject );
167
- if ( !res.isEnd() )
173
+ if ( !res.isOneEnd() )
168
174
  nNotifyType = enUpdate.intValue();
169
175
  }
170
176
  */
@@ -193,7 +199,7 @@ public class SyncNotify {
193
199
  return;
194
200
  }
195
201
 
196
- callNotify(strUrl, strBody);
202
+ callNotify( new SyncNotification(strUrl,"",false), strBody);
197
203
  }
198
204
 
199
205
  void onObjectChanged(Integer nSrcID, String strObject, Integer nType)
@@ -285,7 +291,7 @@ public class SyncNotify {
285
291
 
286
292
  cleanCreateObjectErrors();
287
293
  }
288
-
294
+ /*
289
295
  void setSyncNotification(int source_id, String strUrl, String strParams )throws Exception
290
296
  {
291
297
  LOG.INFO( "Set notification. Source ID: " + source_id + "; Url :" + strUrl + "; Params: " + strParams );
@@ -308,7 +314,26 @@ public class SyncNotify {
308
314
  LOG.INFO( " Done Set notification. Source ID: " + source_id + "; Url :" + strFullUrl + "; Params: " + strParams );
309
315
  }
310
316
  }
311
- }
317
+ }*/
318
+ void setSyncNotification(int source_id, SyncNotification pNotify)
319
+ {
320
+ LOG.INFO("Set notification. Source ID: " + source_id + ";" + (pNotify != null? pNotify.toString() : "") );
321
+
322
+ if ( source_id == -1 )
323
+ {
324
+ synchronized(m_mxSyncNotifications)
325
+ {
326
+ m_pAllNotification = pNotify;
327
+ }
328
+ }else
329
+ {
330
+ synchronized(m_mxSyncNotifications)
331
+ {
332
+ m_mapSyncNotifications.put( new Integer(source_id), pNotify );
333
+ }
334
+ }
335
+
336
+ }
312
337
 
313
338
  void setSearchNotification(String strUrl, String strParams )throws Exception
314
339
  {
@@ -376,7 +401,17 @@ public class SyncNotify {
376
401
  {
377
402
  if ( getSync().getState() == SyncEngine.esExit )
378
403
  return;
379
-
404
+
405
+ if( nErrCode != RhoAppAdapter.ERR_NONE)
406
+ {
407
+ if ( !getSync().isSearch() )
408
+ {
409
+ String strMessage = RhoAppAdapter.getMessageText("sync_failed_for") + "all.";
410
+
411
+ reportSyncStatus(strMessage,nErrCode,strError);
412
+ }
413
+ }
414
+
380
415
  synchronized(m_mxSyncNotifications)
381
416
  {
382
417
  SyncNotification pSN = getSyncNotifyBySrc(null);
@@ -430,15 +465,16 @@ public class SyncNotify {
430
465
  return;
431
466
 
432
467
  try{
433
- String strBody = "", strUrl;
468
+ SyncNotification pSN = null;
469
+
470
+ String strBody = "";
434
471
  boolean bRemoveAfterFire = bFinish;
435
472
  {
436
473
  synchronized(m_mxSyncNotifications){
437
- SyncNotification sn = getSyncNotifyBySrc(src);
438
- if ( sn == null )
474
+ pSN = getSyncNotifyBySrc(src);
475
+ if ( pSN == null )
439
476
  return;
440
477
 
441
- strUrl = sn.m_strUrl;
442
478
  strBody = "";
443
479
 
444
480
  if ( src != null )
@@ -488,18 +524,18 @@ public class SyncNotify {
488
524
  strBody += "in_progress";
489
525
 
490
526
  strBody += "&rho_callback=1";
491
- if ( sn.m_strParams.length() > 0 )
492
- strBody += "&" + sn.m_strParams;
527
+ if ( pSN.m_strParams.length() > 0 )
528
+ strBody += "&" + pSN.m_strParams;
493
529
 
494
- bRemoveAfterFire = bRemoveAfterFire && sn.m_bRemoveAfterFire;
530
+ bRemoveAfterFire = bRemoveAfterFire && pSN.m_bRemoveAfterFire;
495
531
  }
496
532
  }
497
533
  if ( bRemoveAfterFire )
498
534
  clearNotification(src);
499
535
 
500
- LOG.INFO( "Fire notification. Source ID: " + (src != null ? src.getID().toString() : "") + "; Url :" + strUrl + "; Body: " + strBody );
501
-
502
- if ( callNotify(strUrl, strBody) )
536
+ LOG.INFO("Fire notification. Source : " + (src != null ? (src).getName():"") + "; " + pSN.toString());
537
+
538
+ if ( callNotify(pSN, strBody) )
503
539
  clearNotification(src);
504
540
  }catch(Exception exc)
505
541
  {
@@ -507,7 +543,7 @@ public class SyncNotify {
507
543
  }
508
544
  }
509
545
 
510
- boolean callNotify(String strUrl, String strBody )throws Exception
546
+ boolean callNotify(SyncNotification oNotify, String strBody )throws Exception
511
547
  {
512
548
  if ( getSync().isNoThreadedMode() )
513
549
  {
@@ -515,7 +551,10 @@ public class SyncNotify {
515
551
  return false;
516
552
  }
517
553
 
518
- NetResponse resp = getNet().pushData( strUrl, strBody, null );
554
+ if ( oNotify.m_strUrl.length() == 0 )
555
+ return true;
556
+
557
+ NetResponse resp = getNet().pushData( oNotify.m_strUrl, strBody, null );
519
558
  if ( !resp.isOK() )
520
559
  LOG.ERROR( "Fire object notification failed. Code: " + resp.getRespCode() + "; Error body: " + resp.getCharData() );
521
560
  else
@@ -590,7 +629,7 @@ public class SyncNotify {
590
629
  return nCount;
591
630
  }
592
631
 
593
- void callLoginCallback(String callback, int nErrCode, String strMessage)
632
+ void callLoginCallback(SyncNotification oNotify, int nErrCode, String strMessage)
594
633
  {
595
634
  try{
596
635
  if ( getSync().isStoppedByUser() )
@@ -600,11 +639,9 @@ public class SyncNotify {
600
639
  strBody += "&error_message=" + URI.urlEncode(strMessage != null? strMessage : "");
601
640
  strBody += "&rho_callback=1";
602
641
 
603
- String strUrl = getNet().resolveUrl(callback);
604
-
605
- LOG.INFO( "Login callback: " + callback + ". Body: "+ strBody );
642
+ LOG.INFO( "Login callback: " + oNotify.toString() + ". Body: "+ strBody );
606
643
 
607
- callNotify(strUrl, strBody);
644
+ callNotify(oNotify, strBody);
608
645
  }catch(Exception exc)
609
646
  {
610
647
  LOG.ERROR("Call Login callback failed.", exc);