rhodes 3.3.3.beta.4 → 3.3.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (497) hide show
  1. data/CHANGELOG +7 -5
  2. data/CREDITS +2215 -0
  3. data/Rakefile +225 -59
  4. data/bin/c2dm.rb +0 -0
  5. data/bin/get-rhodes-info.bat +0 -0
  6. data/bin/migrate-rhodes-app +0 -0
  7. data/bin/migrate-rhodes-app.bat +0 -0
  8. data/bin/rhodes +0 -0
  9. data/bin/rhodes-setup +0 -0
  10. data/bin/rhodes-setup.bat +0 -0
  11. data/bin/rhogen +0 -0
  12. data/bin/rhogen.bat +0 -0
  13. data/bin/set-rhodes-sdk +0 -0
  14. data/bin/set-rhodes-sdk.bat +0 -0
  15. data/bin/upgrade-rhodes-app +0 -0
  16. data/bin/upgrade-rhodes-app.bat +0 -0
  17. data/doc/build.txt +20 -9
  18. data/doc/configuration.txt +8 -8
  19. data/doc/connect-to-web-services.txt +1 -1
  20. data/doc/device-caps.txt +63 -26
  21. data/doc/extensions.txt +14 -2
  22. data/doc/install.txt +28 -19
  23. data/doc/introduction.txt +6 -3
  24. data/doc/jqt-jqm-transition.txt +10 -9
  25. data/doc/release.txt +5 -1
  26. data/doc/rhodes-command-line.txt +130 -0
  27. data/doc/rhom.txt +16 -11
  28. data/doc/rhostudio-eclipse.txt +3 -3
  29. data/doc/simulator.txt +28 -31
  30. data/doc/syncengine-ajax-api.txt +246 -0
  31. data/doc/synchronization.txt +21 -3
  32. data/doc/test-log-debug.txt +3 -1
  33. data/doc/ui.txt +16 -16
  34. data/ext/extconf.rb +8 -0
  35. data/lib/build/jake.rb +5 -5
  36. data/lib/extensions/barcode/ext/barcode/platform/android/Rakefile +9 -9
  37. data/lib/extensions/barcode/ext/barcode/platform/android/jni/src/barcode.cpp +81 -1
  38. data/lib/extensions/barcode/ext/barcode/platform/android/src/com/google/zxing/client/android/CaptureActivityHandler.java +6 -13
  39. data/lib/extensions/barcode/ext/barcode/platform/android/src/com/google/zxing/client/android/DecodeHandler.java +2 -6
  40. data/lib/extensions/barcode/ext/barcode/platform/android/src/com/rhomobile/barcode/Barcode.java +12 -1
  41. data/lib/extensions/barcode/ext/barcode/platform/bb/run.bat +0 -0
  42. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeCallbackHelper.h +2 -0
  43. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeCallbackHelper.mm +36 -0
  44. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeViewController.h +0 -0
  45. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeViewController.m +15 -5
  46. data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/barcode.m +64 -1
  47. data/lib/extensions/barcode/ext/barcode/shared/ruby/barcode.i +35 -1
  48. data/lib/extensions/barcode/ext/barcode/shared/ruby/barcode_wrap.c +126 -2
  49. data/lib/extensions/barcode/ext/barcode/shared/src/zbar.c +18 -1
  50. data/lib/extensions/barcode/ext/build +0 -0
  51. data/lib/extensions/barcode/ext/build.bat +0 -0
  52. data/lib/extensions/digest-md5/ext/Rakefile +12 -10
  53. data/lib/extensions/digest-md5/ext/build +0 -0
  54. data/lib/extensions/digest-md5/ext/build.bat +0 -0
  55. data/lib/extensions/digest-md5/ext/digest-md5.sln +2 -2
  56. data/lib/extensions/digest-md5/ext/digest-md5.vcproj +41 -28
  57. data/lib/extensions/digest-sha1/ext/Rakefile +11 -10
  58. data/lib/extensions/digest-sha1/ext/build +0 -0
  59. data/lib/extensions/digest-sha1/ext/build.bat +0 -0
  60. data/lib/extensions/digest-sha1/ext/digest-sha1.sln +2 -2
  61. data/lib/extensions/digest-sha1/ext/digest-sha1.vcproj +41 -28
  62. data/lib/extensions/digest/ext/Rakefile +12 -11
  63. data/lib/extensions/digest/ext/build +0 -0
  64. data/lib/extensions/digest/ext/build.bat +0 -0
  65. data/lib/extensions/digest/ext/digest.sln +44 -0
  66. data/lib/extensions/digest/ext/digest.vcproj +40 -27
  67. data/lib/extensions/esri/ext/build +0 -0
  68. data/lib/extensions/esri/ext/build.bat +0 -0
  69. data/lib/extensions/fcntl/ext/Rakefile +10 -9
  70. data/lib/extensions/fcntl/ext/build +0 -0
  71. data/lib/extensions/fcntl/ext/build.bat +0 -0
  72. data/lib/extensions/fcntl/ext/fcntl.vcproj +1 -1
  73. data/lib/extensions/nfc/ext/build +0 -0
  74. data/lib/extensions/nfc/ext/build.bat +0 -0
  75. data/lib/extensions/nfc/ext/nfc/platform/android/Rakefile +11 -11
  76. data/lib/extensions/nfc/ext/nfc/platform/android/jni/src/nfc.cpp +0 -0
  77. data/lib/extensions/nfc/ext/nfc/platform/android/src/com/rhomobile/nfc/Nfc.java +12 -10
  78. data/lib/extensions/nfc/ext/nfc/shared/ruby/nfc_wrap.c +16 -9
  79. data/lib/extensions/pdf-writer/color.rb +145 -0
  80. data/lib/extensions/pdf-writer/color/cmyk.rb +279 -0
  81. data/lib/extensions/pdf-writer/color/css.rb +28 -0
  82. data/lib/extensions/pdf-writer/color/grayscale.rb +212 -0
  83. data/lib/extensions/pdf-writer/color/hsl.rb +221 -0
  84. data/lib/extensions/pdf-writer/color/palette.rb +16 -0
  85. data/lib/extensions/pdf-writer/color/palette/adobecolor.rb +272 -0
  86. data/lib/extensions/pdf-writer/color/palette/gimp.rb +116 -0
  87. data/lib/extensions/pdf-writer/color/palette/monocontrast.rb +180 -0
  88. data/lib/extensions/pdf-writer/color/rgb-colors.rb +355 -0
  89. data/lib/extensions/pdf-writer/color/rgb.rb +453 -0
  90. data/lib/extensions/pdf-writer/color/rgb/metallic.rb +43 -0
  91. data/lib/extensions/pdf-writer/color/yiq.rb +84 -0
  92. data/lib/extensions/pdf-writer/ext/LICENSES/color/Licence.txt +27 -0
  93. data/lib/extensions/pdf-writer/ext/LICENSES/color/README.txt +32 -0
  94. data/lib/extensions/pdf-writer/ext/LICENSES/pdf-writer/LICENCE +131 -0
  95. data/lib/extensions/pdf-writer/ext/LICENSES/pdf-writer/README +33 -0
  96. data/lib/extensions/pdf-writer/ext/LICENSES/transaction-simple/Licence.txt +25 -0
  97. data/lib/extensions/pdf-writer/ext/LICENSES/transaction-simple/Readme.txt +204 -0
  98. data/lib/extensions/pdf-writer/pdf/charts.rb +13 -0
  99. data/lib/extensions/pdf-writer/pdf/charts/stddev.rb +430 -0
  100. data/lib/extensions/pdf-writer/pdf/math.rb +108 -0
  101. data/lib/extensions/pdf-writer/pdf/quickref.rb +332 -0
  102. data/lib/extensions/pdf-writer/pdf/simpletable.rb +947 -0
  103. data/lib/extensions/pdf-writer/pdf/techbook.rb +901 -0
  104. data/lib/extensions/pdf-writer/pdf/writer.rb +2729 -0
  105. data/lib/extensions/pdf-writer/pdf/writer/arc4.rb +63 -0
  106. data/lib/extensions/pdf-writer/pdf/writer/fontmetrics.rb +203 -0
  107. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-Bold.afm +342 -0
  108. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-BoldOblique.afm +342 -0
  109. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-Oblique.afm +342 -0
  110. data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier.afm +342 -0
  111. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-Bold.afm +2827 -0
  112. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-BoldOblique.afm +2827 -0
  113. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-Oblique.afm +3051 -0
  114. data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica.afm +3051 -0
  115. data/lib/extensions/pdf-writer/pdf/writer/fonts/MustRead.html +19 -0
  116. data/lib/extensions/pdf-writer/pdf/writer/fonts/Symbol.afm +213 -0
  117. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Bold.afm +2588 -0
  118. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-BoldItalic.afm +2384 -0
  119. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Italic.afm +2667 -0
  120. data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Roman.afm +2419 -0
  121. data/lib/extensions/pdf-writer/pdf/writer/fonts/ZapfDingbats.afm +225 -0
  122. data/lib/extensions/pdf-writer/pdf/writer/graphics.rb +813 -0
  123. data/lib/extensions/pdf-writer/pdf/writer/graphics/imageinfo.rb +365 -0
  124. data/lib/extensions/pdf-writer/pdf/writer/lang.rb +43 -0
  125. data/lib/extensions/pdf-writer/pdf/writer/lang/en.rb +99 -0
  126. data/lib/extensions/pdf-writer/pdf/writer/object.rb +23 -0
  127. data/lib/extensions/pdf-writer/pdf/writer/object/action.rb +35 -0
  128. data/lib/extensions/pdf-writer/pdf/writer/object/annotation.rb +42 -0
  129. data/lib/extensions/pdf-writer/pdf/writer/object/catalog.rb +39 -0
  130. data/lib/extensions/pdf-writer/pdf/writer/object/contents.rb +65 -0
  131. data/lib/extensions/pdf-writer/pdf/writer/object/destination.rb +40 -0
  132. data/lib/extensions/pdf-writer/pdf/writer/object/encryption.rb +53 -0
  133. data/lib/extensions/pdf-writer/pdf/writer/object/font.rb +72 -0
  134. data/lib/extensions/pdf-writer/pdf/writer/object/fontdescriptor.rb +34 -0
  135. data/lib/extensions/pdf-writer/pdf/writer/object/fontencoding.rb +40 -0
  136. data/lib/extensions/pdf-writer/pdf/writer/object/image.rb +304 -0
  137. data/lib/extensions/pdf-writer/pdf/writer/object/info.rb +51 -0
  138. data/lib/extensions/pdf-writer/pdf/writer/object/outline.rb +30 -0
  139. data/lib/extensions/pdf-writer/pdf/writer/object/outlines.rb +30 -0
  140. data/lib/extensions/pdf-writer/pdf/writer/object/page.rb +195 -0
  141. data/lib/extensions/pdf-writer/pdf/writer/object/pages.rb +115 -0
  142. data/lib/extensions/pdf-writer/pdf/writer/object/procset.rb +46 -0
  143. data/lib/extensions/pdf-writer/pdf/writer/object/viewerpreferences.rb +74 -0
  144. data/lib/extensions/pdf-writer/pdf/writer/ohash.rb +58 -0
  145. data/lib/extensions/pdf-writer/pdf/writer/oreader.rb +25 -0
  146. data/lib/extensions/pdf-writer/pdf/writer/state.rb +48 -0
  147. data/lib/extensions/pdf-writer/pdf/writer/strokestyle.rb +138 -0
  148. data/lib/extensions/pdf-writer/transaction/simple.rb +486 -0
  149. data/lib/extensions/pdf-writer/transaction/simple/group.rb +146 -0
  150. data/lib/extensions/pdf-writer/transaction/simple/threadsafe.rb +68 -0
  151. data/lib/extensions/pdf-writer/transaction/simple/threadsafe/group.rb +36 -0
  152. data/lib/framework/builtinME.rb +0 -0
  153. data/lib/framework/dateOrig.rb +8 -2
  154. data/lib/framework/rational.rb +0 -0
  155. data/lib/framework/res/esri.wm.png +0 -0
  156. data/lib/framework/rho/rho.rb +6 -0
  157. data/lib/framework/rho/rhobluetooth.rb +0 -0
  158. data/lib/framework/rho/rhofsconnector.rb +0 -0
  159. data/lib/framework/rho/rhonativeviewmanager.rb +0 -0
  160. data/lib/framework/rhofsconnector.rb +0 -0
  161. data/lib/framework/rhom/rhom_object_factory.rb +8 -0
  162. data/lib/framework/rhomotoapi.rb +3 -2
  163. data/platform/android/Rhodes/jni/include/rhodes/JNIRhodes.h +9 -1
  164. data/platform/android/Rhodes/jni/include/rhodes/details/rhojava.inc +1 -0
  165. data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_file_RhoFileApi.h +26 -2
  166. data/platform/android/Rhodes/jni/src/callbacks.cpp +0 -5
  167. data/platform/android/Rhodes/jni/src/camera.cpp +1 -1
  168. data/platform/android/Rhodes/jni/src/fileapi.cpp +39 -19
  169. data/platform/android/Rhodes/jni/src/geolocation.cpp +3 -3
  170. data/platform/android/Rhodes/jni/src/mapview.cpp +206 -64
  171. data/platform/android/Rhodes/jni/src/nativeview.cpp +1 -1
  172. data/platform/android/Rhodes/jni/src/rhodes.cpp +13 -0
  173. data/platform/android/Rhodes/jni/src/rhodesapp.cpp +20 -0
  174. data/platform/android/Rhodes/jni/src/rhodessystem.cpp +36 -3
  175. data/platform/android/Rhodes/jni/src/signature.cpp +22 -2
  176. data/platform/android/Rhodes/res/drawable/alert_info.png +0 -0
  177. data/platform/android/Rhodes/res/drawable/esri.png +0 -0
  178. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Capabilities.java +17 -16
  179. data/platform/android/Rhodes/src/com/rhomobile/rhodes/Logger.java +4 -1
  180. data/platform/android/Rhodes/src/com/rhomobile/rhodes/MemoryInfoCollector.java +67 -0
  181. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +139 -114
  182. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +106 -13
  183. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +11 -3
  184. data/platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java +71 -16
  185. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraNewService.java +4 -1
  186. data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraSemiService.java +4 -1
  187. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoExtension.java +22 -1
  188. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/Config.java +243 -0
  189. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtManager.java +19 -1
  190. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtension.java +9 -1
  191. data/platform/android/Rhodes/src/com/rhomobile/rhodes/{RhodesActivityListener.java → extmanager/IRhoListener.java} +16 -12
  192. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManager.java +63 -1
  193. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManagerImpl.java +239 -14
  194. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhodesStartupListeners.java +9 -0
  195. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/WebkitExtension.java +53 -0
  196. data/platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java +27 -12
  197. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocation.java +124 -62
  198. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java +49 -137
  199. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +84 -114
  200. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SplashScreen.java +75 -82
  201. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java +3 -2
  202. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/Callout.java +4 -0
  203. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapBitmapManager.java +124 -0
  204. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java +232 -43
  205. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/Request.java +193 -0
  206. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/IRhoCustomView.java +13 -0
  207. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoNativeViewManager.java +32 -23
  208. data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoVideoView.java +74 -0
  209. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality.java +6 -7
  210. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality01.java +37 -0
  211. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality03.java +14 -1
  212. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality05.java +51 -38
  213. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality07.java +9 -1
  214. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality08.java +48 -31
  215. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionalityManager.java +15 -16
  216. data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/Signature.java +52 -15
  217. data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/LocalFileHandler.java +20 -2
  218. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientOld.java +1 -0
  219. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/GoogleWebView.java +77 -34
  220. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/IRhoWebView.java +9 -0
  221. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebChromeClient.java +105 -0
  222. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebViewClient.java +1 -1
  223. data/platform/android/build/RhodesSRC_build.files +8 -7
  224. data/platform/android/build/android.rake +326 -216
  225. data/platform/android/build/androidcommon.rb +27 -13
  226. data/platform/bb/RubyVM/src/com/rho/file/SimpleFile.java +27 -1
  227. data/platform/bb/RubyVM/src/j2me/io/File.java +104 -38
  228. data/platform/bb/build/bb.rake +1 -0
  229. data/platform/bb/build/runRAPC.bat +0 -0
  230. data/platform/bb/rhodes/resources/background.png +0 -0
  231. data/platform/bb/rhodes/resources/esri.png +0 -0
  232. data/platform/bb/rhodes/resources/mappin.png +0 -0
  233. data/platform/bb/rhodes/src/com/rho/rubyext/System.java +5 -1
  234. data/platform/bb/rhodes/src/rhomobile/PushListeningThread.java +2 -2
  235. data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapField.java +0 -0
  236. data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapProvider.java +0 -0
  237. data/platform/bb/rhodes/src/rhomobile/mapview/GeoCoding.java +0 -0
  238. data/platform/bb/rhodes/src/rhomobile/mapview/GoogleGeoCoding.java +0 -0
  239. data/platform/bb/rhodes/src/rhomobile/mapview/MapTools.java +0 -0
  240. data/platform/iphone/Classes/AppManager/AppManager.m +7 -1
  241. data/platform/iphone/Classes/Camera/PickImageDelegate.h +9 -0
  242. data/platform/iphone/Classes/Camera/PickImageDelegate.m +75 -4
  243. data/platform/iphone/Classes/GeoLocation/LocationController.h +8 -2
  244. data/platform/iphone/Classes/GeoLocation/LocationController.m +74 -76
  245. data/platform/iphone/Classes/InitMemoryInfoCollector.h +33 -0
  246. data/platform/iphone/Classes/InitMemoryInfoCollector.mm +52 -0
  247. data/platform/iphone/Classes/NativeView/NVViewController.h +0 -0
  248. data/platform/iphone/Classes/NativeView/NVViewController.m +34 -2
  249. data/platform/iphone/Classes/Rhodes.m +22 -2
  250. data/platform/iphone/Classes/Signature/SignatureDelegate.m +19 -0
  251. data/platform/iphone/Classes/Signature/SignatureViewController.h +0 -0
  252. data/platform/iphone/Classes/Signature/SignatureViewController.m +0 -0
  253. data/platform/iphone/Classes/SimpleMainView.h +0 -0
  254. data/platform/iphone/Classes/SimpleMainView.m +3 -3
  255. data/platform/iphone/ESRI/BluePushpin.png +0 -0
  256. data/platform/iphone/ESRI/BluePushpin@2x.png +0 -0
  257. data/platform/iphone/ESRI/esri.png +0 -0
  258. data/platform/iphone/ESRI/esri@2x.png +0 -0
  259. data/platform/iphone/rbuild/iphone.rake +75 -7
  260. data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +13 -4
  261. data/platform/linux/target/compiler/rubylinux +0 -0
  262. data/platform/mac/target/compiler/RubyMac +0 -0
  263. data/platform/osx/Rhodes Launcher/rhorunner.app/rhorunner b/data/platform/osx/Rhodes → Launcher/rhorunner.app/rhorunner +0 -0
  264. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtCore.framework/Versions/4/QtCore +0 -0
  265. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtGui.framework/Resources/qt_menu.nib/keyedobjects.nib +0 -0
  266. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtGui.framework/Versions/4/QtGui +0 -0
  267. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtNetwork.framework/Versions/4/QtNetwork +0 -0
  268. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtWebKit.framework/Versions/4/QtWebKit +0 -0
  269. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Info.plist +1 -1
  270. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/MacOS/RhoSimulator +0 -0
  271. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/accessible/libqtaccessiblewidgets.dylib +0 -0
  272. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqcorewlanbearer.dylib +0 -0
  273. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqgenericbearer.dylib +0 -0
  274. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqcncodecs.dylib +0 -0
  275. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqjpcodecs.dylib +0 -0
  276. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqkrcodecs.dylib +0 -0
  277. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqtwcodecs.dylib +0 -0
  278. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/graphicssystems/libqtracegraphicssystem.dylib +0 -0
  279. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqgif.dylib +0 -0
  280. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqico.dylib +0 -0
  281. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqjpeg.dylib +0 -0
  282. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqmng.dylib +0 -0
  283. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtga.dylib +0 -0
  284. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtiff.dylib +0 -0
  285. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_inspector.dylib +0 -0
  286. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_tcp.dylib +0 -0
  287. data/platform/osx/build/osx.rake +6 -8
  288. data/platform/shared/RhoConnectClient/RhoConnectClient.cpp +165 -33
  289. data/platform/shared/RhoConnectClient/RhoConnectClient.h +10 -1
  290. data/platform/shared/common/BundleManager.cpp +27 -16
  291. data/platform/shared/common/ExtManager.h +15 -2
  292. data/platform/shared/common/RhoConf.cpp +17 -2
  293. data/platform/shared/common/RhoConf.h +3 -1
  294. data/platform/shared/common/RhoDefs.h +6 -6
  295. data/platform/shared/common/RhoFatalError.h +1 -1
  296. data/platform/shared/common/RhoFile.cpp +9 -9
  297. data/platform/shared/common/RhoFilePath.h +7 -3
  298. data/platform/shared/common/RhoPort.h +3 -3
  299. data/platform/shared/common/RhoSystem.h +1 -1
  300. data/platform/shared/common/RhodesApp.cpp +426 -26
  301. data/platform/shared/common/RhodesApp.h +11 -3
  302. data/platform/shared/common/RhodesAppBase.cpp +4 -1
  303. data/platform/shared/common/StringConverter.h +3 -3
  304. data/platform/shared/common/app_build_capabilities.h +8 -0
  305. data/platform/shared/common/map/BaseMapEngine.cpp +302 -21
  306. data/platform/shared/common/map/BaseMapEngine.h +132 -6
  307. data/platform/shared/common/map/ESRIMapEngine.cpp +2 -1
  308. data/platform/shared/common/map/GeocodingMapEngine.cpp +22 -4
  309. data/platform/shared/common/map/GeocodingMapEngine.h +40 -0
  310. data/platform/shared/common/map/GoogleMapEngine.cpp +13 -1
  311. data/platform/shared/common/map/MapEngine.h +7 -0
  312. data/platform/shared/common/map/OSMMapEngine.cpp +12 -1
  313. data/platform/shared/json/JSONIterator.cpp +1 -1
  314. data/platform/shared/json/RJSONTokener.c +2 -0
  315. data/platform/shared/json/config.h +3 -3
  316. data/platform/shared/logging/RhoLog.cpp +12 -3
  317. data/platform/shared/logging/RhoLog.h +2 -1
  318. data/platform/shared/logging/RhoLogConf.cpp +147 -11
  319. data/platform/shared/logging/RhoLogConf.h +39 -1
  320. data/platform/shared/logging/RhoLogSink.cpp +1 -1
  321. data/platform/shared/net/HttpServer.cpp +8 -4
  322. data/platform/shared/net/INetRequest.cpp +7 -0
  323. data/platform/shared/net/INetRequest.h +2 -0
  324. data/platform/shared/net/RawSocket.cpp +1 -1
  325. data/platform/shared/qt/pbxproj2pro.pl +0 -0
  326. data/platform/shared/qt/pro_vcproj_diff.pl +0 -0
  327. data/platform/shared/qt/rhodes/QtMainWindow.cpp +1 -1
  328. data/platform/shared/qt/rhodes/impl/RhoClassFactoryImpl.h +2 -2
  329. data/platform/shared/qt/rhodes/impl/RhoThreadImpl.cpp +2 -2
  330. data/platform/shared/qt/rhodes/impl/SystemImpl.cpp +11 -1
  331. data/platform/shared/qt/rhodes/main.cpp +5 -5
  332. data/platform/shared/ruby/ext/alert/alert_wrap.c +8 -8
  333. data/platform/shared/ruby/ext/bluetooth/bluetooth.i +0 -0
  334. data/platform/shared/ruby/ext/bluetooth/bluetooth_wrap.c +16 -9
  335. data/platform/shared/ruby/ext/camera/camera.i +2 -2
  336. data/platform/shared/ruby/ext/camera/camera_wrap.c +18 -3
  337. data/platform/shared/ruby/ext/datetimepicker/datetimepicker_wrap.c +37 -8
  338. data/platform/shared/ruby/ext/geolocation/geolocation_wrap.c +8 -8
  339. data/platform/shared/ruby/ext/mapview/mapview_wrap.c +16 -9
  340. data/platform/shared/ruby/ext/nativebar/nativebar_wrap.c +16 -9
  341. data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager.i +0 -0
  342. data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager_wrap.c +16 -9
  343. data/platform/shared/ruby/ext/phonebook/phonebook_wrap.c +8 -1
  344. data/platform/shared/ruby/ext/rho/rhoruby.c +7 -1
  345. data/platform/shared/ruby/ext/rho/rhoruby.h +1 -0
  346. data/platform/shared/ruby/ext/rhoconf/rhoconf_wrap.c +16 -9
  347. data/platform/shared/ruby/ext/signature/signature.i +0 -0
  348. data/platform/shared/ruby/ext/signature/signature_wrap.c +9 -9
  349. data/platform/shared/ruby/ext/syncengine/syncengine_wrap.c +16 -9
  350. data/platform/shared/ruby/ext/system/system_wrap.c +16 -9
  351. data/platform/shared/ruby/ext/webview/webview_wrap.c +16 -9
  352. data/platform/shared/ruby/gc.c +1 -0
  353. data/platform/shared/ruby/regint.h +6 -4
  354. data/platform/shared/ruby/vm.c +1 -0
  355. data/platform/shared/ruby/wince/wince.h +1 -1
  356. data/platform/shared/rubyext/System.cpp +1 -1
  357. data/platform/shared/shttpd/src/rdispatcher.c +3 -3
  358. data/platform/shared/shttpd/src/std_includes.h +1 -1
  359. data/platform/shared/sqlite/sqlite3.c +1 -0
  360. data/platform/shared/statistic/test/TestProfiling.cpp +1 -1
  361. data/platform/shared/stlport/build/lib/configure +0 -0
  362. data/platform/shared/stlport/build/lib/configure.bat +0 -0
  363. data/platform/shared/sync/SyncEngine.cpp +9 -12
  364. data/platform/shared/sync/SyncNotify.cpp +36 -3
  365. data/platform/shared/sync/SyncNotify.h +11 -4
  366. data/platform/shared/sync/SyncSource.cpp +32 -16
  367. data/platform/shared/sync/SyncSource.h +2 -3
  368. data/platform/shared/sync/SyncThread.cpp +13 -4
  369. data/platform/shared/sync/SyncThread.h +4 -0
  370. data/platform/shared/tcmalloc/page_heap.h +1 -1
  371. data/platform/shared/tcmalloc/rhomem.h +1 -1
  372. data/platform/shared/tcmalloc/windows/port.cpp +12 -3
  373. data/platform/shared/test/Tests.cpp +4 -4
  374. data/platform/shared/test/test_helper.cpp +4 -4
  375. data/platform/symbian/sqlite3/src/sqlite3.h +1 -1
  376. data/platform/win32/RhoSimulator/Microsoft.VC90.CRT.manifest +6 -0
  377. data/platform/win32/RhoSimulator/Microsoft.VC90.OpenMP.manifest +6 -0
  378. data/platform/win32/RhoSimulator/QtCore4.dll +0 -0
  379. data/platform/win32/RhoSimulator/QtGui4.dll +0 -0
  380. data/platform/win32/RhoSimulator/QtNetwork4.dll +0 -0
  381. data/platform/win32/RhoSimulator/QtWebKit4.dll +0 -0
  382. data/platform/win32/RhoSimulator/RhoSimulator.exe +0 -0
  383. data/platform/win32/RhoSimulator/imageformats/qgif4.dll +0 -0
  384. data/platform/win32/RhoSimulator/imageformats/qico4.dll +0 -0
  385. data/platform/win32/RhoSimulator/imageformats/qjpeg4.dll +0 -0
  386. data/platform/win32/RhoSimulator/imageformats/qmng4.dll +0 -0
  387. data/platform/win32/RhoSimulator/imageformats/qsvg4.dll +0 -0
  388. data/platform/win32/RhoSimulator/imageformats/qtiff4.dll +0 -0
  389. data/platform/win32/RhoSimulator/libeay32.dll +0 -0
  390. data/platform/win32/RhoSimulator/msvcm90.dll +0 -0
  391. data/platform/win32/RhoSimulator/msvcp90.dll +0 -0
  392. data/platform/win32/RhoSimulator/msvcr90.dll +0 -0
  393. data/platform/win32/RhoSimulator/phonon4.dll +0 -0
  394. data/platform/win32/RhoSimulator/ssleay32.dll +0 -0
  395. data/platform/win32/RhoSimulator/vcomp90.dll +0 -0
  396. data/platform/win32/target/replaceicon/replaceicon.exe +0 -0
  397. data/platform/win32/target/updateresstring/updateresstring.exe +0 -0
  398. data/platform/wm/RhoLib/RhoLib.vcproj +394 -69
  399. data/platform/wm/build/build_inf.js +83 -23
  400. data/platform/wm/build/wm.rake +127 -81
  401. data/platform/wm/rhodes.sln +6 -6
  402. data/platform/wm/rhodes/DateTimePicker.h +2 -2
  403. data/platform/wm/rhodes/IBrowserEngine.h +3 -0
  404. data/platform/wm/rhodes/IEBrowserEngine.cpp +34 -2
  405. data/platform/wm/rhodes/IEBrowserEngine.h +4 -1
  406. data/platform/wm/rhodes/LicenseStub.cpp +73 -0
  407. data/platform/{android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientNew.java → wm/rhodes/LogMemory.cpp} +32 -20
  408. data/platform/{android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettings.java → wm/rhodes/LogMemory.h} +11 -8
  409. data/platform/wm/rhodes/LogOptionsDlg.h +1 -1
  410. data/platform/wm/rhodes/LogView.cpp +10 -10
  411. data/platform/wm/rhodes/LogView.h +10 -10
  412. data/platform/wm/rhodes/MainWindow.cpp +431 -173
  413. data/platform/wm/rhodes/MainWindow.h +37 -19
  414. data/platform/wm/rhodes/MapView/MapViewManager.h +1 -1
  415. data/platform/wm/rhodes/OkCancelModalDialog.h +1 -1
  416. data/platform/wm/rhodes/Rhodes.cpp +210 -47
  417. data/platform/wm/rhodes/Rhodes.rc +38 -0
  418. data/platform/wm/rhodes/bluetooth/Bluetooth.cpp +2 -2
  419. data/platform/wm/rhodes/bluetooth/Bluetooth.h +3 -3
  420. data/platform/wm/rhodes/camera/Camera.cpp +2 -1
  421. data/platform/wm/rhodes/camera/Camera.h +1 -1
  422. data/platform/wm/rhodes/resource.h +1 -1
  423. data/platform/wm/rhodes/rho/common/ExtManager.cpp +93 -5
  424. data/platform/wm/rhodes/rho/net/NetRequestImpl.cpp +2 -2
  425. data/platform/wm/rhodes/rho/rubyext/NativeToolbar.cpp +2 -2
  426. data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +13 -7
  427. data/platform/wm/rhodes/rhodes.vcproj +1409 -1008
  428. data/platform/wm/rhodes/simulator/MainWindowQt.h +1 -1
  429. data/platform/wm/rhodes/stdafx.h +2 -2
  430. data/platform/wm/rhoelements.sln +7 -9
  431. data/platform/wm/rubylib/rubylib.vcproj +62 -1
  432. data/platform/wm/sqlite3/sqlite3.vcproj +62 -1
  433. data/platform/wm/syncengine/syncengine.vcproj +62 -1
  434. data/platform/wm/tcmalloc/tcmalloc.vcproj +72 -53
  435. data/platform/wm/tools/detool/detool.cpp +1435 -1357
  436. data/platform/wp7/RhoRubyExtGen/GenerateInitializers.cmd +0 -0
  437. data/platform/wp7/RhoRubyLib/common/RhoLicense.cs +105 -0
  438. data/platform/wp7/RhoRubyLib/common/RhodesApp.cs +23 -5
  439. data/platform/wp7/RhoRubyLib/sync/SyncNotify.cs +5 -0
  440. data/platform/wp7/RhoRubyLib/views/RhoView.xaml.cs +22 -3
  441. data/platform/wp7/build/wp.rake +1 -0
  442. data/platform/wp7/rhodes/MainPage.xaml.cs +11 -0
  443. data/rakefile.rb +225 -59
  444. data/res/build-tools/7za.exe +0 -0
  445. data/res/build-tools/RhoAppRunner.exe +0 -0
  446. data/res/build-tools/RhoLogServer.exe +0 -0
  447. data/res/build-tools/RhoRuby.exe +0 -0
  448. data/res/build-tools/RubyMac +0 -0
  449. data/res/build-tools/detool.exe +0 -0
  450. data/res/build-tools/iphonesim/Source/iPhoneSimulator.m +1 -1
  451. data/res/build-tools/iphonesim/build/Release/iphonesim +0 -0
  452. data/res/build-tools/iphonesim/build/Release/iphonesim_43 +0 -0
  453. data/res/build-tools/license_rc.dll +0 -0
  454. data/res/build-tools/make.exe +0 -0
  455. data/res/build-tools/rubylinux +0 -0
  456. data/res/build-tools/swig_patch/Lib/typemaps/fragments.swg +235 -0
  457. data/res/build-tools/wmdc_connect.exe +0 -0
  458. data/res/build-tools/wp7explorer.exe +0 -0
  459. data/res/generators/rhogen.rb +2 -2
  460. data/res/generators/templates/application/app/Settings/controller.rb +1 -1
  461. data/res/generators/templates/application/app/layout.erb +1 -1
  462. data/res/generators/templates/application/app/loading.png +0 -0
  463. data/res/generators/templates/application/public/css/re_webkit.css +736 -0
  464. data/res/generators/templates/application/public/css/windows_mobile.css +0 -0
  465. data/res/generators/templates/application/public/images/listArrow.png +0 -0
  466. data/res/generators/templates/application/public/jqmobile/images/ajax-loader.png +0 -0
  467. data/res/generators/templates/application/public/jqmobile/images/icons-18-black.png +0 -0
  468. data/res/generators/templates/application/public/jqmobile/images/icons-18-white.png +0 -0
  469. data/res/generators/templates/application/public/jqmobile/images/icons-36-black.png +0 -0
  470. data/res/generators/templates/application/public/jqmobile/images/icons-36-white.png +0 -0
  471. data/res/generators/templates/application/public/js/syncengine.js +409 -52
  472. data/res/generators/templates/extension/extensions/montana/ext/build +0 -0
  473. data/res/generators/templates/extension/extensions/montana/ext/build.bat +0 -0
  474. data/res/generators/templates/extension/extensions/montana/ext/montana/platform/android/Rakefile +10 -10
  475. data/res/generators/templates/spec/app/SpecRunner/controller.rb +2 -0
  476. data/res/libs/motorolalicence/android/MotorolaLicence.h +13 -0
  477. data/res/libs/motorolalicence/android/libMotorolaLicence.a +0 -0
  478. data/res/libs/motorolalicence/iphone/MotorolaLicence.h +13 -0
  479. data/res/libs/motorolalicence/iphone/libMotorolaLicence.a +0 -0
  480. data/rhodes.gemspec +1 -1
  481. data/spec/framework_spec/app/SpecRunner/controller.rb +2 -0
  482. data/spec/phone_spec/app/SpecRunner/controller.rb +2 -0
  483. data/version +1 -1
  484. metadata +487 -412
  485. data/Manifest.txt +0 -7960
  486. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivityStartupListeners.java +0 -12
  487. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsNew.java +0 -52
  488. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsOld.java +0 -62
  489. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/phonon.framework/Versions/4/phonon +0 -0
  490. data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/phonon_backend/libphonon_qt7.dylib +0 -0
  491. data/platform/win32/RhoSimulator/Microsoft.VC80.CRT.manifest +0 -8
  492. data/platform/win32/RhoSimulator/Microsoft.VC80.OpenMP.manifest +0 -7
  493. data/platform/win32/RhoSimulator/msvcm80.dll +0 -0
  494. data/platform/win32/RhoSimulator/msvcp80.dll +0 -0
  495. data/platform/win32/RhoSimulator/msvcr80.dll +0 -0
  496. data/platform/win32/RhoSimulator/vcomp.dll +0 -0
  497. data/rhomobile-debug-1.0.6.gem +0 -0
