rhodes 3.4.2 → 3.5.1.12
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +9 -0
- data/Rakefile +61 -9
- data/doc/build.txt +147 -38
- data/doc/configuration.txt +49 -33
- data/doc/connect-to-web-services.txt +32 -32
- data/doc/contributing.txt +1 -1
- data/doc/device-caps.txt +62 -311
- data/doc/extensions.txt +104 -5
- data/doc/install.txt +17 -61
- data/doc/linea.txt +11 -11
- data/doc/nfc.txt +3 -3
- data/doc/release.txt +4 -4
- data/doc/rhom.txt +7 -7
- data/doc/rhostudio-test-plan.txt +12 -12
- data/doc/simulator.txt +32 -19
- data/doc/syncengine-ajax-api.txt +1 -1
- data/doc/synchronization.txt +8 -2
- data/doc/test-log-debug.txt +34 -3
- data/doc/ui.txt +8 -3
- data/installer/icon.ico +0 -0
- data/lib/build/jake.rb +27 -6
- data/lib/extensions/audiocapture/audiocapture.rb +43 -0
- data/lib/extensions/audiocapture/ext.yml +5 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/android/AndroidManifest.xml +10 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/android/Rakefile +77 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/android/ext_build.files +2 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/android/jni/src/audiocapture.cpp +189 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/android/src/com/audiocapture/Audiocapture.java +236 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/android/src/com/audiocapture/ExtAudioRecorder.java +573 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/bb/Audiocapture.files +1 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/bb/Rakefile +97 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/bb/audiocapture.jdp +48 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/bb/src/com/audiocapture/Audiocapture.java +118 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/iphone/Audiocapture.xcodeproj/project.pbxproj +314 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/iphone/Audiocapture_Prefix.pch +7 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/iphone/Classes/audioCapture.h +51 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/iphone/Classes/audioCapture.m +418 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/iphone/Rakefile +79 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/wm/Audiocapture.sln +44 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/wm/Audiocapture.vcproj +647 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/wm/Audiocapture.vsprops +15 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/wm/Rakefile +62 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/wm/src/audiocapture_wm.cpp +40 -0
- data/lib/extensions/audiocapture/ext/audiocapture/platform/wm/src/audiocapture_wm.h +2 -0
- data/lib/extensions/audiocapture/ext/audiocapture/shared/ruby/audiocapture.i +29 -0
- data/lib/extensions/audiocapture/ext/audiocapture/shared/ruby/audiocapture_wrap.c +2310 -0
- data/lib/extensions/audiocapture/ext/audiocapture/shared/src/audiocapture.c +26 -0
- data/lib/extensions/audiocapture/ext/build +17 -0
- data/lib/extensions/audiocapture/ext/build.bat +36 -0
- data/lib/extensions/barcode/ext.yml +5 -3
- data/lib/extensions/barcode/ext/barcode/platform/android/src/com/rhomobile/barcode/Barcode.java +87 -87
- data/lib/extensions/digest-md5/ext/build +1 -1
- data/lib/extensions/digest-sha1/ext/build +1 -1
- data/lib/extensions/digest-sha2/ext/build +1 -1
- data/lib/extensions/digest/ext/build +1 -1
- data/lib/extensions/fcntl/ext/fcntl.c +5 -5
- data/lib/extensions/gcm-push/ext.yml +8 -0
- data/lib/extensions/gcm-push/ext/android/AndroidManifest.rb +5 -0
- data/lib/extensions/gcm-push/ext/android/ApplicationManifestAdds.erb +8 -0
- data/lib/extensions/gcm-push/ext/android/Rakefile +66 -0
- data/lib/extensions/gcm-push/ext/android/ext_build.files +3 -0
- data/lib/extensions/gcm-push/ext/android/jni/src/com_rhomobile_rhodes_gcm_GCMRhoListener.h +21 -0
- data/lib/extensions/gcm-push/ext/android/jni/src/gcmpushclient.cpp +173 -0
- data/lib/extensions/gcm-push/ext/android/jni/src/gcmpushclient.h +62 -0
- data/lib/extensions/gcm-push/ext/android/src/com/rhomobile/rhodes/gcm/GCMBroadcastReceiver.java +40 -0
- data/lib/extensions/gcm-push/ext/android/src/com/rhomobile/rhodes/gcm/GCMFacade.java +55 -0
- data/lib/extensions/gcm-push/ext/android/src/com/rhomobile/rhodes/gcm/GCMIntentService.java +60 -0
- data/lib/extensions/gcm-push/ext/build +12 -0
- data/lib/extensions/gcm-push/ext/build.bat +8 -0
- data/lib/extensions/net-http/net/http.rb +153 -119
- data/lib/extensions/net-http/net/https.rb +4 -38
- data/lib/extensions/nfc/ext.yml +6 -4
- data/lib/extensions/nfc/ext/nfc/platform/android/jni/src/nfc.cpp +2 -2
- data/lib/extensions/nfc/ext/nfc/platform/android/src/com/rhomobile/nfc/NfcTechActivity.java +0 -1
- data/lib/extensions/openssl/openssl/ssl-internal.rb +3 -1
- data/lib/extensions/rawsensors/ext.yml +4 -0
- data/lib/extensions/rawsensors/ext/build +17 -0
- data/lib/extensions/rawsensors/ext/build.bat +36 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/android/Rakefile +77 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/android/ext_build.files +1 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/android/jni/src/rawsensors.cpp +180 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/android/src/com/rawsensors/Rawsensors.java +355 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/bb/Rakefile +97 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/bb/Rawsensors.files +1 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/bb/rawsensors.jdp +48 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/bb/src/com/rawsensors/Rawsensors.java +118 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/iphone/Classes/RawSensors.h +66 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/iphone/Classes/RawSensors.m +351 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/iphone/Rakefile +79 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/iphone/Rawsensors.xcodeproj/project.pbxproj +316 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/iphone/Rawsensors_Prefix.pch +7 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/wm/Rakefile +62 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/wm/Rawsensors.sln +44 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/wm/Rawsensors.vcproj +647 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/wm/Rawsensors.vsprops +15 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/wm/src/rawsensors_wm.cpp +40 -0
- data/lib/extensions/rawsensors/ext/rawsensors/platform/wm/src/rawsensors_wm.h +2 -0
- data/lib/extensions/rawsensors/ext/rawsensors/shared/ruby/rawsensors.i +22 -0
- data/lib/extensions/rawsensors/ext/rawsensors/shared/ruby/rawsensors_wrap.c +2308 -0
- data/lib/extensions/rawsensors/ext/rawsensors/shared/src/rawsensors.c +25 -0
- data/lib/extensions/rawsensors/rawsensors.rb +36 -0
- data/lib/framework/autocomplete/AddressBar.rb +19 -0
- data/lib/framework/autocomplete/Alarm.rb +23 -0
- data/lib/framework/autocomplete/Alert.rb +19 -0
- data/lib/framework/autocomplete/AppApplication.rb +17 -0
- data/lib/framework/autocomplete/AppSwitcher.rb +13 -0
- data/lib/framework/autocomplete/Application.rb +23 -0
- data/lib/framework/autocomplete/AudioCapture.rb +31 -0
- data/lib/framework/autocomplete/BackButton.rb +25 -0
- data/lib/framework/autocomplete/Backlight.rb +21 -0
- data/lib/framework/autocomplete/Barcode.rb +29 -0
- data/lib/framework/autocomplete/BasicSocket.rb +87 -0
- data/lib/framework/autocomplete/Battery.rb +33 -0
- data/lib/framework/autocomplete/BottomCommandArea.rb +19 -0
- data/lib/framework/autocomplete/BrowserHelper.rb +19 -0
- data/lib/framework/autocomplete/Bsearch.rb +11 -0
- data/lib/framework/autocomplete/Camera.rb +17 -0
- data/lib/framework/autocomplete/CardReader.rb +29 -0
- data/lib/framework/autocomplete/Comm.rb +45 -0
- data/lib/framework/autocomplete/Cradle.rb +15 -0
- data/lib/framework/autocomplete/Date.rb +50 -0
- data/lib/framework/autocomplete/DateTime.rb +24 -0
- data/lib/framework/autocomplete/DateTimePicker.rb +15 -0
- data/lib/framework/autocomplete/Device.rb +19 -0
- data/lib/framework/autocomplete/Digest.rb +28 -0
- data/lib/framework/autocomplete/Dir.rb +63 -0
- data/lib/framework/autocomplete/Eink.rb +19 -0
- data/lib/framework/autocomplete/EmmlProfile.rb +19 -0
- data/lib/framework/autocomplete/File.rb +301 -0
- data/lib/framework/autocomplete/FileTransfer.rb +27 -0
- data/lib/framework/autocomplete/ForwardButton.rb +25 -0
- data/lib/framework/autocomplete/GeneratorController.rb +15 -0
- data/lib/framework/autocomplete/GeoLocation.rb +27 -0
- data/lib/framework/autocomplete/Gesture.rb +71 -0
- data/lib/framework/autocomplete/GoButton.rb +25 -0
- data/lib/framework/autocomplete/HashWithIndifferentAccess.rb +51 -0
- data/lib/framework/autocomplete/History.rb +11 -0
- data/lib/framework/autocomplete/HomeButton.rb +25 -0
- data/lib/framework/autocomplete/Hourglass.rb +17 -0
- data/lib/framework/autocomplete/IPSocket.rb +65 -0
- data/lib/framework/autocomplete/Imager.rb +53 -0
- data/lib/framework/autocomplete/IoAnalog.rb +73 -0
- data/lib/framework/autocomplete/IoDigital.rb +93 -0
- data/lib/framework/autocomplete/IoSystem.rb +21 -0
- data/lib/framework/autocomplete/JSON.rb +142 -0
- data/lib/framework/autocomplete/KeyCapture.rb +25 -0
- data/lib/framework/autocomplete/KeyState.rb +23 -0
- data/lib/framework/autocomplete/Keylight.rb +17 -0
- data/lib/framework/autocomplete/Lightsensor.rb +19 -0
- data/lib/framework/autocomplete/LocalizationSimplified.rb +33 -0
- data/lib/framework/autocomplete/MapView.rb +23 -0
- data/lib/framework/autocomplete/MediaPlayer.rb +19 -0
- data/lib/framework/autocomplete/Memory.rb +17 -0
- data/lib/framework/autocomplete/MinimizeButton.rb +25 -0
- data/lib/framework/autocomplete/NativeBar.rb +31 -0
- data/lib/framework/autocomplete/NavBar.rb +15 -0
- data/lib/framework/autocomplete/Network.rb +31 -0
- data/lib/framework/autocomplete/Notification.rb +35 -0
- data/lib/framework/autocomplete/OpenSSL.rb +440 -0
- data/lib/framework/autocomplete/Phonebook.rb +39 -0
- data/lib/framework/autocomplete/PowerOn.rb +13 -0
- data/lib/framework/autocomplete/Push.rb +27 -0
- data/lib/framework/autocomplete/QuitButton.rb +25 -0
- data/lib/framework/autocomplete/RHO_APPS_DIR.rb +8 -0
- data/lib/framework/autocomplete/RHO_ERB_EXT.rb +8 -0
- data/lib/framework/autocomplete/RHO_FRAMEWORK.rb +0 -0
- data/lib/framework/autocomplete/RHO_RB_EXT.rb +8 -0
- data/lib/framework/autocomplete/RawSensors.rb +53 -0
- data/lib/framework/autocomplete/Reboot.rb +13 -0
- data/lib/framework/autocomplete/Registry.rb +25 -0
- data/lib/framework/autocomplete/ReloadButton.rb +25 -0
- data/lib/framework/autocomplete/Rfid.rb +173 -0
- data/lib/framework/autocomplete/Rho.rb +496 -0
- data/lib/framework/autocomplete/RhoBluetooth.rb +41 -0
- data/lib/framework/autocomplete/RhoConf.rb +23 -0
- data/lib/framework/autocomplete/RhoElementsExt.rb +11 -0
- data/lib/framework/autocomplete/RhoLog.rb +13 -0
- data/lib/framework/autocomplete/RhoProfiler.rb +21 -0
- data/lib/framework/autocomplete/RhoStdout.rb +19 -0
- data/lib/framework/autocomplete/Rhodes.rb +13 -0
- data/lib/framework/autocomplete/RhodesNativeViewManager.rb +15 -0
- data/lib/framework/autocomplete/Rhom.rb +198 -0
- data/lib/framework/autocomplete/Rsm.rb +135 -0
- data/lib/framework/autocomplete/SQLite3.rb +36 -0
- data/lib/framework/autocomplete/SWIG.rb +24 -0
- data/lib/framework/autocomplete/ScanError.rb +9 -0
- data/lib/framework/autocomplete/Scanner.rb +379 -0
- data/lib/framework/autocomplete/ScreenOrientation.rb +23 -0
- data/lib/framework/autocomplete/SignatureCapture.rb +47 -0
- data/lib/framework/autocomplete/SignatureTool.rb +11 -0
- data/lib/framework/autocomplete/Sip.rb +19 -0
- data/lib/framework/autocomplete/SipButton.rb +25 -0
- data/lib/framework/autocomplete/Sntp.rb +13 -0
- data/lib/framework/autocomplete/Socket.rb +356 -0
- data/lib/framework/autocomplete/SocketError.rb +9 -0
- data/lib/framework/autocomplete/StopButton.rb +25 -0
- data/lib/framework/autocomplete/StringIO.rb +139 -0
- data/lib/framework/autocomplete/StringScanner.rb +102 -0
- data/lib/framework/autocomplete/Stylus.rb +15 -0
- data/lib/framework/autocomplete/SyncEngine.rb +77 -0
- data/lib/framework/autocomplete/System.rb +79 -0
- data/lib/framework/autocomplete/SystemTime.rb +17 -0
- data/lib/framework/autocomplete/TCPServer.rb +65 -0
- data/lib/framework/autocomplete/TCPSocket.rb +59 -0
- data/lib/framework/autocomplete/Telemetry.rb +23 -0
- data/lib/framework/autocomplete/Thread.rb +85 -0
- data/lib/framework/autocomplete/Time.rb +167 -0
- data/lib/framework/autocomplete/Timer.rb +19 -0
- data/lib/framework/autocomplete/TopCommandArea.rb +19 -0
- data/lib/framework/autocomplete/UDPSocket.rb +65 -0
- data/lib/framework/autocomplete/VideoCapture.rb +29 -0
- data/lib/framework/autocomplete/Volume.rb +13 -0
- data/lib/framework/autocomplete/Wake.rb +15 -0
- data/lib/framework/autocomplete/WebView.rb +31 -0
- data/lib/framework/autocomplete/Wlan.rb +87 -0
- data/lib/framework/autocomplete/Zoom.rb +15 -0
- data/lib/framework/autocomplete/ZoomInPageButton.rb +25 -0
- data/lib/framework/autocomplete/ZoomOutPageButton.rb +25 -0
- data/lib/framework/autocomplete/ZoomTextButton.rb +25 -0
- data/lib/framework/rho/render.rb +15 -4
- data/lib/framework/rho/rho.rb +17 -8
- data/lib/framework/rho/rhoapplication.rb +25 -3
- data/lib/framework/rho/rhocontact.rb +13 -0
- data/lib/framework/rho/rhoevent.rb +15 -0
- data/lib/framework/rho/rhonativeviewmanager.rb +3 -3
- data/lib/framework/rhodes.rb +1 -1
- data/lib/framework/rhom/rhom.rb +5 -0
- data/lib/framework/rhomotoapi.rb +2 -1
- data/lib/framework/version.rb +1 -1
- data/lib/rhodes.rb +1 -1
- data/platform/android/Rhodes/AndroidManifest.xml +4 -3
- data/platform/android/Rhodes/AndroidManifest.xml.erb +7 -7
- data/platform/android/Rhodes/jni/include/rhodes/JNIRhodes.h +22 -0
- data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_RhodesService.h +1 -9
- data/platform/android/Rhodes/jni/src/callbacks.cpp +2 -0
- data/platform/android/Rhodes/jni/src/camera.cpp +5 -0
- data/platform/android/Rhodes/jni/src/event.cpp +10 -0
- data/platform/android/Rhodes/jni/src/geolocation.cpp +10 -0
- data/platform/android/Rhodes/jni/src/logger.cpp +3 -1
- data/platform/android/Rhodes/jni/src/phonebook.cpp +11 -0
- data/platform/android/Rhodes/jni/src/rhodes.cpp +1 -1
- data/platform/android/Rhodes/jni/src/rhodesapp.cpp +41 -25
- data/platform/android/Rhodes/jni/src/signature.cpp +7 -6
- data/platform/android/Rhodes/jni/src/webview.cpp +29 -0
- data/platform/android/Rhodes/project.properties +1 -1
- data/platform/android/Rhodes/res/drawable/icon.png +0 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/ConnectionChangeReceiver.java +28 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/NativeBar.java +1 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushContract.java +102 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +20 -56
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +9 -124
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +114 -126
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java +26 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/alert/PopupActivity.java +3 -5
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/Camera.java +31 -13
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/ImageCapture.java +2 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/datetime/DateTimePicker.java +3 -7
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/event/CalendarIDsProvider.java +19 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/event/CalendarIDsProviderFroyo.java +5 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/event/CalendarIDsProviderICS.java +22 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/event/EventStore.java +32 -22
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoExtension.java +5 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoListener.java +34 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtManager.java +11 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtension.java +1 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/{webview → extmanager}/IRhoWebView.java +5 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManagerImpl.java +605 -492
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocation.java +16 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/MainView.java +9 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +43 -14
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SplashScreen.java +82 -64
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java +28 -13
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/GoogleMapView.java +4 -4
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java +0 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality.java +4 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality01.java +6 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality08.java +7 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality12.java +6 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality13.java +6 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality14.java +12 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionalityManager.java +10 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/Signature.java +3 -6
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/socket/RhoSocketImpl.java +1 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/LocalFileHandler.java +1 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/GoogleWebView.java +43 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebChromeClient.java +5 -0
- data/platform/android/build/RhodesSRC_build.files +10 -4
- data/platform/android/build/android.rake +46 -193
- data/platform/android/build/android_tools.rb +181 -13
- data/platform/bb/Hsqldb/src/org/hsqldb/CompiledStatementExecutor.java +3 -3
- data/platform/bb/Hsqldb/src/org/hsqldb/Expression.java +4 -2
- data/platform/bb/RubyVM/src/com/rho/IRhoRubyHelper.java +2 -0
- data/platform/bb/RubyVM/src/com/rho/RhoRuby.java +6 -0
- data/platform/bb/RubyVM/src/com/rho/ThreadQueue.java +13 -8
- data/platform/bb/RubyVM/src/com/rho/db/DBAdapter.java +103 -1
- data/platform/bb/RubyVM/src/com/rho/db/DBAttrManager.java +18 -0
- data/platform/bb/RubyVM/src/com/rho/net/NetRequest.java +9 -2
- data/platform/bb/RubyVM/src/com/rho/net/RhoConnection.java +16 -11
- data/platform/bb/RubyVM/src/com/rho/sync/ClientRegister.java +25 -3
- data/platform/bb/RubyVM/src/com/rho/sync/ISyncProtocol.java +1 -1
- data/platform/bb/RubyVM/src/com/rho/sync/SyncEngine.java +122 -32
- data/platform/bb/RubyVM/src/com/rho/sync/SyncNotify.java +44 -14
- data/platform/bb/RubyVM/src/com/rho/sync/SyncProtocol_3.java +3 -2
- data/platform/bb/RubyVM/src/com/rho/sync/SyncSource.java +340 -88
- data/platform/bb/RubyVM/src/com/rho/sync/SyncThread.java +62 -15
- data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/AttrReader.java +1 -1
- data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyFixnum.java +3 -1
- data/platform/bb/RubyVM/src/com/xruby/runtime/builtin/RubyHash.java +1 -1
- data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyAPI.java +19 -1
- data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyBasic.java +9 -0
- data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyBinding.java +4 -4
- data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyModule.java +13 -1
- data/platform/bb/RubyVM/src/com/xruby/runtime/lang/RubyObject.java +16 -1
- data/platform/bb/build/bb.rake +3 -1
- data/platform/bb/build/rhodes_build.files +0 -1
- data/platform/bb/rhodes/platform/4.7/com/rho/rubyext/SignatureCapture.java +13 -18
- data/platform/bb/rhodes/platform/5.0/com/rho/BrowserAdapter5.java +13 -3
- data/platform/bb/rhodes/platform/5.0/com/rho/RhodesApplicationPlatform.java +1 -1
- data/platform/bb/rhodes/platform/common/com/rho/rubyext/SignatureCapture.java +13 -18
- data/platform/bb/rhodes/resources/icon.png +0 -0
- data/platform/bb/rhodes/src/com/rho/BrowserAdapter.java +10 -0
- data/platform/bb/rhodes/src/com/rho/BrowserAdapter5.java +13 -3
- data/platform/bb/rhodes/src/com/rho/RhoRubyHelper.java +5 -0
- data/platform/bb/rhodes/src/com/rho/RhodesApplicationPlatform.java +1 -1
- data/platform/bb/rhodes/src/com/rho/file/Jsr75File.java +6 -1
- data/platform/bb/rhodes/src/com/rho/file/Jsr75RAFileImpl.java +6 -1
- data/platform/bb/rhodes/src/com/rho/rubyext/GeoLocation.java +38 -9
- data/platform/bb/rhodes/src/com/rho/rubyext/SignatureCapture.java +13 -18
- data/platform/bb/rhodes/src/com/rho/rubyext/WebView.java +16 -1
- data/platform/bb/rhodes/src/rhomobile/PushListeningThread.java +0 -20
- data/platform/bb/rhodes/src/rhomobile/RhodesApplication.java +1 -10
- data/platform/bb/rhodes/src/rhomobile/camera/CameraScreen.java +40 -35
- data/platform/iphone/Classes/AppManager/AppManager.h +1 -1
- data/platform/iphone/Classes/AppManager/AppManager.m +46 -29
- data/platform/iphone/Classes/Camera/PickImageDelegate.m +9 -0
- data/platform/iphone/Classes/Event/Event.h +6 -1
- data/platform/iphone/Classes/Event/Event.m +67 -1
- data/platform/iphone/Classes/GeoLocation/LocationController.h +2 -1
- data/platform/iphone/Classes/GeoLocation/LocationController.m +17 -1
- data/platform/iphone/Classes/NetworkStatusMonitor.h +17 -0
- data/platform/iphone/Classes/NetworkStatusMonitor.mm +58 -0
- data/platform/iphone/Classes/Phonebook/phonebook.h +6 -0
- data/platform/iphone/Classes/Phonebook/phonebook.m +62 -6
- data/platform/iphone/Classes/Reachability.h +31 -0
- data/platform/iphone/Classes/Reachability.m +223 -0
- data/platform/iphone/Classes/RhoMainView.h +1 -0
- data/platform/iphone/Classes/RhoViewController.m +16 -0
- data/platform/iphone/Classes/Rhodes.h +2 -0
- data/platform/iphone/Classes/Rhodes.m +89 -10
- data/platform/iphone/Classes/Signature/SignatureDelegate.m +4 -7
- data/platform/iphone/Classes/SimpleMainView.m +16 -0
- data/platform/iphone/Classes/SplashViewController.m +11 -1
- data/platform/iphone/Classes/SplitView/RightViewController.m +6 -0
- data/platform/iphone/Classes/SplitView/SplittedMainView.m +5 -0
- data/platform/iphone/Classes/TabbedMainView.m +4 -0
- data/platform/iphone/Classes/WebView.m +14 -0
- data/platform/iphone/Info.plist +1 -6
- data/platform/iphone/iTunesArtwork.jpg +0 -0
- data/platform/iphone/icon.png +0 -0
- data/platform/iphone/icon114.png +0 -0
- data/platform/iphone/icon57.png +0 -0
- data/platform/iphone/icon72.png +0 -0
- data/platform/iphone/rbuild/iphone.rake +8 -11
- data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +20 -4
- data/platform/osx/Rhodes Launcher/rhorunner.app/icon.png +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtCore.framework/Versions/4/QtCore +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtGui.framework/Versions/4/QtGui +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtNetwork.framework/Versions/4/QtNetwork +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/QtWebKit.framework/Versions/4/QtWebKit +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Info.plist +1 -1
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/MacOS/RhoSimulator +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/accessible/libqtaccessiblewidgets.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqcorewlanbearer.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/bearer/libqgenericbearer.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqcncodecs.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqjpcodecs.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqkrcodecs.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/codecs/libqtwcodecs.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/graphicssystems/libqtracegraphicssystem.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqgif.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqico.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqjpeg.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqmng.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtga.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/imageformats/libqtiff.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_inspector.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/qmltooling/libqmldbg_tcp.dylib +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Resources/rho.icns +0 -0
- data/platform/shared/common/ExtManager.h +8 -0
- data/platform/shared/common/RhoDefs.h +3 -2
- data/platform/shared/common/RhoFile.cpp +14 -1
- data/platform/shared/common/RhoMutexLock.h +4 -0
- data/platform/shared/common/RhoPort.h +5 -1
- data/platform/shared/common/RhoStd.h +12 -0
- data/platform/shared/common/RhoThread.cpp +1 -2
- data/platform/shared/common/RhoTime.h +4 -0
- data/platform/shared/common/RhodesApp.cpp +189 -65
- data/platform/shared/common/RhodesApp.h +60 -7
- data/platform/shared/common/RhodesAppBase.cpp +2 -8
- data/platform/shared/common/RhodesAppBase.h +1 -0
- data/platform/shared/common/ThreadQueue.cpp +2 -2
- data/platform/shared/common/app_build_configs.c +3 -1
- data/platform/shared/common/map/MapEngine.cpp +39 -3
- data/platform/shared/common/push/IRhoPushClient.h +3 -3
- data/platform/shared/common/push/RhoPushManager.cpp +31 -53
- data/platform/shared/common/push/RhoPushManager.h +12 -26
- data/platform/shared/curl/lib/curl_config.h +1 -1
- data/platform/shared/json/RJSONTokener.c +3 -1
- data/platform/shared/json/config.h +4 -4
- data/platform/shared/json/json_tokener.c +1 -1
- data/platform/shared/logging/RhoLog.cpp +5 -5
- data/platform/shared/logging/RhoLogConf.cpp +4 -6
- data/platform/shared/logging/RhoLogConf.h +2 -2
- data/platform/shared/logging/RhoLogSink.cpp +2 -0
- data/platform/shared/net/HttpServer.cpp +54 -7
- data/platform/shared/net/HttpServer.h +2 -0
- data/platform/shared/qt/rhodes/QtMainWindow.cpp +22 -0
- data/platform/shared/qt/rhodes/QtMainWindow.h +1 -0
- data/platform/shared/qt/rhodes/impl/CalendarImpl.cpp +4 -0
- data/platform/shared/qt/rhodes/impl/CameraImpl.cpp +4 -0
- data/platform/shared/qt/rhodes/impl/GeoLocationImpl.cpp +6 -0
- data/platform/shared/qt/rhodes/impl/MainWindowImpl.cpp +7 -0
- data/platform/shared/qt/rhodes/impl/MainWindowImpl.h +2 -0
- data/platform/shared/qt/rhodes/impl/PhonebookImpl.cpp +4 -0
- data/platform/shared/qt/rhodes/impl/SystemImpl.cpp +5 -0
- data/platform/shared/qt/rhodes/impl/WebViewImpl.cpp +12 -0
- data/platform/shared/qt/rhodes/main.cpp +0 -7
- data/platform/shared/qt/rhodes/resources/rho.icns +0 -0
- data/platform/shared/qt/rhodes/resources/rho.ico +0 -0
- data/platform/shared/qt/rhodes/resources/rho.png +0 -0
- data/platform/shared/ruby/encoding.c +4 -0
- data/platform/shared/ruby/ext/calendar/calendar.i +3 -0
- data/platform/shared/ruby/ext/calendar/calendar_wrap.c +19 -0
- data/platform/shared/ruby/ext/camera/camera.i +2 -0
- data/platform/shared/ruby/ext/camera/camera_wrap.c +43 -2
- data/platform/shared/ruby/ext/geolocation/geolocation.i +4 -0
- data/platform/shared/ruby/ext/geolocation/geolocation_wrap.c +24 -4
- data/platform/shared/ruby/ext/phonebook/phonebook.i +4 -0
- data/platform/shared/ruby/ext/phonebook/phonebook_wrap.c +44 -0
- data/platform/shared/ruby/ext/rho/extensions.c +0 -2
- data/platform/shared/ruby/ext/rho/rhoruby.c +2 -0
- data/platform/shared/ruby/ext/rho/rhosupport.c +8 -0
- data/platform/shared/ruby/ext/sqlite3_api/sqlite3_api_wrap.c +1 -1
- data/platform/shared/ruby/ext/syncengine/syncengine.i +6 -2
- data/platform/shared/ruby/ext/syncengine/syncengine_wrap.c +19 -6
- data/platform/shared/ruby/ext/system/system.i +22 -0
- data/platform/shared/ruby/ext/system/system_wrap.c +158 -86
- data/platform/shared/ruby/ext/webview/webview.i +13 -8
- data/platform/shared/ruby/ext/webview/webview_wrap.c +88 -2
- data/platform/shared/ruby/include/ruby/win32.h +3 -1
- data/platform/shared/ruby/iphone/ruby/config.h +3 -3
- data/platform/shared/ruby/missing/hypot.c +4 -0
- data/platform/shared/ruby/random.c +6 -2
- data/platform/shared/ruby/thread_win32.c +8 -3
- data/platform/shared/ruby/win32/ruby/config.h +0 -3
- data/platform/shared/ruby/win32/win32.c +4 -0
- data/platform/shared/ruby/wp8/assert.c +12 -0
- data/platform/shared/ruby/wp8/assert.h +18 -0
- data/platform/shared/ruby/wp8/errno.c +11 -0
- data/platform/shared/ruby/wp8/errno.h +59 -0
- data/platform/shared/ruby/wp8/missing_wp8.h +74 -0
- data/platform/shared/ruby/wp8/signal.h +71 -0
- data/platform/shared/ruby/wp8/signal_wp8.c +26 -0
- data/platform/shared/ruby/wp8/stdio.c +36 -0
- data/platform/shared/ruby/wp8/stdlib.c +61 -0
- data/platform/shared/ruby/wp8/string_wp8.c +89 -0
- data/platform/shared/ruby/wp8/sys/stat.c +183 -0
- data/platform/shared/ruby/wp8/sys/stat.h +70 -0
- data/platform/shared/ruby/wp8/sys/timeb.c +31 -0
- data/platform/shared/ruby/wp8/sys/timeb.h +27 -0
- data/platform/shared/ruby/wp8/sys/types.h +62 -0
- data/platform/shared/ruby/wp8/sys/utime.c +44 -0
- data/platform/shared/ruby/wp8/sys/utime.h +27 -0
- data/platform/shared/ruby/wp8/time_wp8.c +256 -0
- data/platform/shared/ruby/wp8/varargs.h +34 -0
- data/platform/shared/ruby/wp8/win32/win32.c +5783 -0
- data/platform/shared/ruby/wp8/winsock_wp8.c +26 -0
- data/platform/shared/ruby/wp8/winsock_wp8.h +23 -0
- data/platform/shared/ruby/wp8/wp8.c +516 -0
- data/platform/shared/ruby/wp8/wp8.h +274 -0
- data/platform/shared/ruby/wp8/wp8main.c +18 -0
- data/platform/shared/rubyext/GeoLocation.cpp +1 -1
- data/platform/shared/rubyext/System.cpp +18 -4
- data/platform/shared/rubyext/ZipFiles.cpp +1 -1
- data/platform/shared/sync/ClientRegister.cpp +113 -23
- data/platform/shared/sync/ClientRegister.h +27 -16
- data/platform/shared/sync/ILoginListener.h +44 -0
- data/platform/shared/sync/SyncEngine.cpp +50 -24
- data/platform/shared/sync/SyncEngine.h +11 -5
- data/platform/shared/sync/SyncSource.cpp +87 -61
- data/platform/shared/sync/SyncSource.h +6 -3
- data/platform/shared/sync/SyncThread.cpp +8 -15
- data/platform/shared/sync/SyncThread.h +13 -7
- data/platform/shared/unzip/unzip.cpp +1 -1
- data/platform/shared/unzip/zip.h +8 -1
- data/platform/shared/xruby/src/com/xruby/runtime/builtin/AttrReader.java +13 -0
- data/platform/shared/xruby/src/com/xruby/runtime/builtin/RubyFixnum.java +3 -1
- data/platform/shared/xruby/src/com/xruby/runtime/lang/MethodBlockBase.java +9 -0
- data/platform/shared/xruby/src/com/xruby/runtime/lang/RubyBasic.java +9 -0
- data/platform/shared/xruby/src/com/xruby/runtime/lang/RubyBinding.java +17 -0
- data/platform/shared/xruby/src/com/xruby/runtime/lang/RubyMethod.java +22 -2
- data/platform/shared/xruby/src/com/xruby/runtime/lang/RubyModule.java +25 -0
- data/platform/shared/xruby/src/com/xruby/runtime/lang/RubyObject.java +21 -0
- data/platform/shared/xruby/src/com/xruby/runtime/lang/RubyValue.java +8 -0
- data/platform/symbian/rhodes/src/phonebook/ruby_phonebook.cpp +6 -0
- data/platform/win32/RhoSimulator/Microsoft.VC90.CRT.manifest +12 -5
- data/platform/win32/RhoSimulator/Microsoft.VC90.OpenMP.manifest +12 -5
- data/platform/win32/RhoSimulator/QtCore4.dll +0 -0
- data/platform/win32/RhoSimulator/QtGui4.dll +0 -0
- data/platform/win32/RhoSimulator/QtNetwork4.dll +0 -0
- data/platform/win32/RhoSimulator/QtWebKit4.dll +0 -0
- data/platform/win32/RhoSimulator/RhoSimulator.exe +0 -0
- data/platform/win32/RhoSimulator/imageformats/qgif4.dll +0 -0
- data/platform/win32/RhoSimulator/imageformats/qico4.dll +0 -0
- data/platform/win32/RhoSimulator/imageformats/qjpeg4.dll +0 -0
- data/platform/win32/RhoSimulator/imageformats/qmng4.dll +0 -0
- data/platform/win32/RhoSimulator/imageformats/qsvg4.dll +0 -0
- data/platform/win32/RhoSimulator/imageformats/qtiff4.dll +0 -0
- data/platform/win32/RhoSimulator/msvcm90.dll +0 -0
- data/platform/win32/RhoSimulator/msvcp90.dll +0 -0
- data/platform/win32/RhoSimulator/msvcr90.dll +0 -0
- data/platform/win32/RhoSimulator/phonon4.dll +0 -0
- data/platform/win32/RhoSimulator/vcomp90.dll +0 -0
- data/platform/wm/build/wm.rake +67 -22
- data/platform/wm/rhodes.sln +485 -493
- data/platform/wm/rhodes/IEBrowserEngine.cpp +2 -6
- data/platform/wm/rhodes/MainWindow.cpp +86 -35
- data/platform/wm/rhodes/MainWindow.h +33 -0
- data/platform/wm/rhodes/Rhodes.cpp +288 -215
- data/platform/wm/rhodes/bluetooth/Bluetooth.cpp +22 -17
- data/platform/wm/rhodes/bluetooth/Bluetooth.h +3 -3
- data/platform/wm/rhodes/camera/Camera.cpp +4 -0
- data/platform/wm/rhodes/camera/Camera.h +1 -0
- data/platform/wm/rhodes/phonebook/phonebook.cpp +9 -0
- data/platform/wm/rhodes/phonebook/phonebook.h +2 -0
- data/platform/wm/rhodes/resources/icon.ico +0 -0
- data/platform/wm/rhodes/rho/common/ExtManager.cpp +5 -1
- data/platform/wm/rhodes/rho/common/RhoClassFactory.cpp +1 -11
- data/platform/wm/rhodes/rho/rubyext/GeoLocationImpl.cpp +5 -0
- data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +21 -2
- data/platform/wm/rhodes/rho/rubyext/WebView.cpp +12 -0
- data/platform/wm/rhodes/rho/rubyext/calendar.cpp +9 -0
- data/platform/wm/rhodes/rhodes.vcproj +60 -60
- data/platform/wm/rhodes/simulator/MainWindowQt.cpp +91 -6
- data/platform/wm/rhodes/simulator/MainWindowQt.h +6 -0
- data/platform/wm/rhoelements.sln +624 -623
- data/platform/wm/tcmalloc/tcmalloc.vcproj +1230 -1070
- data/platform/wp7/RhoRubyLib/rubyext/RhoCamera.cs +6 -3
- data/platform/wp7/rhodes/Properties/WMAppManifest.xml +5 -0
- data/platform/wp7/rhodes/icon.png +0 -0
- data/platform/wp8/RhoAppRunner/Program.cs +99 -0
- data/platform/wp8/RhoAppRunner/Properties/AssemblyInfo.cs +36 -0
- data/platform/wp8/RhoAppRunner/RhoAppRunner.csproj +69 -0
- data/platform/wp8/build/wp.rake +486 -0
- data/platform/wp8/rhodes.sln +154 -0
- data/platform/wp8/rhodes/App.xaml +20 -0
- data/platform/wp8/rhodes/App.xaml.cs +189 -0
- data/platform/wp8/rhodes/Assets/ApplicationIcon.png +0 -0
- data/platform/wp8/rhodes/Assets/Tiles/FlipCycleTileMedium.png +0 -0
- data/platform/wp8/rhodes/Assets/Tiles/FlipCycleTileSmall.png +0 -0
- data/platform/wp8/rhodes/LocalizedStrings.cs +37 -0
- data/platform/wp8/rhodes/MainPage.xaml +21 -0
- data/platform/wp8/rhodes/MainPage.xaml.cs +339 -0
- data/platform/wp8/rhodes/Properties/AppManifest.xml +6 -0
- data/platform/wp8/rhodes/Properties/AssemblyInfo.cs +37 -0
- data/platform/wp8/rhodes/Properties/WMAppManifest.xml +47 -0
- data/platform/wp8/rhodes/Resources/AppResources.Designer.cs +127 -0
- data/platform/wp8/rhodes/Resources/AppResources.resx +135 -0
- data/platform/wp8/rhodes/common/IInputStream.cs +47 -0
- data/platform/wp8/rhodes/common/RhoFile.cs +374 -0
- data/platform/wp8/rhodes/common/RhoFilePath.cs +115 -0
- data/platform/wp8/rhodes/common/RhoResourceMap.cs +92 -0
- data/platform/wp8/rhodes/common/RhoStd.cs +237 -0
- data/platform/wp8/rhodes/icon.png +0 -0
- data/platform/wp8/rhodes/rhodes.csproj +198 -0
- data/platform/wp8/rholib/rholib.vcxproj +240 -0
- data/platform/wp8/rholib/rholib.vcxproj.filters +289 -0
- data/platform/wp8/rhoruntime/FakeDefs.cpp +134 -0
- data/platform/wp8/rhoruntime/common/ExtManager.cpp +449 -0
- data/platform/wp8/rhoruntime/common/RhoClassFactory.cpp +58 -0
- data/platform/wp8/rhoruntime/common/RhoClassFactory.h +60 -0
- data/platform/wp8/rhoruntime/common/RhoCryptImpl.cpp +274 -0
- data/platform/wp8/rhoruntime/common/RhoCryptImpl.h +78 -0
- data/platform/wp8/rhoruntime/common/RhoThreadImpl.cpp +109 -0
- data/platform/wp8/rhoruntime/common/RhoThreadImpl.h +56 -0
- data/platform/wp8/rhoruntime/pch_rhoruntime.cpp +27 -0
- data/platform/wp8/rhoruntime/pch_rhoruntime.h +30 -0
- data/platform/wp8/rhoruntime/rhoruntime.cpp +93 -0
- data/platform/wp8/rhoruntime/rhoruntime.h +114 -0
- data/platform/wp8/rhoruntime/rhoruntime.vcxproj +175 -0
- data/platform/wp8/rhoruntime/rhoruntime.vcxproj.filters +44 -0
- data/platform/wp8/rubylib/file.c +5459 -0
- data/platform/wp8/rubylib/rubylib.vcxproj +286 -0
- data/platform/wp8/rubylib/rubylib.vcxproj.filters +307 -0
- data/platform/wp8/sqlite3/crypto.c +933 -0
- data/platform/wp8/sqlite3/sqlite3.c +136332 -0
- data/platform/wp8/sqlite3/sqlite3.vcxproj +149 -0
- data/platform/wp8/sqlite3/sqlite3.vcxproj.filters +16 -0
- data/platform/wp8/syncengine/syncengine.vcxproj +199 -0
- data/platform/wp8/syncengine/syncengine.vcxproj.filters +155 -0
- data/rakefile.rb +61 -9
- data/res/build-tools/RhoAppRunnerWP8.exe +0 -0
- data/res/build-tools/license_rc.dll +0 -0
- data/res/build-tools/win32/license_rc.dll +0 -0
- data/res/build-tools/xruby-0.3.3.jar +0 -0
- data/res/generators/rhogen.rb +36 -0
- data/res/generators/templates/application/app/loading-568h@2x.png +0 -0
- data/res/generators/templates/application/app/loading-Landscape.png +0 -0
- data/res/generators/templates/application/app/loading-LandscapeLeft.png +0 -0
- data/res/generators/templates/application/app/loading-LandscapeRight.png +0 -0
- data/res/generators/templates/application/app/loading-Portrait.png +0 -0
- data/res/generators/templates/application/app/loading-PortraitUpsideDown.png +0 -0
- data/res/generators/templates/application/app/loading.png +0 -0
- data/res/generators/templates/application/app/loading@2x.png +0 -0
- data/res/generators/templates/application/icon/icon.ico +0 -0
- data/res/generators/templates/application/icon/icon.png +0 -0
- data/res/generators/templates/application/icon/icon114.png +0 -0
- data/res/generators/templates/application/icon/icon57.png +0 -0
- data/res/generators/templates/application/icon/icon72.png +0 -0
- data/res/generators/templates/application/public/css/android.css +1 -1
- data/res/generators/templates/application/public/jqmobile/images/icon-search-black.png +0 -0
- data/res/generators/templates/application/rhoconfig.txt +3 -1
- data/res/generators/templates/model/model.rb +1 -1
- data/res/icons/rho.icns +0 -0
- data/res/icons/rho.ico +0 -0
- data/res/icons/rho.png +0 -0
- data/res/icons/rhodes.icns +0 -0
- data/res/icons/rhodes.ico +0 -0
- data/res/icons/rhodes.png +0 -0
- data/res/icons/rhosim.icns +0 -0
- data/res/icons/rhosim.ico +0 -0
- data/res/icons/rhosim.png +0 -0
- data/res/libs/motorolalicence/android/MotorolaLicence.h +2 -1
- data/res/libs/motorolalicence/android/libMotorolaLicence.a +0 -0
- data/res/libs/motorolalicence/iphone/MotorolaLicence.h +2 -1
- data/res/libs/motorolalicence/iphone/libMotorolaLicence.a +0 -0
- data/spec/autocomplete_generator/Rakefile +37 -0
- data/spec/autocomplete_generator/app/Generator/controller.rb +40 -0
- data/spec/autocomplete_generator/app/Generator/generator.rb +236 -0
- data/spec/autocomplete_generator/app/Generator/index.erb +21 -0
- data/spec/autocomplete_generator/app/Settings/controller.rb +117 -0
- data/spec/autocomplete_generator/app/Settings/err_sync.erb +11 -0
- data/spec/autocomplete_generator/app/Settings/home.bb.erb +18 -0
- data/spec/autocomplete_generator/app/Settings/home.erb +19 -0
- data/spec/autocomplete_generator/app/Settings/index.bb.erb +31 -0
- data/spec/autocomplete_generator/app/Settings/index.erb +31 -0
- data/spec/autocomplete_generator/app/Settings/login.bb.erb +29 -0
- data/spec/autocomplete_generator/app/Settings/login.erb +25 -0
- data/spec/autocomplete_generator/app/Settings/reset.bb.erb +16 -0
- data/spec/autocomplete_generator/app/Settings/reset.erb +14 -0
- data/spec/autocomplete_generator/app/Settings/wait.bb.erb +10 -0
- data/spec/autocomplete_generator/app/Settings/wait.erb +10 -0
- data/spec/autocomplete_generator/app/application.rb +16 -0
- data/spec/autocomplete_generator/app/helpers/application_helper.rb +129 -0
- data/spec/autocomplete_generator/app/helpers/browser_helper.rb +22 -0
- data/spec/autocomplete_generator/app/index.bb.erb +21 -0
- data/spec/autocomplete_generator/app/index.erb +24 -0
- data/spec/autocomplete_generator/app/layout.erb +94 -0
- data/spec/autocomplete_generator/app/loading.html +11 -0
- data/spec/autocomplete_generator/build.yml +41 -0
- data/spec/autocomplete_generator/icon/icon.ico +0 -0
- data/spec/autocomplete_generator/icon/icon.png +0 -0
- data/spec/autocomplete_generator/icon/icon.svg +5334 -0
- data/spec/autocomplete_generator/icon/icon114.png +0 -0
- data/spec/autocomplete_generator/icon/icon57.png +0 -0
- data/spec/autocomplete_generator/icon/icon72.png +0 -0
- data/spec/autocomplete_generator/readme.txt +1 -0
- data/spec/autocomplete_generator/rhoconfig.txt +88 -0
- data/spec/autocomplete_generator/rhosimulator/Databases/Databases.db +0 -0
- data/spec/autocomplete_generator/rhosimulator/WebpageIcons.db +0 -0
- data/spec/autocomplete_generator/rhosimulator/db/syncdbuser.sqlite +0 -0
- data/spec/autocomplete_generator/rhosimulator/db/syncdbuser.sqlite.version +1 -0
- data/spec/autocomplete_generator/rhosimulator/rholog.txt_pos +1 -0
- data/spec/autocomplete_generator/rhosimulator/rhosimconfig.txt +8 -0
- data/spec/framework_spec/app/spec/rhomobile/NetHttp_spec.rb +22 -0
- data/spec/framework_spec/app/spec_runner.rb +12 -0
- data/spec/framework_spec/icon/icon.ico +0 -0
- data/spec/framework_spec/icon/icon.png +0 -0
- data/spec/perfomance_spec/icon/icon.ico +0 -0
- data/spec/perfomance_spec/icon/icon.png +0 -0
- data/spec/phone_spec/app/BlobBulkTest/blob_bulk_test.png +0 -0
- data/spec/phone_spec/app/BlobBulkTest_s/blob_bulk_test_s.png +0 -0
- data/spec/phone_spec/app/PartialTest/_index_partial.erb +5 -0
- data/spec/phone_spec/app/PartialTest/_index_partial_nested.erb +2 -0
- data/spec/phone_spec/app/PartialTest/index.erb +6 -0
- data/spec/phone_spec/app/spec/blob_bulksync_spec.rb +5 -3
- data/spec/phone_spec/app/spec/bulksync_spec.rb +33 -41
- data/spec/phone_spec/app/spec/database_spec.rb +5 -0
- data/spec/phone_spec/app/spec/json_spec.rb +50 -50
- data/spec/phone_spec/app/spec/rho_controller_spec.rb +29 -0
- data/spec/phone_spec/app/spec/syncengine_spec.rb +184 -47
- data/spec/phone_spec/app/spec_runner.rb +3 -2
- data/spec/phone_spec/icon/icon.ico +0 -0
- data/spec/phone_spec/icon/icon.png +0 -0
- data/spec/phone_spec/rhoconfig.txt +2 -0
- data/version +1 -1
- metadata +339 -47
- data/platform/android/Rhodes/PushReceiver.erb +0 -14
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushReceiver.java +0 -126
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushService.java +0 -83
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/Config.java +0 -246
- data/platform/bb/rhodes/src/com/rho/rubyext/PNGEncoder.java +0 -613
- data/res/icons/rho.psd +0 -0
- data/res/icons/rhodes.psd +0 -0
- data/res/icons/rhosim.psd +0 -0
@@ -318,8 +318,9 @@ public class NetRequest
|
|
318
318
|
static String szMultipartContType =
|
319
319
|
"multipart/form-data; boundary=----------A6174410D6AD474183FDE48F5662FCC5";
|
320
320
|
|
321
|
-
|
321
|
+
int processMultipartItems( Vector/*Ptr<CMultipartItem*>&*/ arItems )throws Exception
|
322
322
|
{
|
323
|
+
int nSize = 0;
|
323
324
|
for( int i = 0; i < (int)arItems.size(); i++ )
|
324
325
|
{
|
325
326
|
MultipartItem oItem = (MultipartItem)arItems.elementAt(i);
|
@@ -373,8 +374,13 @@ public class NetRequest
|
|
373
374
|
oItem.m_strDataPrefix += "Content-Length: " + nContentSize + "\r\n";
|
374
375
|
|
375
376
|
oItem.m_strDataPrefix += "\r\n";
|
377
|
+
|
378
|
+
nSize += oItem.m_strDataPrefix.length() + nContentSize;
|
376
379
|
}
|
377
380
|
|
381
|
+
nSize += szMultipartPostfix.length();
|
382
|
+
|
383
|
+
return nSize;
|
378
384
|
}
|
379
385
|
|
380
386
|
public NetResponse pushMultipartData(String strUrl, Vector/*Ptr<CMultipartItem*>&*/ arItems, IRhoSession oSession, Hashtable/*<String,String>**/ headers)throws Exception
|
@@ -402,7 +408,8 @@ public class NetRequest
|
|
402
408
|
m_connection.setRequestMethod(IHttpConnection.POST);
|
403
409
|
|
404
410
|
//PUSH specific
|
405
|
-
processMultipartItems( arItems );
|
411
|
+
int nContentSize = processMultipartItems( arItems );
|
412
|
+
m_connection.setRequestProperty("content-length", Integer.toString(nContentSize) );
|
406
413
|
os = m_connection.openOutputStream();
|
407
414
|
//write all items
|
408
415
|
for( int i = 0; i < (int)arItems.size(); i++ )
|
@@ -371,7 +371,14 @@ public class RhoConnection implements IHttpConnection {
|
|
371
371
|
public InputStream openInputStream() throws IOException {
|
372
372
|
LOG.TRACE("openInputStream");
|
373
373
|
processRequest();
|
374
|
-
|
374
|
+
|
375
|
+
if ( responseData != null )
|
376
|
+
return responseData;
|
377
|
+
|
378
|
+
if ( m_isDispatchCall )
|
379
|
+
return null;
|
380
|
+
|
381
|
+
throw new IOException("Not found: " + url_external);
|
375
382
|
}
|
376
383
|
|
377
384
|
public DataOutputStream openDataOutputStream() throws IOException {
|
@@ -508,12 +515,9 @@ public class RhoConnection implements IHttpConnection {
|
|
508
515
|
|
509
516
|
protected boolean httpGetIndexFile(){
|
510
517
|
String strIndex = null;
|
511
|
-
String slash = "";
|
512
|
-
if ( uri.getPath()!=null && uri.getPath().length() > 0 )
|
513
|
-
slash = uri.getPath().charAt(uri.getPath().length()-1) == '/' ? "" : "/";
|
514
518
|
|
515
519
|
for( int i = 0; i < m_arIndexes.length; i++ ){
|
516
|
-
String name = uri.getPath()
|
520
|
+
String name = FilePath.join( URI.urlDecode(uri.getPath()), m_arIndexes[i] );
|
517
521
|
String nameClass = name;
|
518
522
|
if ( nameClass.endsWith(".iseq"))
|
519
523
|
nameClass = nameClass.substring(0, nameClass.length()-5);
|
@@ -558,7 +562,7 @@ public class RhoConnection implements IHttpConnection {
|
|
558
562
|
|
559
563
|
protected boolean httpServeFile(String strContType)throws IOException
|
560
564
|
{
|
561
|
-
String strPath = uri.getPath();
|
565
|
+
String strPath = URI.urlDecode(uri.getPath());
|
562
566
|
//if ( !strPath.startsWith("/apps") )
|
563
567
|
// strPath = "/apps" + strPath;
|
564
568
|
|
@@ -638,19 +642,20 @@ public class RhoConnection implements IHttpConnection {
|
|
638
642
|
|
639
643
|
protected boolean httpGetFile(String strContType)throws IOException
|
640
644
|
{
|
641
|
-
|
645
|
+
String strPath = URI.urlDecode(uri.getPath());
|
646
|
+
if ( !isDbFilesPath(strPath) && !isKnownExtension(strPath) && strContType.length() == 0 )
|
642
647
|
{
|
643
|
-
String strTemp = FilePath.join(
|
648
|
+
String strTemp = FilePath.join(strPath, "/");
|
644
649
|
|
645
650
|
if( RhoSupport.findClass(strTemp + "controller") != null )
|
646
651
|
return false;
|
647
652
|
|
648
|
-
int nPos = findIndex(
|
653
|
+
int nPos = findIndex(strPath);
|
649
654
|
if ( nPos >= 0 )
|
650
655
|
{
|
651
|
-
String url =
|
656
|
+
String url = strPath;// + (nPos == 0 ? ".iseq" : "");
|
652
657
|
Properties reqHash = new Properties();
|
653
|
-
|
658
|
+
doDispatch(reqHash, url);
|
654
659
|
// RubyValue res = RhoRuby.processIndexRequest(url);//erb-compiled should load from class
|
655
660
|
//processResponse(res);
|
656
661
|
|
@@ -63,7 +63,7 @@ public class ClientRegister extends RhoThread
|
|
63
63
|
|
64
64
|
public void startUp()
|
65
65
|
{
|
66
|
-
if ( RhoConf.getInstance().getString("syncserver").length() > 0 )
|
66
|
+
if ( com.rho.Capabilities.ENABLE_PUSH && RhoConf.getInstance().getString("syncserver").length() > 0 )
|
67
67
|
{
|
68
68
|
start(epLow);
|
69
69
|
stopWait();
|
@@ -102,7 +102,8 @@ public class ClientRegister extends RhoThread
|
|
102
102
|
int port = RhoConf.getInstance().getInt("push_port");
|
103
103
|
|
104
104
|
return SyncThread.getSyncEngine().getProtocol().getClientRegisterBody( strClientID, m_strDevicePin,
|
105
|
-
port > 0 ? port : DEFAULT_PUSH_PORT, m_sysInfo.getPlatform()
|
105
|
+
port > 0 ? port : DEFAULT_PUSH_PORT, m_sysInfo.getPlatform(),
|
106
|
+
isPushServiceEnabled() ? "bis" : "" );
|
106
107
|
}
|
107
108
|
|
108
109
|
private boolean doRegister( SyncEngine oSync )throws Exception
|
@@ -147,5 +148,26 @@ public class ClientRegister extends RhoThread
|
|
147
148
|
}
|
148
149
|
|
149
150
|
return false;
|
150
|
-
}
|
151
|
+
}
|
152
|
+
|
153
|
+
public static boolean isMDSPushEnabled()
|
154
|
+
{
|
155
|
+
if ( !RhoConf.getInstance().isExist("push_options") )
|
156
|
+
return true;
|
157
|
+
|
158
|
+
String strOptions = RhoConf.getInstance().getString("push_options");
|
159
|
+
|
160
|
+
return strOptions.indexOf("mds") >= 0;
|
161
|
+
}
|
162
|
+
|
163
|
+
public static boolean isPushServiceEnabled()
|
164
|
+
{
|
165
|
+
if ( !RhoConf.getInstance().isExist("push_options") )
|
166
|
+
return false;
|
167
|
+
|
168
|
+
String strOptions = RhoConf.getInstance().getString("push_options");
|
169
|
+
|
170
|
+
return strOptions.indexOf("push_service") >= 0;
|
171
|
+
}
|
172
|
+
|
151
173
|
}
|
@@ -35,7 +35,7 @@ public interface ISyncProtocol
|
|
35
35
|
public abstract String getClientCreateUrl();
|
36
36
|
|
37
37
|
public abstract String getClientRegisterUrl();
|
38
|
-
public abstract String getClientRegisterBody( String strClientID, String strPin, int nPort, String strType );
|
38
|
+
public abstract String getClientRegisterBody( String strClientID, String strPin, int nPort, String strType, String strPushType );
|
39
39
|
|
40
40
|
public abstract String getClientResetUrl(String strClientID);
|
41
41
|
public abstract String getClientChangesUrl();
|
@@ -50,7 +50,9 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
50
50
|
RhoConf RHOCONF(){ return RhoConf.getInstance(); }
|
51
51
|
|
52
52
|
public static final int esNone = 0, esSyncAllSources = 1, esSyncSource = 2, esSearch=3, esStop = 4, esExit = 5;
|
53
|
-
|
53
|
+
public static final int ebsNotSynced = 0, ebsSynced = 1, ebsLoadBlobs = 2;
|
54
|
+
//public static final String RHO_SETTING_BULKSYNC_STATE = "bulksync_state";
|
55
|
+
|
54
56
|
static class SourceID
|
55
57
|
{
|
56
58
|
String m_strName = "";
|
@@ -116,6 +118,22 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
116
118
|
return strValue.compareTo("1") == 0 || strValue.compareTo("true") == 0 ? true : false;
|
117
119
|
|
118
120
|
}
|
121
|
+
|
122
|
+
public int getIntProperty(Integer nSrcID, String szPropName)
|
123
|
+
{
|
124
|
+
String strValue = getProperty(nSrcID, szPropName);
|
125
|
+
|
126
|
+
return strValue != null && strValue.length() > 0 ? Integer.valueOf(strValue).intValue() : 0;
|
127
|
+
}
|
128
|
+
|
129
|
+
void clearProperties()
|
130
|
+
{
|
131
|
+
synchronized(m_mxSrcOptions)
|
132
|
+
{
|
133
|
+
m_hashSrcOptions.clear();
|
134
|
+
}
|
135
|
+
}
|
136
|
+
|
119
137
|
};
|
120
138
|
|
121
139
|
Vector/*<SyncSource*>*/ m_sources = new Vector();
|
@@ -252,7 +270,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
252
270
|
stopSync();
|
253
271
|
}
|
254
272
|
|
255
|
-
void doSyncAllSources(String strQueryParams)
|
273
|
+
void doSyncAllSources(String strQueryParams, boolean bSyncOnlyChangedSources)
|
256
274
|
{
|
257
275
|
try
|
258
276
|
{
|
@@ -268,7 +286,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
268
286
|
PROF.CREATE_COUNTER("Pull");
|
269
287
|
PROF.START("Sync");
|
270
288
|
|
271
|
-
syncAllSources(strQueryParams);
|
289
|
+
syncAllSources(strQueryParams, bSyncOnlyChangedSources);
|
272
290
|
|
273
291
|
PROF.DESTROY_COUNTER("Net");
|
274
292
|
PROF.DESTROY_COUNTER("Parse");
|
@@ -351,7 +369,10 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
351
369
|
|
352
370
|
String szData = null;
|
353
371
|
if ( strTestResp != null && strTestResp.length() > 0 )
|
372
|
+
{
|
354
373
|
szData = strTestResp;
|
374
|
+
getNotify().setFakeServerResponse(true);
|
375
|
+
}
|
355
376
|
else
|
356
377
|
szData = resp.getCharData();
|
357
378
|
|
@@ -409,15 +430,6 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
409
430
|
pSrc.processServerResponse_ver3(oSrcArr);
|
410
431
|
|
411
432
|
nSearchCount += pSrc.getCurPageCount();
|
412
|
-
|
413
|
-
if ( pSrc.getServerError().length() > 0 )
|
414
|
-
{
|
415
|
-
if ( m_strServerError.length() > 0 )
|
416
|
-
m_strServerError += "&";
|
417
|
-
|
418
|
-
m_strServerError += pSrc.getServerError();
|
419
|
-
m_nErrCode = pSrc.getErrorCode();
|
420
|
-
}
|
421
433
|
}
|
422
434
|
|
423
435
|
if ( nSearchCount == 0 )
|
@@ -430,6 +442,9 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
430
442
|
}
|
431
443
|
break;
|
432
444
|
}
|
445
|
+
|
446
|
+
if ( strTestResp!= null && strTestResp.length() > 0 )
|
447
|
+
break;
|
433
448
|
}
|
434
449
|
|
435
450
|
getNotify().fireAllSyncNotifications(true, m_nErrCode, m_strError, m_strServerError);
|
@@ -655,7 +670,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
655
670
|
else
|
656
671
|
getUserDB().executeSQL("INSERT INTO client_info (client_id) values (?)", clientID);
|
657
672
|
|
658
|
-
if ( ClientRegister.getInstance() != null )
|
673
|
+
if ( clientID != null && clientID.length() > 0 && ClientRegister.getInstance() != null )
|
659
674
|
ClientRegister.getInstance().startUp();
|
660
675
|
|
661
676
|
}else if ( bResetClient )
|
@@ -741,30 +756,98 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
741
756
|
if ( !RhoConf.getInstance().isExist("bulksync_state") )
|
742
757
|
return;
|
743
758
|
|
744
|
-
int nBulkSyncState =
|
745
|
-
|
746
|
-
|
747
|
-
|
748
|
-
LOG.INFO("Bulk sync: start");
|
749
|
-
getNotify().fireBulkSyncNotification(false, "start", "", RhoAppAdapter.ERR_NONE);
|
759
|
+
int nBulkSyncState = RHOCONF().getInt("bulksync_state");
|
760
|
+
if ( !isContinueSync() ) {
|
761
|
+
return;
|
762
|
+
}
|
750
763
|
|
751
|
-
|
752
|
-
|
753
|
-
|
754
|
-
|
764
|
+
switch (nBulkSyncState) {
|
765
|
+
case ebsNotSynced:
|
766
|
+
loadBulkPartitions();
|
767
|
+
|
768
|
+
if ( !isContinueSync() ) {
|
769
|
+
return;
|
770
|
+
}
|
771
|
+
|
772
|
+
//no break here is intentional.
|
773
|
+
case ebsLoadBlobs:
|
774
|
+
if ( !processBlobs() ) {
|
775
|
+
return;
|
776
|
+
}
|
777
|
+
break;
|
778
|
+
|
779
|
+
default:
|
780
|
+
return;
|
781
|
+
}
|
782
|
+
|
755
783
|
if (isContinueSync())
|
756
784
|
{
|
757
|
-
|
758
|
-
|
785
|
+
RHOCONF().setInt("bulksync_state", ebsSynced, true);
|
786
|
+
getNotify().fireBulkSyncNotification(true, "complete", "", RhoAppAdapter.ERR_NONE);
|
759
787
|
}
|
760
788
|
}
|
761
789
|
|
790
|
+
void loadBulkPartitions()throws Exception
|
791
|
+
{
|
792
|
+
LOG.INFO( "Bulk sync: start" );
|
793
|
+
getNotify().fireBulkSyncNotification(false, "start", "", RhoAppAdapter.ERR_NONE);
|
794
|
+
Vector/*<String>*/ arPartNames = DBAdapter.getDBAllPartitionNames();
|
795
|
+
|
796
|
+
for (int i = 0; i < (int)arPartNames.size() && isContinueSync(); i++)
|
797
|
+
{
|
798
|
+
if ( ((String)arPartNames.elementAt(i)).compareTo("local") !=0 )
|
799
|
+
loadBulkPartition( (String)arPartNames.elementAt(i) );
|
800
|
+
}
|
801
|
+
}
|
802
|
+
|
803
|
+
boolean processBlobs()throws Exception
|
804
|
+
{
|
805
|
+
LOG.INFO("Bulk sync: download BLOBs");
|
806
|
+
|
807
|
+
RHOCONF().setInt("bulksync_state", ebsLoadBlobs, true );
|
808
|
+
getNotify().fireBulkSyncNotification( false, "blobs", "", RhoAppAdapter.ERR_NONE);
|
809
|
+
|
810
|
+
LOG.TRACE( "=== Processing server blob attributes ===" );
|
811
|
+
|
812
|
+
for ( int i = 0; i < (int)m_sources.size(); ++i )
|
813
|
+
{
|
814
|
+
SyncSource src = (SyncSource)m_sources.elementAt(i);
|
815
|
+
if ( !src.processServerBlobAttrs() ) {
|
816
|
+
getNotify().fireBulkSyncNotification(false, "error", "", RhoAppAdapter.ERR_UNEXPECTEDSERVERRESPONSE);
|
817
|
+
return false;
|
818
|
+
}
|
819
|
+
}
|
820
|
+
|
821
|
+
LOG.TRACE( "=== Processing server blob attributes DONE ===" );
|
822
|
+
|
823
|
+
DBAdapter.initAttrManager();
|
824
|
+
|
825
|
+
for ( int i = 0; i < (int)m_sources.size(); ++i )
|
826
|
+
{
|
827
|
+
SyncSource src = (SyncSource)m_sources.elementAt(i);
|
828
|
+
if (!src.processAllBlobs()) {
|
829
|
+
getNotify().fireBulkSyncNotification(false, "error", "", RhoAppAdapter.ERR_UNEXPECTEDSERVERRESPONSE);
|
830
|
+
return false;
|
831
|
+
}
|
832
|
+
}
|
833
|
+
|
834
|
+
return true;
|
835
|
+
}
|
836
|
+
|
762
837
|
void loadBulkPartition(String strPartition )throws Exception
|
763
838
|
{
|
764
839
|
DBAdapter dbPartition = getDB(strPartition);
|
765
840
|
String serverUrl = RhoConf.getInstance().getPath("syncserver");
|
766
841
|
String strUrl = serverUrl + "bulk_data";
|
767
|
-
String strQuery = "?client_id=" + m_clientID + "&partition=" + strPartition;
|
842
|
+
String strQuery = "?client_id=" + m_clientID + "&partition=" + strPartition + "&sources=";
|
843
|
+
for ( int i = 0; i < (int)m_sources.size(); ++i )
|
844
|
+
{
|
845
|
+
strQuery += URI.urlEncode( ((SyncSource)m_sources.elementAt(i)).getName() );
|
846
|
+
if ( i < (int)m_sources.size()-1 ) {
|
847
|
+
strQuery += ",";
|
848
|
+
}
|
849
|
+
}
|
850
|
+
|
768
851
|
String strDataUrl = "", strCmd = "";
|
769
852
|
|
770
853
|
getNotify().fireBulkSyncNotification(false, "start", strPartition, RhoAppAdapter.ERR_NONE);
|
@@ -802,7 +885,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
802
885
|
if ( strCmd.compareTo("nop") == 0)
|
803
886
|
{
|
804
887
|
LOG.INFO("Bulk sync return no data.");
|
805
|
-
getNotify().fireBulkSyncNotification(true, "", strPartition, RhoAppAdapter.ERR_NONE);
|
888
|
+
getNotify().fireBulkSyncNotification(true, "ok", strPartition, RhoAppAdapter.ERR_NONE);
|
806
889
|
return;
|
807
890
|
}
|
808
891
|
|
@@ -846,10 +929,11 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
846
929
|
getNotify().fireBulkSyncNotification(false, "change_db", strPartition, RhoAppAdapter.ERR_NONE);
|
847
930
|
|
848
931
|
dbPartition.setBulkSyncDB(fDataName, fScriptName);
|
932
|
+
getSourceOptions().clearProperties();
|
849
933
|
processServerSources("{\"partition\":\"" + strPartition + "\"}");
|
850
934
|
|
851
935
|
LOG.INFO("Bulk sync: end change db");
|
852
|
-
getNotify().fireBulkSyncNotification(false, "", strPartition, RhoAppAdapter.ERR_NONE);
|
936
|
+
getNotify().fireBulkSyncNotification(false, "ok", strPartition, RhoAppAdapter.ERR_NONE);
|
853
937
|
}
|
854
938
|
|
855
939
|
void downloadBulkDataAndUnzip(String strDataUrl, String fDataName, String strPartition)throws Exception
|
@@ -915,7 +999,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
915
999
|
return -1;
|
916
1000
|
}
|
917
1001
|
*/
|
918
|
-
void syncOneSource(int i, String strQueryParams)throws Exception
|
1002
|
+
void syncOneSource(int i, String strQueryParams, boolean syncOnlyIfChanged)throws Exception
|
919
1003
|
{
|
920
1004
|
SyncSource src = null;
|
921
1005
|
//boolean bError = false;
|
@@ -927,7 +1011,13 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
927
1011
|
if ( isSessionExist() && getState() != esStop )
|
928
1012
|
{
|
929
1013
|
src.m_strQueryParams = strQueryParams;
|
930
|
-
|
1014
|
+
if (syncOnlyIfChanged) {
|
1015
|
+
if (src.haveChangedValues() ) {
|
1016
|
+
src.sync();
|
1017
|
+
}
|
1018
|
+
} else {
|
1019
|
+
src.sync();
|
1020
|
+
}
|
931
1021
|
}
|
932
1022
|
|
933
1023
|
//getNotify().onSyncSourceEnd(i, m_sources);
|
@@ -947,7 +1037,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
947
1037
|
//return !bError;
|
948
1038
|
}
|
949
1039
|
|
950
|
-
void syncAllSources(String strQueryParams)throws Exception
|
1040
|
+
void syncAllSources(String strQueryParams, boolean bSyncOnlyChangedSources)throws Exception
|
951
1041
|
{
|
952
1042
|
// boolean bError = false;
|
953
1043
|
|
@@ -958,7 +1048,7 @@ public class SyncEngine implements NetRequest.IRhoSession
|
|
958
1048
|
//TODO: do not stop on error source
|
959
1049
|
for( int i = 0; i < (int)m_sources.size() && isContinueSync(); i++ )
|
960
1050
|
{
|
961
|
-
/*bError = !*/syncOneSource(i, strQueryParams);
|
1051
|
+
/*bError = !*/syncOneSource(i, strQueryParams, bSyncOnlyChangedSources);
|
962
1052
|
}
|
963
1053
|
|
964
1054
|
if ( !isSchemaChanged() && getState() != SyncEngine.esStop )
|
@@ -60,6 +60,11 @@ public class SyncNotify {
|
|
60
60
|
m_strParams = strParams;
|
61
61
|
m_bRemoveAfterFire = bRemoveAfterFire;
|
62
62
|
}
|
63
|
+
|
64
|
+
public String toString()
|
65
|
+
{
|
66
|
+
return "Url: " + m_strUrl + ";Params:" + m_strParams + ";RemoveAfterFire: " + m_bRemoveAfterFire;
|
67
|
+
}
|
63
68
|
};
|
64
69
|
|
65
70
|
public static final Integer enNone = new Integer(0), enDelete=new Integer(1), enUpdate=new Integer(2), enCreate=new Integer(3);
|
@@ -83,18 +88,22 @@ public class SyncNotify {
|
|
83
88
|
ISyncStatusListener m_syncStatusListener = null;
|
84
89
|
boolean m_bEnableReporting = false;
|
85
90
|
boolean m_bEnableReportingGlobal = true;
|
86
|
-
String
|
91
|
+
Vector/*<String>*/ m_arNotifyBody = new Vector();
|
92
|
+
boolean m_bFakeServerResponse = false;
|
93
|
+
boolean m_isInsideCallback = false;
|
87
94
|
NetRequest m_NetRequest;
|
88
95
|
|
89
96
|
SyncEngine getSync(){ return m_syncEngine; }
|
90
97
|
NetRequest getNet() { return m_NetRequest;}
|
91
98
|
|
92
|
-
|
93
|
-
|
99
|
+
void cleanNotifyBody(){ m_arNotifyBody.removeAllElements(); setFakeServerResponse(false); }
|
100
|
+
boolean isFakeServerResponse(){ return m_bFakeServerResponse; }
|
101
|
+
void setFakeServerResponse(boolean bFakeServerResponse){ m_bFakeServerResponse = bFakeServerResponse; }
|
94
102
|
|
95
103
|
boolean isReportingEnabled(){return m_bEnableReporting&&m_bEnableReportingGlobal;}
|
96
104
|
void enableReporting(boolean bEnable) { m_bEnableReporting = bEnable; }
|
97
105
|
void enableStatusPopup(boolean bEnable){m_bEnableReportingGlobal = bEnable;}
|
106
|
+
boolean isInsideCallback() { return m_isInsideCallback; }
|
98
107
|
|
99
108
|
SyncNotify( SyncEngine syncEngine )
|
100
109
|
{
|
@@ -486,6 +495,11 @@ public class SyncNotify {
|
|
486
495
|
return pSN != null ? pSN : m_emptyNotify;
|
487
496
|
}
|
488
497
|
|
498
|
+
void fireSyncNotification2( SyncSource src, boolean bFinish, int nErrCode, String strServerError)
|
499
|
+
{
|
500
|
+
doFireSyncNotification(src, bFinish, nErrCode, "", "", strServerError);
|
501
|
+
}
|
502
|
+
|
489
503
|
void doFireSyncNotification( SyncSource src, boolean bFinish, int nErrCode, String strError, String strParams, String strServerError )
|
490
504
|
{
|
491
505
|
if ( getSync().isStoppedByUser() )
|
@@ -559,13 +573,6 @@ public class SyncNotify {
|
|
559
573
|
|
560
574
|
strBody += "&" + strServerError;
|
561
575
|
}
|
562
|
-
else if ( src != null && src.m_strServerError != null && src.m_strServerError.length() > 0 )
|
563
|
-
{
|
564
|
-
if ( src.m_strServerError.length() > MAX_SERVER_ERROR_LEN )
|
565
|
-
src.m_strServerError = src.m_strServerError.substring(0, MAX_SERVER_ERROR_LEN);
|
566
|
-
|
567
|
-
strBody += "&" + src.m_strServerError;
|
568
|
-
}
|
569
576
|
}
|
570
577
|
|
571
578
|
if ( src != null )
|
@@ -589,7 +596,7 @@ public class SyncNotify {
|
|
589
596
|
if ( bRemoveAfterFire )
|
590
597
|
clearNotification(src);
|
591
598
|
|
592
|
-
LOG.INFO("Fire notification. Source : " + (src != null ? (src).getName():"") + "; " + pSN.toString());
|
599
|
+
LOG.INFO("Fire notification. Source : " + (src != null ? (src).getName():"") + "; " + pSN.toString() + ";Body: " + strBody);
|
593
600
|
|
594
601
|
if ( callNotify(pSN, strBody) )
|
595
602
|
clearNotification(src);
|
@@ -599,18 +606,41 @@ public class SyncNotify {
|
|
599
606
|
}
|
600
607
|
}
|
601
608
|
|
609
|
+
String getNotifyBody()
|
610
|
+
{
|
611
|
+
String emptyBody = "";
|
612
|
+
if ( m_arNotifyBody.size() == 0 )
|
613
|
+
return emptyBody;
|
614
|
+
|
615
|
+
if ( isFakeServerResponse() )
|
616
|
+
return (String)m_arNotifyBody.elementAt(0);
|
617
|
+
|
618
|
+
return (String)m_arNotifyBody.elementAt(m_arNotifyBody.size()-1);
|
619
|
+
}
|
620
|
+
|
602
621
|
boolean callNotify(SyncNotification oNotify, String strBody )throws Exception
|
603
622
|
{
|
623
|
+
String strUrl = new String(oNotify.m_strUrl); //Need to copy url since notify may be cleared in callback
|
624
|
+
|
604
625
|
if ( getSync().isNoThreadedMode() )
|
605
626
|
{
|
606
|
-
|
627
|
+
m_arNotifyBody.addElement( strBody );
|
607
628
|
return false;
|
608
629
|
}
|
609
630
|
|
610
|
-
if (
|
631
|
+
if ( strUrl.length() == 0 )
|
611
632
|
return true;
|
633
|
+
|
634
|
+
if ( strUrl.startsWith("javascript:") )
|
635
|
+
{
|
636
|
+
String js = strUrl.substring(11) + "('" + strBody + "');";
|
637
|
+
RhoClassFactory.createRhoRubyHelper().webview_execute_js(js);
|
638
|
+
return true;
|
639
|
+
}
|
612
640
|
|
613
|
-
|
641
|
+
m_isInsideCallback = true;
|
642
|
+
NetResponse resp = getNet().pushData( strUrl, strBody, null );
|
643
|
+
m_isInsideCallback = false;
|
614
644
|
if ( !resp.isOK() )
|
615
645
|
LOG.ERROR( "Fire object notification failed. Code: " + resp.getRespCode() + "; Error body: " + resp.getCharData() );
|
616
646
|
else
|