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
@@ -10,6 +10,7 @@
10
10
  #ifndef RHO_NO_RUBY
11
11
  #include "ruby/ext/rho/rhoruby.h"
12
12
  #endif //RHO_NO_RUBY
13
+ #include "common/app_build_configs.h"
13
14
 
14
15
  namespace rho{
15
16
  namespace db{
@@ -40,7 +41,7 @@ void SyncBlob_DeleteCallback(sqlite3_context* dbContext, int nArgs, sqlite3_valu
40
41
  CRhoFile::deleteFile(strFilePath.c_str());
41
42
  }
42
43
 
43
- attrMgr.remove( nSrcID, szAttrName );
44
+ //attrMgr.remove( nSrcID, szAttrName );
44
45
  }
45
46
 
46
47
  void SyncBlob_UpdateCallback(sqlite3_context* dbContext, int nArgs, sqlite3_value** ppArgs)
@@ -68,10 +69,10 @@ void SyncBlob_DeleteSchemaCallback(sqlite3_context* dbContext, int nArgs, sqlite
68
69
 
69
70
  void SyncBlob_InsertCallback(sqlite3_context* dbContext, int nArgs, sqlite3_value** ppArgs)
70
71
  {
71
- if ( nArgs < 2 )
72
- return;
72
+ //if ( nArgs < 2 )
73
+ // return;
73
74
 
74
- CDBAdapter::getDBByHandle(sqlite3_context_db_handle(dbContext)).getAttrMgr().add( sqlite3_value_int(*(ppArgs)), (char*)sqlite3_value_text(*(ppArgs+1)) );
75
+ //CDBAdapter::getDBByHandle(sqlite3_context_db_handle(dbContext)).getAttrMgr().add( sqlite3_value_int(*(ppArgs)), (char*)sqlite3_value_text(*(ppArgs+1)) );
75
76
  }
76
77
 
77
78
  boolean CDBAdapter::checkDbError(int rc)
@@ -125,6 +126,22 @@ void CDBAdapter::open (String strDbPath, String strVer, boolean bTemp)
125
126
  if ( !checkDbError(nRes) )
126
127
  return;
127
128
  //TODO: raise exception if error
129
+
130
+ //if (RHOCONF().getBool("encrypt_database"))
131
+ const char* szEncrypt = get_app_build_config_item("encrypt_database");
132
+ if ( szEncrypt && strcmp(szEncrypt, "1") == 0 )
133
+ {
134
+ common::CAutoPtr<common::IRhoClassFactory> factory = rho_impl_createClassFactory();
135
+ m_ptrCrypt = factory->createRhoCrypt();
136
+ if ( m_strCryptKey.length() > 0 )
137
+ m_ptrCrypt->set_db_CryptKey( m_strDbPartition.c_str(), m_strCryptKey.c_str(), !bTemp );
138
+
139
+ CDBError dbError;
140
+ String strKey = "PRAGMA key = \"";
141
+ strKey += m_strDbPartition + "\";";
142
+ executeBatch(strKey.c_str(), dbError);
143
+ }
144
+
128
145
  if ( !bExist )
129
146
  createSchema();
130
147
 
@@ -141,7 +158,7 @@ void CDBAdapter::open (String strDbPath, String strVer, boolean bTemp)
141
158
 
142
159
  sqlite3_busy_handler(m_dbHandle, onDBBusy, 0 );
143
160
 
144
- getAttrMgr().load(*this);
161
+ //getAttrMgr().load(*this);
145
162
 
146
163
  //copy client_info table
147
164
  if ( !bTemp && !bExist && CRhoFile::isFileExist((strDbPath+"_oldver").c_str()) )
@@ -259,6 +276,9 @@ void CDBAdapter::checkDBVersion(String& strRhoDBVer)
259
276
  CRhoFile::deleteFilesInFolder(RHODESAPPBASE().getBlobsDirPath().c_str());
260
277
 
261
278
  writeDBVersion( CDBVersion(strRhoDBVer, strAppDBVer) );
279
+
280
+ if ( RHOCONF().isExist("bulksync_state") && RHOCONF().getInt("bulksync_state") != 0)
281
+ RHOCONF().setInt("bulksync_state", 0, true);
262
282
  }
263
283
  }
264
284
 
@@ -385,7 +405,7 @@ boolean CDBAdapter::isTableExist(String strTableName)
385
405
 