@@ -59,19 +59,24 @@ typedef struct _RHO_CONNECT_NOTIFY
59
59
  char* source_name;
60
60
  char* status;
61
61
  char* sync_type;
62
+ char* bulk_status;
63
+ char* partition;
62
64
  int error_code;
63
65
  char* error_message;
64
66
  char* callback_params;
65
- unsigned long create_errors;
67
+
68
+ unsigned long create_errors_messages;
66
69
 
67
70
  unsigned long update_errors_obj;
68
71
  unsigned long update_errors_attrs;
72
+ unsigned long update_errors_messages;
69
73
 
70
74
  unsigned long update_rollback_obj;
71
75
  unsigned long update_rollback_attrs;
72
76
 
73
77
  unsigned long delete_errors_obj;
74
78
  unsigned long delete_errors_attrs;
79
+ unsigned long delete_errors_messages;
75
80
 
76
81
  }RHO_CONNECT_NOTIFY;
77
82
 
@@ -93,6 +98,8 @@ void rho_connectclient_initmodel(RHOM_MODEL* model);
93
98
  void rho_connectclient_destroymodel(RHOM_MODEL* model);
94
99
 
95
100
  void rho_connectclient_init(RHOM_MODEL* pModels, int nModels);
101
+ void rho_connectclient_updatemodels(RHOM_MODEL* pModels, int nModels);
102
+
96
103
  void rho_connectclient_destroy();
