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
@@ -29,12 +29,14 @@
|
|
29
29
|
|
30
30
|
#include "logging/RhoLog.h"
|
31
31
|
#include "common/RhoThread.h"
|
32
|
+
#include "common/RhoStd.h"
|
32
33
|
#include "net/INetRequest.h"
|
33
34
|
#include "common/IRhoClassFactory.h"
|
34
35
|
|
35
36
|
namespace rho{
|
36
37
|
namespace sync{
|
37
38
|
|
39
|
+
class ILoginListener;
|
38
40
|
class CSyncEngine;
|
39
41
|
|
40
42
|
#define WAIT_BEFOREKILL_SECONDS 3
|
@@ -42,33 +44,44 @@ class CSyncEngine;
|
|
42
44
|
#define POLL_INTERVAL_INFINITE (unsigned int)(-1)
|
43
45
|
#define DEFAULT_PUSH_PORT 100
|
44
46
|
|
45
|
-
class CClientRegister :
|
47
|
+
class CClientRegister : protected common::CRhoThread
|
46
48
|
{
|
47
49
|
DEFINE_LOGCLASS;
|
48
50
|
|
49
|
-
|
50
|
-
|
51
|
-
|
51
|
+
static CClientRegister* m_pInstance;
|
52
|
+
static bool s_sslVerifyPeer;
|
53
|
+
static VectorPtr<ILoginListener*> s_loginListeners;
|
54
|
+
|
55
|
+
NetRequest m_NetRequest;
|
56
|
+
String m_strDevicePin;
|
52
57
|
unsigned int m_nPollInterval;
|
53
|
-
bool m_isAns;
|
54
58
|
public:
|
55
|
-
static
|
59
|
+
static void SetSslVerifyPeer(boolean b);
|
60
|
+
static void AddLoginListener(ILoginListener* listener);
|
61
|
+
static CClientRegister* Get();
|
62
|
+
static CClientRegister* Create();
|
63
|
+
static CClientRegister* Create(const String& devicePin);
|
64
|
+
static void Stop();
|
56
65
|
static void Destroy();
|
57
|
-
|
58
|
-
|
59
|
-
virtual void run();
|
66
|
+
static CClientRegister* getInstance() { return m_pInstance; }
|
60
67
|
|
61
|
-
const String&
|
62
|
-
|
63
|
-
|
68
|
+
void setRhoconnectCredentials(const String& user, const String& pass, const String& session);
|
69
|
+
void dropRhoconnectCredentials(const String& session);
|
70
|
+
void setDevicehPin(const String& pin);
|
71
|
+
const String& getDevicePin() const { return m_strDevicePin; }
|
64
72
|
|
65
73
|
void startUp();
|
66
74
|
|
67
|
-
|
75
|
+
protected:
|
76
|
+
virtual void run();
|
77
|
+
|
68
78
|
private:
|
69
|
-
|
79
|
+
String getRegisterBody(const String& strClientID);
|
80
|
+
|
81
|
+
CClientRegister();
|
70
82
|
~CClientRegister();
|
71
83
|
|
84
|
+
void doStop();
|
72
85
|
boolean doRegister(CSyncEngine& oSync);
|
73
86
|
net::CNetRequestWrapper getNet(){ return getNetRequest(&m_NetRequest); }
|
74
87
|
|
@@ -83,8 +96,6 @@ extern "C" {
|
|
83
96
|
#endif //__cplusplus
|
84
97
|
|
85
98
|
void rho_clientregister_create(const char* szDevicePin);
|
86
|
-
void rho_clientansregister_create(const char* szDevicePin);
|
87
|
-
void rho_clientregister_destroy();
|
88
99
|
|
89
100
|
#ifdef __cplusplus
|
90
101
|
};
|
@@ -0,0 +1,44 @@
|
|
1
|
+
/*------------------------------------------------------------------------
|
2
|
+
* (The MIT License)
|
3
|
+
*
|
4
|
+
* Copyright (c) 2008-2011 Rhomobile, Inc.
|
5
|
+
*
|
6
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
7
|
+
* of this software and associated documentation files (the "Software"), to deal
|
8
|
+
* in the Software without restriction, including without limitation the rights
|
9
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
10
|
+
* copies of the Software, and to permit persons to whom the Software is
|
11
|
+
* furnished to do so, subject to the following conditions:
|
12
|
+
*
|
13
|
+
* The above copyright notice and this permission notice shall be included in
|
14
|
+
* all copies or substantial portions of the Software.
|
15
|
+
*
|
16
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
17
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
18
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
19
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
20
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
21
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
22
|
+
* THE SOFTWARE.
|
23
|
+
*
|
24
|
+
* http://rhomobile.com
|
25
|
+
*------------------------------------------------------------------------*/
|
26
|
+
|
27
|
+
#pragma once
|
28
|
+
|
29
|
+
#include "common/RhoStd.h"
|
30
|
+
|
31
|
+
namespace rho {
|
32
|
+
namespace sync {
|
33
|
+
|
34
|
+
class CSyncEngine;
|
35
|
+
|
36
|
+
class ILoginListener {
|
37
|
+
public:
|
38
|
+
virtual ~ILoginListener() {}
|
39
|
+
virtual void onLogin(const String& user, const String& pass, const String& session) const = 0;
|
40
|
+
virtual void onLogout(const String& session) const = 0;
|
41
|
+
};
|
42
|
+
|
43
|
+
|
44
|
+
}}
|
@@ -76,8 +76,7 @@ void CSyncEngine::setSslVerifyPeer(boolean b)
|
|
76
76
|
m_NetRequest.setSslVerifyPeer(b);
|
77
77
|
m_NetRequestClientID.setSslVerifyPeer(b);
|
78
78
|
|
79
|
-
|
80
|
-
CClientRegister::getInstance()->setSslVerifyPeer(b);
|
79
|
+
CClientRegister::SetSslVerifyPeer(b);
|
81
80
|
}
|
82
81
|
|
83
82
|
void CSyncEngine::CSourceOptions::setProperty(int nSrcID, const char* szPropName, const char* szPropValue)
|
@@ -125,7 +124,15 @@ int CSyncEngine::CSourceOptions::getIntProperty(int nSrcID, const char* szPropNa
|
|
125
124
|
|
126
125
|
return strValue.length() ? atoi(strValue.c_str()) : 0;
|
127
126
|
}
|
128
|
-
|
127
|
+
|
128
|
+
void CSyncEngine::CSourceOptions::clearProperties()
|
129
|
+
{
|
130
|
+
synchronized(m_mxSrcOptions)
|
131
|
+
{
|
132
|
+
m_hashSrcOptions.clear();
|
133
|
+
}
|
134
|
+
}
|
135
|
+
|
129
136
|
void CSyncEngine::prepareSync(ESyncState eState, const CSourceID* oSrcID)
|
130
137
|
{
|
131
138
|
setState(eState);
|
@@ -169,7 +176,7 @@ void CSyncEngine::prepareSync(ESyncState eState, const CSourceID* oSrcID)
|
|
169
176
|
stopSync();
|
170
177
|
}
|
171
178
|
|
172
|
-
void CSyncEngine::doSyncAllSources(const String& strQueryParams)
|
179
|
+
void CSyncEngine::doSyncAllSources(const String& strQueryParams, boolean bSyncOnlyChangedSources)
|
173
180
|
{
|
174
181
|
prepareSync(esSyncAllSources, null);
|
175
182
|
|
@@ -183,7 +190,7 @@ void CSyncEngine::doSyncAllSources(const String& strQueryParams)
|
|
183
190
|
PROF_CREATE_COUNTER("Pull");
|
184
191
|
PROF_START("Sync");
|
185
192
|
|
186
|
-
syncAllSources(strQueryParams);
|
193
|
+
syncAllSources(strQueryParams, bSyncOnlyChangedSources);
|
187
194
|
|
188
195
|
PROF_DESTROY_COUNTER("Net");
|
189
196
|
PROF_DESTROY_COUNTER("Parse");
|
@@ -548,9 +555,6 @@ String CSyncEngine::loadClientID()
|
|
548
555
|
else
|
549
556
|
getUserDB().executeSQL("INSERT INTO client_info (client_id) values (?)", clientID);
|
550
557
|
|
551
|
-
if ( CClientRegister::getInstance() != null )
|
552
|
-
CClientRegister::getInstance()->startUp();
|
553
|
-
|
554
558
|
}else if ( bResetClient )
|
555
559
|
{
|
556
560
|
if ( !resetClientIDByNet(clientID) )
|
@@ -710,13 +714,24 @@ void CSyncEngine::loadBulkPartition(const String& strPartition )
|
|
710
714
|
db::CDBAdapter& dbPartition = getDB(strPartition);
|
711
715
|
String serverUrl = RHOCONF().getPath("syncserver");
|
712
716
|
String strUrl = serverUrl + "bulk_data";
|
713
|
-
|
717
|
+
|
718
|
+
//old code
|
719
|
+
String strQuery = "?client_id=" + m_clientID + "&partition=" + strPartition + "&sources=";
|
714
720
|
for ( int i = 0; i < (int)m_sources.size(); ++i ) {
|
715
721
|
strQuery += URI::urlEncode(m_sources[i]->getName());
|
716
722
|
if ( i < (int)m_sources.size()-1 ) {
|
717
723
|
strQuery += ",";
|
718
724
|
}
|
719
725
|
}
|
726
|
+
|
727
|
+
//new code
|
728
|
+
/*
|
729
|
+
String strQuery = "?client_id=" + m_clientID + "&partition=" + strPartition;
|
730
|
+
for ( int i = 0; i < (int)m_sources.size(); ++i ) {
|
731
|
+
strQuery += "&sources[]=";
|
732
|
+
strQuery += URI::urlEncode(m_sources[i]->getName());
|
733
|
+
}
|
734
|
+
*/
|
720
735
|
String strDataUrl = "", strCmd = "", strCryptKey = "";
|
721
736
|
|
722
737
|
getNotify().fireBulkSyncNotification(false, "start", strPartition, RhoAppAdapter.ERR_NONE);
|
@@ -798,6 +813,7 @@ void CSyncEngine::loadBulkPartition(const String& strPartition )
|
|
798
813
|
getNotify().fireBulkSyncNotification(false, "change_db", strPartition, RhoAppAdapter.ERR_NONE);
|
799
814
|
|
800
815
|
dbPartition.setBulkSyncDB(fDataName, strCryptKey);
|
816
|
+
getSourceOptions().clearProperties();
|
801
817
|
processServerSources(String("{\"partition\":\"") + strPartition + "\"}");
|
802
818
|
|
803
819
|
LOG(INFO) + "Bulk sync: end change db";
|
@@ -838,7 +854,7 @@ int CSyncEngine::getStartSource()
|
|
838
854
|
return -1;
|
839
855
|
}*/
|
840
856
|
|
841
|
-
void CSyncEngine::syncOneSource(int i, const String& strQueryParams)
|
857
|
+
void CSyncEngine::syncOneSource(int i, const String& strQueryParams, boolean syncOnlyIfChanged)
|
842
858
|
{
|
843
859
|
CSyncSource& src = *m_sources.elementAt(i);
|
844
860
|
if ( src.getSyncType().compare("bulk_sync_only")==0 )
|
@@ -847,7 +863,13 @@ void CSyncEngine::syncOneSource(int i, const String& strQueryParams)
|
|
847
863
|
if ( isSessionExist() && getState() != esStop )
|
848
864
|
{
|
849
865
|
src.m_strQueryParams = strQueryParams;
|
850
|
-
|
866
|
+
if (syncOnlyIfChanged) {
|
867
|
+
if (src.haveChangedValues() ) {
|
868
|
+
src.sync();
|
869
|
+
}
|
870
|
+
} else {
|
871
|
+
src.sync();
|
872
|
+
}
|
851
873
|
}
|
852
874
|
|
853
875
|
getNotify().onSyncSourceEnd(i, m_sources);
|
@@ -855,7 +877,7 @@ void CSyncEngine::syncOneSource(int i, const String& strQueryParams)
|
|
855
877
|
// return src.m_nErrCode == RhoAppAdapter.ERR_NONE;
|
856
878
|
}
|
857
879
|
|
858
|
-
void CSyncEngine::syncAllSources(const String& strQueryParams)
|
880
|
+
void CSyncEngine::syncAllSources(const String& strQueryParams, boolean bSyncOnlyChangedSources)
|
859
881
|
{
|
860
882
|
// boolean bError = false;
|
861
883
|
|
@@ -865,7 +887,7 @@ void CSyncEngine::syncAllSources(const String& strQueryParams)
|
|
865
887
|
|
866
888
|
for( int i = 0; i < (int)m_sources.size() && isContinueSync(); i++ )
|
867
889
|
{
|
868
|
-
/*bError = !*/syncOneSource(i, strQueryParams);
|
890
|
+
/*bError = !*/syncOneSource(i, strQueryParams, bSyncOnlyChangedSources);
|
869
891
|
}
|
870
892
|
|
871
893
|
if ( !isSchemaChanged() && getState() != CSyncEngine::esStop )
|
@@ -942,11 +964,9 @@ void CSyncEngine::login(String name, String password, const CSyncNotification& o
|
|
942
964
|
|
943
965
|
PROF_STOP("Login");
|
944
966
|
|
945
|
-
|
946
|
-
|
947
|
-
|
948
|
-
CClientRegister::getInstance()->startUp();
|
949
|
-
}
|
967
|
+
getUserDB().executeSQL("UPDATE client_info SET token_sent=?", 0 );
|
968
|
+
CClientRegister::Get()->setRhoconnectCredentials(name, password, strSession);
|
969
|
+
|
950
970
|
//}catch(Exception exc)
|
951
971
|
//{
|
952
972
|
// LOG.ERROR("Login failed.", exc);
|
@@ -966,17 +986,23 @@ boolean CSyncEngine::isLoggedIn()
|
|
966
986
|
|
967
987
|
String CSyncEngine::loadSession()
|
968
988
|
{
|
969
|
-
|
970
|
-
|
989
|
+
synchronized(m_mxSessionID)
|
990
|
+
{
|
991
|
+
m_strSession = "";
|
992
|
+
IDBResult res = getUserDB().executeSQL("SELECT session FROM client_info");
|
971
993
|
|
972
|
-
|
973
|
-
|
994
|
+
if ( !res.isEnd() )
|
995
|
+
m_strSession = res.getStringByIdx(0);
|
974
996
|
|
975
|
-
|
997
|
+
return m_strSession;
|
998
|
+
}
|
976
999
|
}
|
977
1000
|
|
978
1001
|
void CSyncEngine::logout_int()
|
979
1002
|
{
|
1003
|
+
CClientRegister::Get()->dropRhoconnectCredentials(m_strSession);
|
1004
|
+
//CClientRegister::Destroy();
|
1005
|
+
|
980
1006
|
getUserDB().executeSQL( "UPDATE client_info SET session=NULL" );
|
981
1007
|
m_strSession = "";
|
982
1008
|
|
@@ -988,7 +1014,7 @@ void CSyncEngine::logout()
|
|
988
1014
|
stopSync();
|
989
1015
|
logout_int();
|
990
1016
|
}
|
991
|
-
|
1017
|
+
|
992
1018
|
void CSyncEngine::setSyncServer(const char* syncserver)
|
993
1019
|
{
|
994
1020
|
String strOldSrv = RHOCONF().getString("syncserver");
|
@@ -68,6 +68,7 @@ public:
|
|
68
68
|
String getProperty(int nSrcID, const char* szPropName);
|
69
69
|
boolean getBoolProperty(int nSrcID, const char* szPropName);
|
70
70
|
int getIntProperty(int nSrcID, const char* szPropName);
|
71
|
+
void clearProperties();
|
71
72
|
};
|
72
73
|
|
73
74
|
private:
|
@@ -76,7 +77,7 @@ private:
|
|
76
77
|
common::CAutoPtr<ISyncProtocol> m_SyncProtocol;
|
77
78
|
ESyncState m_syncState;
|
78
79
|
String m_clientID;
|
79
|
-
common::CMutex m_mxLoadClientID;
|
80
|
+
common::CMutex m_mxLoadClientID, m_mxSessionID;
|
80
81
|
String m_strSession;
|
81
82
|
CSyncNotify m_oSyncNotify;
|
82
83
|
boolean m_bStopByUser;
|
@@ -96,7 +97,7 @@ public:
|
|
96
97
|
static CSourceOptions& getSourceOptions(){ return m_oSourceOptions; }
|
97
98
|
net::CNetRequestWrapper getNet(){ return getNetRequest(&m_NetRequest); }
|
98
99
|
|
99
|
-
void doSyncAllSources(const String& strQueryParams);
|
100
|
+
void doSyncAllSources(const String& strQueryParams, boolean bSyncOnlyChangedSources);
|
100
101
|
void doSyncSource(const CSourceID& oSrcID, const String& strQueryParams);
|
101
102
|
void doSearch(rho::Vector<rho::String>& arSources, String strParams, String strAction, boolean bSearchSyncChanges, int nProgressStep);
|
102
103
|
|
@@ -127,7 +128,12 @@ public:
|
|
127
128
|
void setSchemaChanged(boolean bChanged){ m_bIsSchemaChanged = bChanged; }
|
128
129
|
boolean isSchemaChanged(){ return m_bIsSchemaChanged; }
|
129
130
|
//IRhoSession
|
130
|
-
virtual const String& getSession()
|
131
|
+
virtual const String& getSession()
|
132
|
+
{
|
133
|
+
synchronized(m_mxSessionID){
|
134
|
+
return m_strSession;
|
135
|
+
}
|
136
|
+
}
|
131
137
|
virtual const String& getContentType(){ return getProtocol().getContentType();}
|
132
138
|
|
133
139
|
void loadAllSources();
|
@@ -166,8 +172,8 @@ private:
|
|
166
172
|
void processServerSources(String strSources);
|
167
173
|
void checkSourceAssociations();
|
168
174
|
|
169
|
-
void syncOneSource(int i, const String& strQueryParams);
|
170
|
-
void syncAllSources(const String& strQueryParams);
|
175
|
+
void syncOneSource(int i, const String& strQueryParams, boolean bSyncOnlyIfChanged);
|
176
|
+
void syncAllSources(const String& strQueryParams, boolean bSyncOnlyChangedSources);
|
171
177
|
|
172
178
|
boolean processBlobs();
|
173
179
|
void loadBulkPartitions();
|
@@ -150,9 +150,10 @@ void CSyncSource::sync()
|
|
150
150
|
// {
|
151
151
|
if ( isEmptyToken() )
|
152
152
|
processToken(1);
|
153
|
+
|
154
|
+
syncClientChanges();
|
155
|
+
syncServerChanges();
|
153
156
|
|
154
|
-
syncClientChanges();
|
155
|
-
syncServerChanges();
|
156
157
|
/*
|
157
158
|
boolean bSyncedServer = syncClientChanges();
|
158
159
|
if ( !bSyncedServer )
|
@@ -180,11 +181,8 @@ void CSyncSource::syncClientChanges()
|
|
180
181
|
{
|
181
182
|
PROF_START("Pull");
|
182
183
|
|
183
|
-
boolean bSyncClient =
|
184
|
-
|
185
|
-
IDBResult res = getDB().executeSQL("SELECT object FROM changed_values WHERE source_id=? and sent<=1 LIMIT 1 OFFSET 0", getID());
|
186
|
-
bSyncClient = !res.isEnd();
|
187
|
-
}
|
184
|
+
boolean bSyncClient = haveChangedValues();
|
185
|
+
|
188
186
|
if ( bSyncClient )
|
189
187
|
doSyncClientChanges();
|
190
188
|
|
@@ -351,7 +349,7 @@ void CSyncSource::doSyncClientChanges()
|
|
351
349
|
{
|
352
350
|
LOG(INFO) + "Push client changes to server. Source: " + getName() + "Size :" + strBody.length();
|
353
351
|
if ( !RHOCONF().getBool("log_skip_post") )
|
354
|
-
LOG(
|
352
|
+
LOG(TRACE) + "Push body: " + strBody;
|
355
353
|
|
356
354
|
if ( getSync().getSourceOptions().getBoolProperty(getID(), "set_sync_push_body" ) )
|
357
355
|
getSync().getSourceOptions().setProperty(getID(), "sync_push_body", strBody.c_str() );
|
@@ -870,7 +868,7 @@ void CSyncSource::processSyncCommand(const String& strCmd, CJSONEntry oCmdEntry,
|
|
870
868
|
String strObject = objIter.getCurKey();
|
871
869
|
CJSONStructIterator attrIter( objIter.getCurValue() );
|
872
870
|
if ( m_bSchemaSource )
|
873
|
-
processServerCmd_Ver3_Schema(strCmd,strObject,attrIter);
|
871
|
+
processServerCmd_Ver3_Schema(strCmd,strObject,attrIter,bCheckUIRequest);
|
874
872
|
else
|
875
873
|
{
|
876
874
|
for( ; !attrIter.isEnd(); attrIter.next() )
|
@@ -878,7 +876,7 @@ void CSyncSource::processSyncCommand(const String& strCmd, CJSONEntry oCmdEntry,
|
|
878
876
|
String strAttrib = attrIter.getCurKey();
|
879
877
|
String strValue = attrIter.getCurString();
|
880
878
|
|
881
|
-
processServerCmd_Ver3(strCmd,strObject,strAttrib,strValue);
|
879
|
+
processServerCmd_Ver3(strCmd,strObject,strAttrib,strValue,bCheckUIRequest);
|
882
880
|
}
|
883
881
|
}
|
884
882
|
|
@@ -947,7 +945,7 @@ void CSyncSource::updateAssociation(const String& strOldObject, const String& st
|
|
947
945
|
strNewObject, strAttrib, getID(), strOldObject );
|
948
946
|
}
|
949
947
|
|
950
|
-
void CSyncSource::processServerCmd_Ver3_Schema(const String& strCmd, const String& strObject, CJSONStructIterator& attrIter)//throws Exception
|
948
|
+
void CSyncSource::processServerCmd_Ver3_Schema(const String& strCmd, const String& strObject, CJSONStructIterator& attrIter, boolean bCheckUIRequest)//throws Exception
|
951
949
|
{
|
952
950
|
if ( strCmd.compare("insert") == 0 )
|
953
951
|
{
|
@@ -957,13 +955,9 @@ void CSyncSource::processServerCmd_Ver3_Schema(const String& strCmd, const Strin
|
|
957
955
|
{
|
958
956
|
CAttrValue oAttrValue(attrIter.getCurKey(),attrIter.getCurString());
|
959
957
|
|
960
|
-
|
961
|
-
|
962
|
-
|
963
|
-
LOG(INFO) + "Skip Non-exist property : " + oAttrValue.m_strAttrib + ". For model : " + getName();
|
964
|
-
continue;
|
965
|
-
}
|
966
|
-
|
958
|
+
if ( bCheckUIRequest && !checkFreezedProps(oAttrValue.m_strAttrib))
|
959
|
+
continue;
|
960
|
+
|
967
961
|
if ( !processBlob(strCmd,strObject,oAttrValue) )
|
968
962
|
break;
|
969
963
|
|
@@ -1140,20 +1134,17 @@ boolean CSyncSource::processServerBlobAttrs() {
|
|
1140
1134
|
if ( m_bSchemaSource ) {
|
1141
1135
|
return true;
|
1142
1136
|
} else {
|
1143
|
-
static const String selAttrsRequest = "SELECT source_attribs,blob_attribs from sources WHERE source_id=?";
|
1144
|
-
static const String updAttrsRequest = "UPDATE sources SET source_attribs=?,blob_attribs=? WHERE source_id=?";
|
1145
|
-
static const String updObjectsRequest = "UPDATE object_values SET attrib=? WHERE attrib=? and source_id=?";
|
1146
1137
|
static const String blobSfx = "-rhoblob";
|
1147
1138
|
|
1148
|
-
|
1149
|
-
|
1150
|
-
IDBResult res = db.executeSQL(selAttrsRequest.c_str(),getID());
|
1139
|
+
getDB().startTransaction();
|
1140
|
+
IDBResult res = getDB().executeSQL( "SELECT source_attribs,blob_attribs from sources WHERE source_id=?", getID() );
|
1151
1141
|
|
1152
1142
|
Vector<String> attrsToRename;
|
1153
1143
|
|
1154
1144
|
String newAttrs = "";
|
1155
1145
|
|
1156
|
-
for ( ; !res.isEnd(); res.next() )
|
1146
|
+
for ( ; !res.isEnd(); res.next() )
|
1147
|
+
{
|
1157
1148
|
String attrs = res.getStringByIdx(0);
|
1158
1149
|
String blobs = res.getStringByIdx(1);
|
1159
1150
|
|
@@ -1166,12 +1157,12 @@ boolean CSyncSource::processServerBlobAttrs() {
|
|
1166
1157
|
String attrVal = tokenizer.nextToken();
|
1167
1158
|
|
1168
1159
|
|
1169
|
-
if ( String_endsWith(attrName, blobSfx
|
1160
|
+
if ( String_endsWith( attrName, blobSfx ) ) {
|
1170
1161
|
if ( blobs.length() > 0 ) {
|
1171
1162
|
blobs += ",";
|
1172
1163
|
}
|
1173
1164
|
blobs += attrName.substr(0,attrName.length()-blobSfx.length()) + "," + attrVal;
|
1174
|
-
attrsToRename.
|
1165
|
+
attrsToRename.addElement(attrName);
|
1175
1166
|
} else {
|
1176
1167
|
if (newAttrs.length() > 0 ) {
|
1177
1168
|
newAttrs += ",";
|
@@ -1182,32 +1173,35 @@ boolean CSyncSource::processServerBlobAttrs() {
|
|
1182
1173
|
|
1183
1174
|
LOG(TRACE) + "Updating attributes for source " + getName() + ". Old attribs=" + attrs + ", new attribs=" + newAttrs + ", blob attribs=" + blobs;
|
1184
1175
|
|
1185
|
-
|
1176
|
+
getDB().executeSQL("UPDATE sources SET source_attribs=?,blob_attribs=? WHERE source_id=?", newAttrs, blobs, getID() );
|
1186
1177
|
}
|
1187
1178
|
|
1188
|
-
for (
|
1189
|
-
|
1190
|
-
|
1179
|
+
for ( int i = 0; i < (int)attrsToRename.size(); i++ )
|
1180
|
+
{
|
1181
|
+
String strAttr = (String)attrsToRename.elementAt(i);
|
1182
|
+
LOG(TRACE) + "Updating objects with blob attribute " + strAttr + " for source " + getName();
|
1183
|
+
getDB().executeSQL( "UPDATE object_values SET attrib=? WHERE attrib=? and source_id=?", strAttr.substr( 0, strAttr.length()-blobSfx.length()), strAttr, getID() );
|
1191
1184
|
}
|
1192
|
-
|
1193
|
-
|
1185
|
+
|
1186
|
+
getDB().endTransaction();
|
1194
1187
|
}
|
1195
1188
|
return true;
|
1196
1189
|
}
|
1197
1190
|
|
1198
1191
|
|
1199
|
-
boolean CSyncSource::processAllBlobs()
|
1200
|
-
|
1192
|
+
boolean CSyncSource::processAllBlobs()
|
1193
|
+
{
|
1201
1194
|
if (m_bSchemaSource) {
|
1202
|
-
|
1203
|
-
|
1204
|
-
|
1205
|
-
|
1206
|
-
String
|
1195
|
+
Vector<String> blobAttrs = getDB().getAttrMgr().getBlobAttrs( getID() );
|
1196
|
+
|
1197
|
+
for ( int i = 0; i < (int)blobAttrs.size(); i ++ )
|
1198
|
+
{
|
1199
|
+
String strAttr = (String)blobAttrs.elementAt(i);
|
1200
|
+
String sql = "SELECT object," + strAttr + " FROM " + getName();
|
1207
1201
|
|
1208
|
-
IDBResult res =
|
1202
|
+
IDBResult res = getDB().executeSQL( sql.c_str() );
|
1209
1203
|
|
1210
|
-
LOG(TRACE) + "Processing blobs for source " + getName() + ", attribute " +
|
1204
|
+
LOG(TRACE) + "Processing blobs for source " + getName() + ", attribute " + strAttr;
|
1211
1205
|
|
1212
1206
|
for ( ; !res.isEnd(); res.next() )
|
1213
1207
|
{
|
@@ -1216,26 +1210,26 @@ boolean CSyncSource::processAllBlobs() {
|
|
1216
1210
|
|
1217
1211
|
if ( value.find("://") != String::npos ) {
|
1218
1212
|
LOG(TRACE) + "Processing remote blob: " + value;
|
1219
|
-
CAttrValue attr(
|
1213
|
+
CAttrValue attr( strAttr, value );
|
1220
1214
|
if ( !downloadBlob( attr ) ) {
|
1221
1215
|
return false;
|
1222
1216
|
}
|
1223
1217
|
|
1224
|
-
sql = "UPDATE " + getName() + " SET " +
|
1218
|
+
sql = "UPDATE " + getName() + " SET " + strAttr + "=? WHERE object=?";
|
1225
1219
|
|
1226
|
-
|
1220
|
+
getDB().executeSQL( sql.c_str(), attr.m_strValue, object );
|
1227
1221
|
}
|
1228
1222
|
}
|
1229
1223
|
}
|
1230
1224
|
} else {
|
1231
|
-
|
1232
|
-
Vector<String> blobAttrs = db.getAttrMgr().getBlobAttrs( getID() );
|
1225
|
+
Vector<String> blobAttrs = getDB().getAttrMgr().getBlobAttrs( getID() );
|
1233
1226
|
|
1234
|
-
for (
|
1235
|
-
|
1236
|
-
|
1227
|
+
for ( int i = 0; i < (int)blobAttrs.size(); i ++ )
|
1228
|
+
{
|
1229
|
+
String strAttr = (String)blobAttrs.elementAt(i);
|
1230
|
+
IDBResult res = getDB().executeSQL("SELECT object,value FROM object_values WHERE attrib=? and source_id=?", strAttr, getID());
|
1237
1231
|
|
1238
|
-
LOG(TRACE) + "Processing blobs for source " + getName() + ", attribute " +
|
1232
|
+
LOG(TRACE) + "Processing blobs for source " + getName() + ", attribute " + strAttr;
|
1239
1233
|
|
1240
1234
|
for ( ; !res.isEnd(); res.next() )
|
1241
1235
|
{
|
@@ -1244,12 +1238,12 @@ boolean CSyncSource::processAllBlobs() {
|
|
1244
1238
|
|
1245
1239
|
if ( value.find("://") != String::npos ) {
|
1246
1240
|
LOG(TRACE) + "Processing remote blob: " + value;
|
1247
|
-
CAttrValue attr(
|
1241
|
+
CAttrValue attr( strAttr, value );
|
1248
1242
|
if ( !downloadBlob( attr ) ) {
|
1249
1243
|
return false;
|
1250
1244
|
}
|
1251
1245
|
|
1252
|
-
|
1246
|
+
getDB().executeSQL("UPDATE object_values SET value=? where object=? and source_id=? and attrib=?", attr.m_strValue, object, getID(), strAttr);
|
1253
1247
|
}
|
1254
1248
|
}
|
1255
1249
|
}
|
@@ -1258,18 +1252,44 @@ boolean CSyncSource::processAllBlobs() {
|
|
1258
1252
|
return true;
|
1259
1253
|
}
|
1260
1254
|
|
1261
|
-
|
1255
|
+
boolean CSyncSource::checkFreezedProps(String strProp)
|
1256
|
+
{
|
1257
|
+
String strFreezedProps = getSync().getSourceOptions().getProperty(getID(), "freezed");
|
1258
|
+
|
1259
|
+
if ( strFreezedProps.length() > 0 )
|
1260
|
+
{
|
1261
|
+
CTokenizer oTokenizer( strFreezedProps, "," );
|
1262
|
+
boolean bFound =false;
|
1263
|
+
while (oTokenizer.hasMoreTokens() && (!bFound) )
|
1264
|
+
{
|
1265
|
+
String tok = oTokenizer.nextToken();
|
1266
|
+
if (tok.length() == 0)
|
1267
|
+
continue;
|
1268
|
+
|
1269
|
+
if (tok.compare(strProp)==0)
|
1270
|
+
{
|
1271
|
+
bFound = true;
|
1272
|
+
}
|
1273
|
+
}
|
1274
|
+
|
1275
|
+
if (!bFound)
|
1276
|
+
{
|
1277
|
+
LOG(INFO) + "Skip Non-exist property : " + strProp + ". For model : " + getName();
|
1278
|
+
return false;
|
1279
|
+
}
|
1280
|
+
}
|
1281
|
+
|
1282
|
+
return true;
|
1283
|
+
}
|
1284
|
+
|
1285
|
+
void CSyncSource::processServerCmd_Ver3(const String& strCmd, const String& strObject, const String& strAttriba, const String& strValuea, boolean bCheckUIRequest)//throws Exception
|
1262
1286
|
{
|
1263
1287
|
CAttrValue oAttrValue(strAttriba,strValuea);
|
1264
1288
|
|
1265
1289
|
if ( strCmd.compare("insert") == 0 )
|
1266
1290
|
{
|
1267
|
-
|
1268
|
-
|
1269
|
-
{
|
1270
|
-
LOG(INFO) + "Skip Non-exist property : " + oAttrValue.m_strAttrib + ". For model : " + getName();
|
1271
|
-
return;
|
1272
|
-
}
|
1291
|
+
if ( bCheckUIRequest && !checkFreezedProps(oAttrValue.m_strAttrib))
|
1292
|
+
return;
|
1273
1293
|
|
1274
1294
|
if ( !processBlob(strCmd,strObject,oAttrValue) )
|
1275
1295
|
return;
|
@@ -1304,7 +1324,7 @@ void CSyncSource::processServerCmd_Ver3(const String& strCmd, const String& strO
|
|
1304
1324
|
{
|
1305
1325
|
getNotify().onObjectChanged(getID(), strObject, CSyncNotify::enDelete);
|
1306
1326
|
// oo conflicts
|
1307
|
-
getDB().executeSQL("UPDATE changed_values SET sent=3 where object=? and attrib=? and
|
1327
|
+
getDB().executeSQL("UPDATE changed_values SET sent=3 where object=? and attrib=? and source_id=? and update_type=?", strObject, oAttrValue.m_strAttrib, getID(), "create" );
|
1308
1328
|
//
|
1309
1329
|
}
|
1310
1330
|
|
@@ -1418,5 +1438,11 @@ void CSyncSource::processToken(uint64 token)
|
|
1418
1438
|
|
1419
1439
|
}
|
1420
1440
|
|
1441
|
+
bool CSyncSource::haveChangedValues()
|
1442
|
+
{
|
1443
|
+
IDBResult res = getDB().executeSQL("SELECT object FROM changed_values WHERE source_id=? and sent<=1 LIMIT 1 OFFSET 0", getID());
|
1444
|
+
return !res.isEnd();
|
1445
|
+
}
|
1446
|
+
|
1421
1447
|
}
|
1422
1448
|
}
|