386
406
  void CDBAdapter::destroy_tables(const rho::Vector<rho::String>& arIncludeTables, const rho::Vector<rho::String>& arExcludeTables)
387
407
  {
388
- getAttrMgr().reset(*this);
408
+ //getAttrMgr().reset(*this);
389
409
  CFilePath oFilePath(m_strDbPath);
390
410
  String dbNewName = oFilePath.changeBaseName("resetdbtemp.sqlite");
391
411
 
@@ -445,8 +465,76 @@ void CDBAdapter::copyTable(String tableName, CDBAdapter& dbFrom, CDBAdapter& dbT
445
465
  }
446
466
  }
447
467
 
468
+ void CDBAdapter::updateAllAttribChanges()
469
+ {
470
+ //Check for attrib = object
471
+ DBResult( res , executeSQL("SELECT object, source_id, update_type "
472
+ "FROM changed_values where attrib = 'object' and sent=0") );
473
+
474
+ if ( res.isEnd() )
475
+ return;
476
+
477
+ startTransaction();
478
+
479
+ Vector<String> arObj, arUpdateType;
480
+ Vector<int> arSrcID;
481
+ for( ; !res.isEnd(); res.next() )
482
+ {
483
+ arObj.addElement(res.getStringByIdx(0));
484
+ arSrcID.addElement(res.getIntByIdx(1));
485
+ arUpdateType.addElement(res.getStringByIdx(2));
486
+ }
487
+
488
+ for( int i = 0; i < (int)arObj.size(); i++ )
489
+ {
490
+ DBResult( resSrc , executeSQL("SELECT name, schema FROM sources where source_id=?", arSrcID.elementAt(i) ) );
491
+ boolean bSchemaSource = false;
492
+ String strTableName = "object_values";
493
+ if ( !resSrc.isEnd() )
494
+ {
495
+ bSchemaSource = resSrc.getStringByIdx(1).length() > 0;
496
+ if ( bSchemaSource )
497
+ strTableName = resSrc.getStringByIdx(0);
498
+ }
499
+
500
+ if (bSchemaSource)
501
+ {
502
+ DBResult( res2 , executeSQL((String("SELECT * FROM ") + strTableName + " where object=?").c_str(), arObj.elementAt(i) ) );
503
+ for( int j = 0; j < res2.getColCount(); j ++)
504
+ {
505
+ String strAttrib = res2.getColName(j);
506
+ String value = res2.getStringByIdx(j);
507
+ String attribType = getAttrMgr().isBlobAttr(arSrcID.elementAt(i), strAttrib.c_str()) ? "blob.file" : "";
508
+
509
+ executeSQLReportNonUnique("INSERT INTO changed_values (source_id,object,attrib,value,update_type,attrib_type,sent) VALUES(?,?,?,?,?,?,?)",
510
+ arSrcID.elementAt(i), arObj.elementAt(i), strAttrib, value, arUpdateType.elementAt(i), attribType, 0);
511
+ }
512
+ }else
513
+ {
514
+ DBResult( res2 , executeSQL((String("SELECT attrib, value FROM ") + strTableName + " where object=? and source_id=?").c_str(),
515
+ arObj.elementAt(i), arSrcID.elementAt(i) ) );
516
+
517
+ for( ; !res2.isEnd(); res2.next() )
518
+ {
519
+ String strAttrib = res2.getStringByIdx(0);
520
+ String value = res2.getStringByIdx(1);
521
+ String attribType = getAttrMgr().isBlobAttr(arSrcID.elementAt(i), strAttrib.c_str()) ? "blob.file" : "";
522
+
523
+ executeSQLReportNonUnique("INSERT INTO changed_values (source_id,object,attrib,value,update_type,attrib_type,sent) VALUES(?,?,?,?,?,?,?)",
524
+ arSrcID.elementAt(i), arObj.elementAt(i), strAttrib, value, arUpdateType.elementAt(i), attribType, 0);
525
+ }
526
+ }
527
+ }
528
+
529
+ executeSQL("DELETE FROM changed_values WHERE attrib='object'");
530
+
531
+ endTransaction();
532
+ }
533
+
448
534
  void CDBAdapter::copyChangedValues(CDBAdapter& db)