97
104
  void rho_connectclient_database_client_reset();
98
105
  void rho_connectclient_database_full_reset_and_logout();
@@ -123,6 +130,7 @@ unsigned long rho_connectclient_find_all(const char* szModel, unsigned long hash
123
130
  unsigned long rho_connectclient_findbysql(const char* szModel, const char* szSql, unsigned long arParams );
124
131
 
125
132
  int rho_connectclient_is_changed(const char* szModel);
133
+ void rho_connectclient_set_synctype(const char* szModel, RHOM_SYNC_TYPE sync_type);
126
134
 
127
135
  void rho_connectclient_save( const char* szModel, unsigned long hash );
128
136
  void rho_connectclient_itemdestroy( const char* szModel, unsigned long hash );
@@ -141,6 +149,7 @@ void rho_connectclient_stop_bulkupdate(const char* szModel);
141
149
  void rho_connectclient_on_sync_create_error(const char* szModel, RHO_CONNECT_NOTIFY* oNotify, const char* szAction );
142
150
  void rho_connectclient_on_sync_update_error(const char* szModel, RHO_CONNECT_NOTIFY* oNotify, const char* szAction );
143
151
  void rho_connectclient_on_sync_delete_error(const char* szModel, RHO_CONNECT_NOTIFY* oNotify, const char* szAction );
152
+ void rho_connectclient_push_changes(const char* szModel );
144
153
 
145
154
  #ifdef __cplusplus
146
155
  };
@@ -36,19 +36,12 @@ using namespace rho;
36
36
  using namespace rho::common;
37
37
  extern "C" void rho_sys_app_exit();
38
38
  extern "C" void rho_sys_impl_exit_with_errormessage(const char* szTitle, const char* szMsg);
39
- extern "C" void rho_sys_impl_before_exit();
40
39
 
41
- #if !defined(OS_WINDOWS) && !defined(OS_WINCE) && !defined(OS_MACOSX)
40
+ #if !defined(OS_WINDOWS_DESKTOP) && !defined(OS_WINCE) && !defined(OS_MACOSX)
42
41
  void rho_sys_impl_exit_with_errormessage(const char* szTitle, const char* szMsg)
43
42
  {
44
43
  }
45
44
  #endif
46
- #if !defined(OS_ANDROID)
47
- extern "C"
48
- void rho_sys_impl_before_exit()
49
- {
50
- }
51
- #endif
52
45
 
53
46
  namespace rho {
54
47
  namespace common {
@@ -58,8 +51,9 @@ class CFileTransaction
58
51
  unsigned int m_nError;
59
52
  String m_strError;
60
53
  String m_strFolder;
54
+ boolean m_bRollbackInDestr;
61
55
  public:
62
- CFileTransaction(const String& strFolder);
56
+ CFileTransaction(const String& strFolder, boolean bRollbackInDestr = true);
63
57
  ~CFileTransaction();
64
58
  unsigned int start();
65
59
  void commit();
@@ -77,8 +71,6 @@ class CReplaceBundleThread : public rho::common::CRhoThread
77
71
 
78
72
  String m_bundle_path;
79
73
 
80
- unsigned int removeFilesByList( const String& strListPath, const String& strSrcFolder );
81
- unsigned int moveFilesByList( const String& strListPath, const String& strSrcFolder, const String& strDstFolder );
82
74
  void doReplaceBundle();
83
75
  public:
84
76
 
@@ -93,10 +85,13 @@ public:
93
85
  virtual void run();
94
86
 
95
87
  static void showError(int nError, const String& strError );
88
+
89
+ static unsigned int removeFilesByList( const String& strListPath, const String& strSrcFolder );
90
+ static unsigned int moveFilesByList( const String& strListPath, const String& strSrcFolder, const String& strDstFolder );
96
91
  };
97
92
  IMPLEMENT_LOGCLASS(CReplaceBundleThread,"RhoBundle");
98
93
 
99
- CFileTransaction::CFileTransaction(const String& strFolder) : m_strFolder(strFolder)
94
+ CFileTransaction::CFileTransaction(const String& strFolder, boolean bRollbackInDestr) : m_strFolder(strFolder), m_bRollbackInDestr(bRollbackInDestr)
100
95
  {
101
96
  }
102
97
 
@@ -132,7 +127,8 @@ unsigned int CFileTransaction::start()
132
127
 
133
128
  CFileTransaction::~CFileTransaction()
134
129
  {
135
- rollback();
130
+ if (m_bRollbackInDestr)
131
+ rollback();
136
132
  }
137
133
 
138
134
  void CFileTransaction::commit()
@@ -201,12 +197,13 @@ unsigned int CFileTransaction::rollback()
201
197
 
202
198
  unsigned int CReplaceBundleThread::removeFilesByList( const String& strListPath, const String& strSrcFolder )
203
199
  {
204
- LOG(TRACE) + "Removing files by list: " + strSrcFolder;
200
+ LOG(TRACE) + "Removing files by list: " + strSrcFolder + ", list: " + strListPath;
205
201
 
206
202
  unsigned int nError = 0;
207
203
  String strList;
208
204
  CRhoFile::loadTextFile(strListPath.c_str(), strList);
209
205
 
206
+
210
207
  CTokenizer oTokenizer( strList, "\n" );
211
208
  while (oTokenizer.hasMoreTokens())
212
209
  {
@@ -331,7 +328,11 @@ void CReplaceBundleThread::doReplaceBundle()
331
328
 
332
329
  #ifdef OS_ANDROID
333
330
  //rho_file_patch_stat_table(CFilePath::join(m_bundle_path, "RhoBundle/apps/rhofilelist.txt"))
334
- CRhoFile::copyFile(CFilePath::join(m_bundle_path, "RhoBundle/rho.dat").c_str(), RHODESAPP().getRhoRootPath().c_str());
331
+ if (CRhoFile::copyFile(CFilePath::join(m_bundle_path, "RhoBundle/rho.dat").c_str(), CFilePath::join(RHODESAPP().getRhoRootPath().c_str(), "rho.dat").c_str()))
332
+ {
333
+ int err = errno;
334
+ LOG(ERROR) + "Cannot copy rho.dat, errno: " + LOGFMT("%d") + err;
335
+ }
335
336
  #endif
336
337
 
337
338
 
@@ -352,7 +353,7 @@ void rho_sys_replace_current_bundle(const char* path)
352
353
 
353
354
  int rho_sys_check_rollback_bundle(const char* szRhoPath)
354
355
  {
355
- CFileTransaction oFT( CFilePath::join(szRhoPath, "apps") );
356
+ CFileTransaction oFT( CFilePath::join(szRhoPath, "apps"), false );
356
357
  return oFT.rollback() != 0 ? 0 : 1;
357
358
  }
358
359
 
@@ -361,6 +362,16 @@ int rho_sys_delete_folder(const char* szRhoPath)
361
362
  return CRhoFile::deleteFolder(szRhoPath);
362
363
  }
363
364
 
365
+ int rho_sysimpl_remove_bundle_files(const char* path, const char* fileListName)
366
+ {
367
+ unsigned int nError = CReplaceBundleThread::removeFilesByList(CFilePath::join(path, fileListName), path);
368
+ if ( nError != 0 )
369
+ {
370
+ CReplaceBundleThread::showError(nError, String("Remove of bundle files is failed: ") += path);
371
+ }
372
+ return nError;
373
+ }
374
+
364
375
  } //extern "C"
365
376
 
366
377
 
@@ -56,12 +56,17 @@ struct IRhoExtension
56
56
  virtual long OnNavigateTimeout(const wchar_t* szUrlBeingNavigatedTo, const CRhoExtData& oExtData){return 0;}
57
57
  virtual long OnSIPState(bool bSIPState, const CRhoExtData& oExtData){return 0;}
58
58
  virtual long OnAlertPopup(int nEnum, void* pData, const CRhoExtData& oExtData){return 0;}
59
+ virtual long OnAuthenticationRequest(int nEnum, void* pData, const CRhoExtData& oExtData){return 0;}
60
+ virtual long OnGeolocationData(int nEnum, void* pData, const CRhoExtData& oExtData){return 0;}
59
61
  virtual long OnNavigateError(const wchar_t* szUrlBeingNavigatedTo, const CRhoExtData& oExtData){return 0;}
60
62
  virtual void OnAppActivate(bool bActivate, const CRhoExtData& oExtData){}
63
+ virtual void OnWindowChanged(LPVOID lparam){}
61
64
  };