449
535
  {
536
+ updateAllAttribChanges();
537
+
450
538
  copyTable("changed_values", *this, db );
451
539
  {
452
540
  Vector<int> arOldSrcs;
@@ -455,7 +543,7 @@ void CDBAdapter::copyChangedValues(CDBAdapter& db)
455
543
  for ( ; !resSrc.isEnd(); resSrc.next() )
456
544
  arOldSrcs.addElement( resSrc.getIntByIdx(0) );
457
545
  }
458
- for( int i = 0; i < arOldSrcs.size(); i++)
546
+ for( int i = 0; i < (int)arOldSrcs.size(); i++)
459
547
  {
460
548
  int nOldSrcID = arOldSrcs.elementAt(i);
461
549
 
@@ -480,9 +568,10 @@ void CDBAdapter::copyChangedValues(CDBAdapter& db)
480
568
  }
481
569
  }
482
570
 
483
- void CDBAdapter::setBulkSyncDB(String fDataName)
571
+ void CDBAdapter::setBulkSyncDB(String fDataName, String strCryptKey)
484
572
  {
485
573
  CDBAdapter db(m_strDbPartition.c_str(), true);
574
+ db.setCryptKey(strCryptKey);
486
575
  db.open( fDataName, m_strDbVer, true );
487
576
  db.createTriggers();
488
577
 
@@ -491,6 +580,7 @@ void CDBAdapter::setBulkSyncDB(String fDataName)
491
580
  copyTable("client_info", *this, db );
492
581
  copyChangedValues(db);
493
582
 
583
+ /*
494
584
  //update User partition
495
585
  if ( m_strDbPartition.compare(USER_PARTITION_NAME())==0 )
496
586
  {
@@ -510,7 +600,7 @@ void CDBAdapter::setBulkSyncDB(String fDataName)
510
600
  copyTable("sources", db, dbUser );
511
601
 
512
602
  dbUser.endTransaction();
513
- }
603
+ }*/
514
604
 
515
605
  getDBPartitions().put(m_strDbPartition.c_str(), &db);
516
606
  sync::CSyncThread::getSyncEngine().applyChangedValues(db);
@@ -526,6 +616,7 @@ void CDBAdapter::setBulkSyncDB(String fDataName)
526
616
 
527
617
  CRhoFile::deleteFile(dbOldName.c_str());
528
618
  CRhoFile::renameFile(fDataName.c_str(),dbOldName.c_str());
619
+ setCryptKey(strCryptKey);
529
620
  open( dbOldName, m_strDbVer, false );
530
621
  }
531
622
 
@@ -614,6 +705,9 @@ void CDBAdapter::close()
614
705
 
615
706
  m_dbHandle = 0;
616
707
  m_strDbPath = String();
708
+
709
+ m_ptrCrypt = 0;
710
+ m_strCryptKey = "";
617
711
  }
618
712
 
619
713
  int CDBAdapter::prepareSqlStatement(const char* szSql, int nByte, sqlite3_stmt **ppStmt)
@@ -668,7 +762,7 @@ DBResultPtr CDBAdapter::executeSQLReportNonUniqueEx( const char* szSt, Vector<St
668
762
  bind(res->getStatement(), i+1, arValues.elementAt(i));
669
763
 
670
764
  res->setReportNonUnique(true);
671
- return executeStatement(res);
765
+ return executeStatement(res, szSt);
672
766
  }
673
767
 
674
768
  DBResultPtr CDBAdapter::executeSQLEx( const char* szSt, Vector<String>& arValues)
@@ -680,7 +774,7 @@ DBResultPtr CDBAdapter::executeSQLEx( const char* szSt, Vector<String>& arValues
680
774
  for (int i = 0; i < (int)arValues.size(); i++ )
681
775
  bind(res->getStatement(), i+1, arValues.elementAt(i));
682
776
 
683
- return executeStatement(res);
777
+ return executeStatement(res, szSt);
684
778
  }
685
779
 
686
780
  DBResultPtr CDBAdapter::executeSQL( const char* szSt)
@@ -689,11 +783,13 @@ DBResultPtr CDBAdapter::executeSQL( const char* szSt)
689
783
  if ( res->getStatement() == null )
690
784
  return res;
691
785
 
692
- return executeStatement(res);
786
+ return executeStatement(res, szSt);
693
787
  }
694
788
 