62
65
 
63
66
  struct IRhoExtManager
64
67
  {
68
+ enum ELogExtLevels { eLogError = 0, eLogWarning, eLogInfo, eLogUser, eLogDebug, eLogLevelsCount };
69
+
65
70
  virtual ~IRhoExtManager(){}
66
71
 
67
72
  virtual void onUnhandledProperty( const wchar_t* pModuleName, const wchar_t* pName, const wchar_t* pValue, const CRhoExtData& oExtData ) = 0;
@@ -75,7 +80,7 @@ struct IRhoExtManager
75
80
  virtual bool existsJavascript(const wchar_t* szJSFunction) = 0;
76
81
  virtual void executeJavascript(const wchar_t* szJSFunction) = 0;
77
82
 
78
- virtual void rhoLog(int nSeverity, const char* szModule, const char* szMsg, const char* szFile, int nLine) = 0;
83
+ virtual void rhoLog(ELogExtLevels eLogLevel, const char* szModule, const char* szMsg, const char* szFile, int nLine) = 0;
79
84
  virtual StringW getCurrentUrl() = 0;
80
85
  virtual void stopNavigate() = 0;
81
86
  virtual void historyForward() = 0;
@@ -91,6 +96,9 @@ struct IRhoExtManager
91
96
  virtual StringW getPageTitle(UINT iTab) = 0;
92
97
 
93
98
  virtual StringW getConfigPath() = 0;
99
+
100
+ virtual void setBrowserGesturing(bool bEnableGesturing) = 0;
101
+ virtual void passSipPositionToEngine() = 0;
94
102
  };