695
- DBResultPtr CDBAdapter::executeStatement(DBResultPtr& res)
789
+ DBResultPtr CDBAdapter::executeStatement(DBResultPtr& res, const char* szSt)
696
790
  {
791
+ //LOG(INFO) + "executeStatement:" + szSt;
792
+
697
793
  int rc = sqlite3_step(res->getStatement());
698
794
  if ( rc != SQLITE_ROW )
699
795
  {
@@ -749,7 +845,7 @@ void CDBAdapter::endTransaction()
749
845
  m_nTransactionCounter--;
750
846
  if (m_dbHandle && m_nTransactionCounter == 0)
751
847
  {
752
- getAttrMgr().save(*this);
848
+ //getAttrMgr().save(*this);
753
849
  rc = sqlite3_exec(m_dbHandle, "END;",0,0,&zErr);
754
850
  checkDbError(rc);
755
851
  }
@@ -794,6 +890,15 @@ void CDBAdapter::rollback()
794
890
  return *getDBPartitions().get(szPartition);
795
891
  }
796
892
 
893
+ /*static*/ Vector<String> CDBAdapter::getDBAllPartitionNames()
894
+ {
895
+ Vector<String> vecNames;
896
+ for (Hashtable<String,CDBAdapter*>::iterator it = m_mapDBPartitions.begin(); it != m_mapDBPartitions.end(); ++it )
897
+ vecNames.addElement(it->first);
898
+
899
+ return vecNames;
900
+ }
901
+
797
902
  /*static*/ boolean CDBAdapter::isAnyInsideTransaction()
798
903
  {
799
904
  for (Hashtable<String,CDBAdapter*>::iterator it = m_mapDBPartitions.begin(); it != m_mapDBPartitions.end(); ++it )
@@ -805,13 +910,13 @@ void CDBAdapter::rollback()
805
910
  return false;
806
911
  }
807
912
 
808
- /*static*/ void CDBAdapter::destroy_tables_allpartitions(const rho::Vector<rho::String>& arIncludeTables, const rho::Vector<rho::String>& arExcludeTables)
913
+ /*static void CDBAdapter::destroy_tables_allpartitions(const rho::Vector<rho::String>& arIncludeTables, const rho::Vector<rho::String>& arExcludeTables)
809
914
  {
810
915
  for (Hashtable<String,CDBAdapter*>::iterator it = m_mapDBPartitions.begin(); it != m_mapDBPartitions.end(); ++it )
811
916
  {
812
917
  it->second->destroy_tables(arIncludeTables, arExcludeTables);
813
918
  }
814
- }
919
+ }*/
815
920
 
816
921
  /*static*/ db::CDBAdapter& CDBAdapter::getDBByHandle(sqlite3* db)
817
922
  {
@@ -907,7 +1012,7 @@ void* rho_db_get_handle(void* pDB)
907
1012
  rho::db::CDBAdapter& db = *((rho::db::CDBAdapter*)pDB);
908
1013
  return db.getDbHandle();
909
1014
  }
910
-
1015
+ /*
911
1016
  void* rho_db_user_get_handle()
912
1017
  {
913
1018
  rho::db::CDBAdapter& db = rho::db::CDBAdapter::getUserDB();
@@ -918,7 +1023,7 @@ void* rho_db_user_get_adapter()
918
1023
  {
919
1024
  rho::db::CDBAdapter& db = rho::db::CDBAdapter::getUserDB();
920
1025
  return &db;
921
- }
1026
+ } */
922
1027
 
923
1028
  int rho_db_prepare_statement(void* pDB, const char* szSql, int nByte, sqlite3_stmt **ppStmt)
924
1029
  {
@@ -949,6 +1054,30 @@ void rho_db_init_attr_manager()
949
1054
  rho::db::CDBAdapter::initAttrManager();
950
1055
  }
951
1056
 
1057
+ void rho_sync_update_blob_attribs(const char* szPartition, int source_id)
1058
+ {
1059
+ rho::db::CDBAdapter& db = rho::db::CDBAdapter::getDB(szPartition);
1060
+ db.getAttrMgr().loadBlobAttrs(db);
1061
+ }
1062
+
1063
+ void rho_db_encrypt( const char* szPartition, int nPartLen, int size, unsigned char* data, unsigned char* dataOut )
1064
+ {
1065
+ String strPartition(szPartition, nPartLen);
1066
+ rho::db::CDBAdapter& db = rho::db::CDBAdapter::getDB(strPartition.c_str());
1067
+ if ( db.getCrypt() )
1068
+ db.getCrypt()->db_encrypt(strPartition.c_str(), size, data, dataOut);
1069
+ else
1070
+ memcpy(dataOut, data, size);
1071
+ }
1072
+
1073
+ void rho_db_decrypt( const char* szPartition, int nPartLen, int size, unsigned char* data )
1074
+ {
1075
+ String strPartition(szPartition, nPartLen);
1076
+ rho::db::CDBAdapter& db = rho::db::CDBAdapter::getDB( strPartition.c_str() );
1077
+ if ( db.getCrypt() )
1078
+ db.getCrypt()->db_decrypt(strPartition.c_str(), size, data);
1079
+ }
1080
+
952
1081
  }
953
1082
 
954
1083
  namespace rho{
@@ -3,6 +3,7 @@
3
3
  #include "DBResult.h"
4
4
  #include "DBAttrManager.h"
5
5
  #include "logging/RhoLog.h"
6
+ #include "common/IRhoCrypt.h"
6
7
 
7
8
  namespace rho{
8
9
  namespace common{
@@ -36,6 +37,8 @@ class CDBAdapter
36
37
  int m_nTransactionCounter;
37
38
  CDBAttrManager m_attrMgr;
38
39
  static HashtablePtr<String,CDBAdapter*> m_mapDBPartitions;
40
+ common::CAutoPtr<common::IRhoCrypt> m_ptrCrypt;
41
+ String m_strCryptKey;
39
42
 
40
43
  struct CDBVersion
41
44
  {
@@ -68,6 +71,8 @@ public:
68
71
  void Unlock();
69
72
  boolean isInsideTransaction(){ return m_nTransactionCounter > 0; }
70
73
  const String& getDBPath(){ return m_strDbPath; }
74
+ common::IRhoCrypt* getCrypt(){ return m_ptrCrypt; }
75
+ void setCryptKey(String& strKey){ m_strCryptKey = strKey; }
71
76
 
72
77
  static HashtablePtr<String,CDBAdapter*>& getDBPartitions(){ return m_mapDBPartitions; }
73
78
  static void closeAll();
@@ -76,7 +81,8 @@ public:
76
81
  static CDBAdapter& getUserDB();
77
82
  static CDBAdapter& getDBByHandle(sqlite3* db);
78
83
  static CDBAdapter& getDB(const char* szPartition);
79
- static void destroy_tables_allpartitions(const rho::Vector<rho::String>& arIncludeTables, const rho::Vector<rho::String>& arExcludeTables);
84
+ static Vector<String> getDBAllPartitionNames();
85
+ //static void destroy_tables_allpartitions(const rho::Vector<rho::String>& arIncludeTables, const rho::Vector<rho::String>& arExcludeTables);
80
86
 
81
87
  boolean isTableExist(String strTableName);
82
88
  int prepareSqlStatement(const char* szSql, int nByte, sqlite3_stmt **ppStmt);
@@ -112,7 +118,7 @@ public:
112
118
  bind(res->getStatement(), 1, p1);
113
119
  bind(res->getStatement(), 2, p2);
114
120
 
115
- return executeStatement(res);
121
+ return executeStatement(res, szSt);
116
122
  }
117
123
 
118
124
  template<typename T1, typename T2, typename T3>
@@ -126,7 +132,7 @@ public:
126
132
  bind(res->getStatement(), 2, p2);
127
133
  bind(res->getStatement(), 3, p3);
128
134
 
129
- return executeStatement(res);
135
+ return executeStatement(res, szSt);
130
136
  }
131
137
 
132
138
  template<typename T1, typename T2, typename T3, typename T4>
@@ -141,7 +147,7 @@ public:
141
147
  bind(res->getStatement(), 3, p3);
142
148
  bind(res->getStatement(), 4, p4);
143
149
 
144
- return executeStatement(res);
150
+ return executeStatement(res, szSt);
145
151
  }
146
152
 
147
153
  template<typename T1, typename T2, typename T3, typename T4, typename T5>
@@ -157,7 +163,7 @@ public:
157
163
  bind(res->getStatement(), 4, p4);
158
164
  bind(res->getStatement(), 5, p5);
159
165
 
160
- return executeStatement(res);
166
+ return executeStatement(res, szSt);
161
167
  }
162
168
 
163
169
  template<typename T1, typename T2, typename T3, typename T4, typename T5, typename T6>
@@ -174,7 +180,7 @@ public:
174
180
  bind(res->getStatement(), 5, p5);
175
181
  bind(res->getStatement(), 6, p6);
176
182
 
177
- return executeStatement(res);
183
+ return executeStatement(res, szSt);
178
184
  }
179
185
 