95
103
 
96
104
  class CExtManager : public IRhoExtManager
@@ -112,8 +120,11 @@ public:
112
120
  long OnNavigateTimeout(const wchar_t* szUrlBeingNavigatedTo);
113
121
  long OnSIPState(bool bSIPState);
114
122
  long OnAlertPopup(int nEnum, void* pData);
123
+ long OnAuthenticationRequest(int nEnum, void* pData);
124
+ long OnGeolocationData(int nEnum, void* pData);
115
125
  long OnNavigateError(const wchar_t* szUrlBeingNavigatedTo);
116
126
  void OnAppActivate(bool bActivate);
127
+ void OnWindowChanged(LPVOID lparam);
117
128
 
118
129
  CRhoExtData makeExtData();
119
130
  void close();
@@ -129,7 +140,7 @@ public:
129
140
 
130
141
  virtual void executeJavascript(const wchar_t* szJSFunction);
131
142
  virtual bool existsJavascript(const wchar_t* szJSFunction);
132
- virtual void rhoLog(int nSeverity, const char* szModule, const char* szMsg, const char* szFile, int nLine);
143
+ virtual void rhoLog(ELogExtLevels eLogLevel, const char* szModule, const char* szMsg, const char* szFile, int nLine);
133
144
  virtual StringW getCurrentUrl();
134
145
  virtual void stopNavigate();
135
146
  virtual void historyForward();
@@ -144,6 +155,8 @@ public:
144
155
  virtual int getTextZoom(); //Enum (0 to 4)
145
156
  virtual StringW getPageTitle(UINT iTab);
146
157
  virtual StringW getConfigPath();
158
+ virtual void setBrowserGesturing(bool bEnableGesturing);
159
+ virtual void passSipPositionToEngine();
147
160
  };
148
161
 
149
162
  } //namespace common
@@ -42,9 +42,12 @@ namespace common{
42
42
 
43
43
  RhoSettings g_RhoSettings;
44
44
 
45
- void RhoSettings::saveToFile(const char* szName)
45
+ void RhoSettings::saveToFile(const char* szName, boolean bRemove/* = false*/)
46
46
  {
47
- m_mapChangedValues.put(szName, getString(szName) );
47
+ if ( !bRemove )
48
+ m_mapChangedValues.put(szName, getString(szName) );
49
+ else
50
+ m_mapChangedValues.remove(szName);
48
51
 
49
52
  String strData;
50
53
  saveChangesToString(strData);
@@ -253,6 +256,13 @@ bool RhoSettings::isExist(const char* szName){
253
256
  return it != m_mapValues.end();
254
257
  }
255
258
 
259
+ void RhoSettings::removeProperty(const char* szName, boolean bSaveToFile)
260
+ {
261
+ m_mapValues.remove(szName);
262
+ if ( bSaveToFile )
263
+ saveToFile( szName, true );
264
+ }
265
+
256
266
  }
257
267
  }
258
268
 
@@ -307,6 +317,11 @@ int rho_conf_is_property_exists(const char* name)
307
317
  return RHOCONF().isExist(name) ? 1 : 0;
308
318
  }
309
319
 
320
+ void rho_conf_remove_property(const char* name)
321
+ {
322
+ RHOCONF().removeProperty(name, true);
323
+ }
324
+
310
325
  void rho_conf_freeString(char* str) {
311
326
  if ( str )
312
327
  free(str);
@@ -55,6 +55,7 @@ public:
55
55
  void setBool(const char* szName, bool bVal, boolean bSaveToFile);
56
56
 
57
57
  bool isExist(const char* szName);
58
+ void removeProperty(const char* szName, boolean bSaveToFile);
58
59
 
59
60
  const String& getConfFilePath()const{ return m_strConfFilePath;}
60
61
  void setConfFilePath(const char* szConfFilePath){ m_strConfFilePath = szConfFilePath; }
@@ -76,7 +77,7 @@ protected:
76
77
  void setPropertyByName(const char* szName, int nNameLen, const char* szValue, int nValueLen, Hashtable<String,String>& mapValues );
77
78
  void loadProperty( const char* start, int len, Hashtable<String,String>& mapValues );
78
79
 
79
- void saveToFile(const char* szName);
80
+ void saveToFile(const char* szName, boolean bRemove = false );
80
81
  void readChanges();
81
82
  void checkConflicts();
82
83
  };
@@ -106,6 +107,7 @@ void rho_conf_freeString(char* str);
106
107
  void rho_conf_setString(const char* szName, const char* value);
107
108
  //void rho_conf_save();
108
109
  int rho_conf_is_property_exists(const char* name);
110
+ void rho_conf_remove_property(const char* name);
109
111
 
110
112
  #ifdef __cplusplus
111
113
  }
@@ -34,7 +34,7 @@
34
34
  #elif defined(_WIN32_WCE)
35
35
  # define OS_WINCE _WIN32_WINCE
36
36
  #elif defined(WIN32)
37
- # define OS_WINDOWS
37
+ # define OS_WINDOWS_DESKTOP
38
38
  #elif defined(__CYGWIN__) || defined(__CYGWIN32__)
39
39
  # define OS_CYGWIN
40
40
  #elif defined(linux) || defined(__linux) || defined(__linux__)