180
186
  DBResultPtr executeSQLReportNonUniqueEx( const char* szSt, Vector<String>& arValues );
@@ -192,7 +198,26 @@ public:
192
198
  bind(res->getStatement(), 4, p4);
193
199
 
194
200
  res->setReportNonUnique(true);
195
- return executeStatement(res);
201
+ return executeStatement(res, szSt);
202
+ }
203
+
204
+ template<typename T1, typename T2, typename T3, typename T4, typename T5, typename T6, typename T7>
205
+ DBResultPtr executeSQLReportNonUnique( const char* szSt, T1 p1, T2 p2, T3 p3, T4 p4, T5 p5, T6 p6, T7 p7 )
206
+ {
207
+ DBResultPtr res = prepareStatement(szSt);
208
+ if ( res->getStatement() == null )
209
+ return res;
210
+
211
+ bind(res->getStatement(), 1, p1);
212
+ bind(res->getStatement(), 2, p2);
213
+ bind(res->getStatement(), 3, p3);
214
+ bind(res->getStatement(), 4, p4);
215
+ bind(res->getStatement(), 5, p5);
216
+ bind(res->getStatement(), 6, p6);
217
+ bind(res->getStatement(), 7, p7);
218
+
219
+ res->setReportNonUnique(true);
220
+ return executeStatement(res, szSt);
196
221
  }
197
222
 
198
223
  template<typename T1, typename T2, typename T3, typename T4, typename T5, typename T6, typename T7>
@@ -210,7 +235,7 @@ public:
210
235
  bind(res->getStatement(), 6, p6);
211
236
  bind(res->getStatement(), 7, p7);
212
237
 
213
- return executeStatement(res);
238
+ return executeStatement(res, szSt);
214
239
  }
215
240
 
216
241
  template<typename T1, typename T2, typename T3, typename T4, typename T5, typename T6, typename T7, typename T8>
@@ -229,7 +254,7 @@ public:
229
254
  bind(res->getStatement(), 7, p7);
230
255
  bind(res->getStatement(), 8, p8);
231
256
 
232
- return executeStatement(res);
257
+ return executeStatement(res, szSt);
233
258
  }
234
259
 
235
260
  template<typename T1>
@@ -240,7 +265,7 @@ public:
240
265
  return res;
241
266
 
242
267
  bind(res->getStatement(), 1, p1);
243
- return executeStatement(res);
268
+ return executeStatement(res, szSt);
244
269
  }
245
270
 
246
271
  DBResultPtr executeSQLEx( const char* szSt, Vector<String>& arValues);
@@ -251,12 +276,13 @@ public:
251
276
  void endTransaction();
252
277
  void rollback();
253
278
  void destroy_tables(const rho::Vector<rho::String>& arIncludeTables, const rho::Vector<rho::String>& arExcludeTables);
254
- void setBulkSyncDB(String fDataName);
279
+ void setBulkSyncDB(String fDataName, String strCryptKey);
255
280
 
256
281
  void createDeleteTrigger(const String& strTable);
257
282
 
258
283
  virtual DBResultPtr prepareStatement( const char* szSt );
259
- DBResultPtr executeStatement(common::CAutoPtr<CDBResult>& res);
284
+ DBResultPtr executeStatement(common::CAutoPtr<CDBResult>& res, const char* szSt);
285
+ void updateAllAttribChanges();
260
286
 
261
287
  private:
262
288
 
@@ -9,7 +9,7 @@
9
9
  namespace rho{
10
10
  namespace db{
11
11
  using namespace rho::common;
12
-
12
+ /*
13
13
  void CDBAttrManager::add( int nSrcID, const char* szAttr )
14
14
  {
15
15
  synchronized(m_mxSrcAttrs)
@@ -90,8 +90,8 @@ void CDBAttrManager::reset(CDBAdapter& db)
90
90
  m_mapSrcAttrs.clear();
91
91
  db.executeSQL("UPDATE sources SET source_attribs=?", "" );
92
92
  }
93
- }
94
-
93
+ }*/
94
+ /*
95
95
  #ifndef RHO_NO_RUBY
96
96
  unsigned long CDBAttrManager::getAttrsBySrc(int nSrcID)
97
97
  {
@@ -115,6 +115,7 @@ unsigned long CDBAttrManager::getAttrsBySrc(int nSrcID)
115
115
  }
116
116
  }
117
117
  #endif //RHO_NO_RUBY
118
+ */
118
119
 
119
120
  boolean CDBAttrManager::isBlobAttr(int nSrcID, const char* szAttr)
120
121
  {
@@ -9,22 +9,22 @@ class CDBAdapter;
9
9
 
10
10
  class CDBAttrManager
11
11
  {
12
- common::CMutex m_mxSrcAttrs;
13
- HashtablePtr< int, Hashtable<String,int>* > m_mapSrcAttrs;
12
+ //common::CMutex m_mxSrcAttrs;
13
+ //HashtablePtr< int, Hashtable<String,int>* > m_mapSrcAttrs;
14
14
 
15
15
  HashtablePtr< int, Hashtable<String,int>* > m_mapBlobAttrs;
16
16
 
17
17
  static void loadAttrs(CDBAdapter& db, HashtablePtr< int, Hashtable<String,int>* >& mapAttrs, String strDBAttr);
18
18
  public:
19
-
19
+ /*
20
20
  void add( int nSrcID, const char* szAttr );
21
21
  void remove( int nSrcID, const char* szAttr );
22
22
  void save(CDBAdapter& db);
23
23
  void load(CDBAdapter& db);
24
- void reset(CDBAdapter& db);
25
- #ifndef RHO_NO_RUBY
26
- unsigned long getAttrsBySrc(int nSrcID);
27
- #endif //RHO_NO_RUBY
24
+ void reset(CDBAdapter& db);*/
25
+ //#ifndef RHO_NO_RUBY
26
+ // unsigned long getAttrsBySrc(int nSrcID);
27
+ //#endif //RHO_NO_RUBY
28
28
  boolean isBlobAttr(int nSrcID, const char* szAttr);
29
29
  boolean isOverwriteBlobFromServer(int nSrcID, const String& strAttr);
30
30
  void loadBlobAttrs(CDBAdapter& db);
@@ -8,8 +8,3 @@ CREATE TRIGGER rhoupdateTrigger BEFORE UPDATE ON object_values FOR EACH ROW WHEN
8
8
  SELECT rhoOnUpdateObjectRecord(OLD.value, OLD.source_id, OLD.attrib );
9
9
  END;
10
10
  ;
11
- CREATE TRIGGER rhoinsertTrigger AFTER INSERT ON object_values FOR EACH ROW
12
- BEGIN
13
- SELECT rhoOnInsertObjectRecord( NEW.source_id, NEW.attrib );
14
- END;
15
- ;
@@ -0,0 +1,21 @@
1
+ CREATE TABLE object_attribs_to_delete(
2
+ "source_id" BIGINT default NULL,
3
+ "attrib" varchar(255) default NULL,
4
+ "object" varchar(255) default NULL,
5
+ "value" varchar default NULL);
6
+ CREATE TABLE object_attribs_to_update(
7
+ "source_id" BIGINT default NULL,
8
+ "attrib" varchar(255) default NULL,
9
+ "object" varchar(255) default NULL,
10
+ "value" varchar default NULL);
11
+
12
+ CREATE TRIGGER rhodeleteTrigger BEFORE DELETE ON object_values FOR EACH ROW
13
+ BEGIN
14
+ INSERT INTO object_attribs_to_delete(source_id, attrib, value) VALUES (OLD.source_id, OLD.attrib, OLD.value);
15
+ END;
16
+ ;
17
+ CREATE TRIGGER rhoupdateTrigger BEFORE UPDATE ON object_values FOR EACH ROW WHEN NEW.value != OLD.value
18
+ BEGIN
19
+ INSERT INTO object_attribs_to_update(source_id, attrib, value) VALUES (OLD.source_id, OLD.attrib, OLD.value);
20
+ END;
21
+ ;
@@ -231,6 +231,16 @@ uint64 CJSONEntry::getUInt64(const char* name)
231
231
  return nRes;
232
232
  }
233
233
 
234
+ double CJSONEntry::getDouble(const char* name)
235
+ {
236
+ double res = 0;
237
+ struct json_object* obj = json_object_object_get(m_object, const_cast<char*>(name));
238
+ if (obj != 0)
239
+ res = json_object_get_double(obj);
240
+
241
+ return res;
242
+ }
243
+
234
244
  /*
235
245
  uint64 CJSONEntry::getUInt64(const char* name)
236
246
  {
@@ -316,4 +326,4 @@ extern "C" VALUE rho_json_quote_value(VALUE v,VALUE str)
316
326
 
317
327
  return rho_ruby_create_string(strRes.c_str());
318
328
  }
319
- #endif //RHO_NO_RUBY
329
+ #endif //RHO_NO_RUBY
@@ -26,6 +26,7 @@ public:
26
26
 
27
27
  int getInt(const char* name);
28
28
  uint64 getUInt64(const char* name);
29
+ double getDouble(const char* name);
29
30
  const char* getString(const char* name);
30
31
  const char* getString();
31
32
 
@@ -6,7 +6,7 @@
6
6
  #include "common/RhoConf.h"
7
7
  #ifndef RHO_NO_RUBY
8
8
  #include "ruby/ext/rho/rhoruby.h"
9
- #endif /RHO_NO_RUBY
9
+ #endif //RHO_NO_RUBY
10
10
 
11
11
  namespace rho{
12
12
  common::CMutex LogSettings::m_FlushLock;
@@ -62,17 +62,15 @@ int LogSettings::getLogTextPos()
62
62
  }
63
63
 
64
64
  void LogSettings::saveToFile(){
65
- RHOCONF().setInt("MinSeverity", getMinSeverity() );
66
- RHOCONF().setBool("LogToOutput", isLogToOutput() );
67
- RHOCONF().setBool("LogToFile", isLogToFile() );
65
+ RHOCONF().setInt("MinSeverity", getMinSeverity(), true );
66
+ RHOCONF().setBool("LogToOutput", isLogToOutput(), true );
67
+ RHOCONF().setBool("LogToFile", isLogToFile(), true );
68
68
  #if !defined(OS_MACOSX)
69
- RHOCONF().setString("LogFilePath", getLogFilePath() );
69
+ RHOCONF().setString("LogFilePath", getLogFilePath(), true );
70
70
  #endif
71
- RHOCONF().setInt("MaxLogFileSize", getMaxLogFileSize() );
72
- RHOCONF().setString("LogCategories", getEnabledCategories() );
73
- RHOCONF().setString("ExcludeLogCategories", getDisabledCategories() );
74
-
75
- RHOCONF().saveToFile();
71
+ RHOCONF().setInt("MaxLogFileSize", getMaxLogFileSize(), true );
72
+ RHOCONF().setString("LogCategories", getEnabledCategories(), true );
73
+ RHOCONF().setString("ExcludeLogCategories", getDisabledCategories(), true );
76
74
  }
77
75
 
78
76
  void LogSettings::loadFromConf(rho::common::RhoSettings& oRhoConf){
@@ -162,6 +160,8 @@ void LogSettings::setDisabledCategories( const char* szCatList ){
162
160
  }
163
161
 
164
162
  extern "C" {
163
+ using namespace rho;
164
+ using namespace rho::common;
165
165
 
166
166
  void rho_logconf_Init(const char* szRootPath){
167
167
 
@@ -236,8 +236,7 @@ void rho_logconf_freeString(char* str) {
236
236
  // RhoConf.set_property_by_name
237
237
  void rho_conf_set_property_by_name(char* name, char* value)
238
238
  {
239
- rho_conf_setString(name, value);
240
- rho_conf_save();
239
+ RHOCONF().setString(name, value, true);
241
240
 
242
241
  LOGCONF().loadFromConf(RHOCONF());
243
242
  }
@@ -255,6 +254,24 @@ VALUE rho_conf_get_property_by_name(char* name)
255
254
  return rho_ruby_create_string(szValue);
256
255
  }
257
256
 
257
+ VALUE rho_conf_get_conflicts()
258
+ {
259
+ CHoldRubyValue hashConflicts(rho_ruby_createHash());
260
+
261
+ HashtablePtr<String,Vector<String>* >& mapConflicts = RHOCONF().getConflicts();
262
+ for ( HashtablePtr<String,Vector<String>* >::iterator it=mapConflicts.begin() ; it != mapConflicts.end(); it++ )
263
+ {
264
+ Vector<String>& values = *(it->second);
265
+ CHoldRubyValue arValues(rho_ruby_create_array());
266
+ for( int i = 0; i < (int)values.size(); i++)
267
+ rho_ruby_add_to_array(arValues, rho_ruby_create_string(values.elementAt(i).c_str()) );
268
+
269
+ addHashToHash(hashConflicts, it->first.c_str(), arValues);
270
+ }
271
+
272
+ return hashConflicts;
273
+ }
274
+
258
275
  VALUE rho_conf_read_log(int limit)
259
276
  {
260
277
  VALUE res = rho_ruby_create_string("");