@@ -46,7 +46,7 @@
46
46
  #else
47
47
  #endif
48
48
 
49
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
49
+ #if defined(OS_WINDOWS_DESKTOP) || defined(OS_WINCE)
50
50
  #define WINDOWS_PLATFORM
51
51
  #endif
52
52
 
@@ -97,7 +97,7 @@
97
97
 
98
98
  typedef int LogSeverity;
99
99
 
100
- #if defined( OS_WINDOWS ) || defined( OS_WINCE )
100
+ #if defined( WINDOWS_PLATFORM )
101
101
  #ifndef _CRT_SECURE_NO_WARNINGS
102
102
  #define _CRT_SECURE_NO_WARNINGS 1
103
103
  #endif //_CRT_SECURE_NO_WARNINGS
@@ -116,9 +116,9 @@ typedef int LogSeverity;
116
116
 
117
117
  #endif
118
118
 
119
- #if !defined(OS_ANDROID)
120
- #include "tcmalloc/rhomem.h"
121
- #endif
119
+ //#if !defined(OS_ANDROID)
120
+ //#include "tcmalloc/rhomem.h"
121
+ //#endif
122
122
 
123
123
  #ifdef RHODES_EMULATOR
124
124
  #define RHO_RB_EXT ".rb"
@@ -41,7 +41,7 @@ public:
41
41
  static void processFatalError(){
42
42
  #ifdef RHO_DEBUG
43
43
 
44
- #if defined (OS_WINDOWS)
44
+ #if defined (OS_WINDOWS_DESKTOP)
45
45
  //__debugbreak();
46
46
  DebugBreak();
47
47
  #elif defined (OS_WINCE)
@@ -49,7 +49,7 @@
49
49
 
50
50
  #if defined(OS_WINCE)
51
51
  extern "C" int _rename(const char *, const char *);
52
- #elif defined(OS_WINDOWS)
52
+ #elif defined(OS_WINDOWS_DESKTOP)
53
53
  extern "C" int rename(const char *, const char *);
54
54
  #endif
55
55
 
@@ -360,7 +360,7 @@ void CRhoFile::loadTextFile(const char* szFilePath, String& strFile)
360
360
  }
361
361
 
362
362
  unsigned int CRhoFile::deleteFile( const char* szFilePath ){
363
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
363
+ #if defined(WINDOWS_PLATFORM)
364
364
  return (unsigned int)_unlink(szFilePath);
365
365
  #else
366
366
  return (unsigned int)remove(szFilePath);
@@ -368,7 +368,7 @@ unsigned int CRhoFile::deleteFile( const char* szFilePath ){
368
368
  }
369
369
 
370
370
  unsigned int CRhoFile::deleteEmptyFolder( const char* szFilePath ){
371
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
371
+ #if defined(WINDOWS_PLATFORM)
372
372
  return (unsigned int)_rmdir(szFilePath);
373
373
  #else
374
374
  return (unsigned int)rmdir(szFilePath);
@@ -378,7 +378,7 @@ unsigned int CRhoFile::deleteEmptyFolder( const char* szFilePath ){
378
378
 
379
379
  void CRhoFile::deleteFilesInFolder(const char* szFolderPath)
380
380
  {
381
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
381
+ #if defined(WINDOWS_PLATFORM)
382
382
  StringW wFolderName;
383
383
  common::convertToStringW(szFolderPath,wFolderName);
384
384
  StringW wFolderMask = wFolderName + L"/*";
@@ -497,7 +497,7 @@ void CRhoFile::deleteFilesInFolder(const char* szFolderPath)
497
497
 
498
498
  /*static*/ unsigned int CRhoFile::deleteFolder(const char* szFolderPath)
499
499
  {
500
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
500
+ #if defined(WINDOWS_PLATFORM)
501
501
 
502
502
  StringW swPath;
503
503
  convertToStringW(szFolderPath, swPath);
@@ -512,7 +512,7 @@ void CRhoFile::deleteFilesInFolder(const char* szFolderPath)
512
512
  fop.pFrom = name;
513
513
  fop.pTo = NULL;
514
514
  fop.fFlags = FOF_SILENT | FOF_NOCONFIRMATION | FOF_NOCONFIRMMKDIR
515
- #if defined(OS_WINDOWS) || defined(OS_PLATFORM_MOTCE)
515
+ #if defined(OS_WINDOWS_DESKTOP) || defined(OS_PLATFORM_MOTCE)
516
516
  | FOF_NOERRORUI
517
517
  #endif
518
518
  ;
@@ -532,7 +532,7 @@ void CRhoFile::deleteFilesInFolder(const char* szFolderPath)
532
532
 
533
533
  }
534
534
 
535
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
535
+ #if defined(WINDOWS_PLATFORM)
536
536
  static unsigned int copyFolder(const StringW& strSrc, const StringW& strDst, boolean bMove)
537
537
  {
538
538
  unsigned int nErr = 0;
@@ -580,7 +580,7 @@ static unsigned int copyFolder(const StringW& strSrc, const StringW& strDst, boo
580
580
 
581
581
  /*static*/ unsigned int CRhoFile::copyFoldersContentToAnotherFolder(const char* szSrcFolderPath, const char* szDstFolderPath)
582
582
  {
583
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
583
+ #if defined(WINDOWS_PLATFORM)
584
584
 
585
585
  StringW strSrcW, strDstW;
586
586
  common::convertToStringW(szSrcFolderPath,strSrcW);
@@ -601,7 +601,7 @@ static unsigned int copyFolder(const StringW& strSrc, const StringW& strDst, boo
601
601
 
602
602
  /*static*/ unsigned int CRhoFile::moveFoldersContentToAnotherFolder(const char* szSrcFolderPath, const char* szDstFolderPath)
603
603
  {
604
- #if defined(OS_WINDOWS) || defined(OS_WINCE)
604
+ #if defined(WINDOWS_PLATFORM)
605
605
 
606
606
  StringW strSrcW, strDstW;
607
607
  common::convertToStringW(szSrcFolderPath,strSrcW);
@@ -58,11 +58,15 @@ public:
58
58
 
59
59
  String makeFullPath(const char* szFileName){
60
60
  String res = m_szPath;
61
- if ( res.length() > 0 && !findLastSlash() )
62
- res += "/";
61
+ if (res.length() > 0)
62
+ {
63
+ const char* pSlash = findLastSlash();
64
+ if (!pSlash || (pSlash != (res.c_str() + res.length())))
65
+ res += "/";
66
+ }
63
67
 
64
68
  res += szFileName;
65
-
69
+
66
70
  return res;
67
71
  }
68
72
 
@@ -34,7 +34,7 @@
34
34
  #define stricmp strcasecmp
35
35
  #endif
36
36
 
37
- #ifdef OS_WINDOWS
37
+ #ifdef OS_WINDOWS_DESKTOP
38
38
  #define strncasecmp _strnicmp
39
39
  #endif
40
40
 
@@ -73,7 +73,7 @@ extern long _timezone;
73
73
  #endif
74
74
  #endif
75
75
 
76
- #if defined(OS_WINDOWS)
76
+ #if defined(OS_WINDOWS_DESKTOP)
77
77
  #define _USE_MATH_DEFINES
78
78
  #endif
79
79
 
@@ -112,7 +112,7 @@ typedef unsigned __int64 uint64;
112
112
  #define FMTI64 "%I64d"
113
113
  #define FMTU64 "%I64u"
114
114
 
115
- #else // !(defined( OS_WINDOWS ) || defined( OS_WINCE ))
115
+ #else // !defined( WINDOWS_PLATFORM)
116
116
 
117
117
  #define FMTI64 "%lli"
118
118
  #define FMTU64 "%llu"