rhodes 2.3.2 → 2.4.0.beta.1
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +18 -0
- data/CREDITS +38 -0
- data/README.md +2 -2
- data/Rakefile +60 -2
- data/bin/set-rhodes-sdk.bat +1 -0
- data/doc/application.txt +11 -0
- data/doc/build.txt +156 -39
- data/doc/configuration.txt +1 -10
- data/doc/connect-to-web-services.txt +6 -6
- data/doc/device-caps.txt +48 -5
- data/doc/extensions.txt +8 -1
- data/doc/rhom.txt +16 -0
- data/doc/synchronization.txt +56 -14
- data/doc/ui.txt +23 -2
- data/installer/instant-rhodes.nsi +6 -6
- data/lib/extensions/barcode/ext/barcode/platform/iphone/Barcode.xcodeproj/project.pbxproj +4 -2
- data/lib/extensions/barcode/ext/barcode/platform/wm/Rakefile +1 -1
- data/lib/extensions/digest-md5/ext/Rakefile +3 -3
- data/lib/extensions/digest-md5/ext/build +0 -1
- data/lib/extensions/digest-sha1/ext/Rakefile +1 -1
- data/lib/extensions/digest-sha1/ext/build +0 -1
- data/lib/extensions/digest/ext/Rakefile +3 -3
- data/lib/extensions/digest/ext/build +0 -1
- data/lib/extensions/fcntl/ext/Rakefile +1 -1
- data/lib/extensions/mspec/mspec/guards/guard.rb +4 -0
- data/lib/extensions/mspec/mspec/helpers/environment.rb +4 -0
- data/lib/extensions/nfc/ext.yml +2 -0
- data/lib/extensions/nfc/ext/build +12 -0
- data/lib/extensions/nfc/ext/build.bat +8 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/AndroidManifest.xml +25 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/Rakefile +94 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/ext_build.files +4 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/jni/src/nfc.cpp +404 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/src/com/nfc/Nfc.java +138 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/src/com/nfc/NfcMessage.java +34 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/src/com/nfc/NfcMessagePack.java +33 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/src/com/nfc/NfcRecord.java +149 -0
- data/lib/extensions/nfc/ext/nfc/shared/ruby/nfc.i +22 -0
- data/lib/extensions/nfc/ext/nfc/shared/ruby/nfc_wrap.c +2034 -0
- data/lib/extensions/nfc/nfc.rb +120 -0
- data/lib/extensions/rholang/{lang_ca.rb → rholang/lang_ca.rb} +0 -0
- data/lib/extensions/rholang/{lang_cf.rb → rholang/lang_cf.rb} +0 -0
- data/lib/extensions/rholang/{lang_chef.rb → rholang/lang_chef.rb} +0 -0
- data/lib/extensions/rholang/{lang_cs.rb → rholang/lang_cs.rb} +0 -0
- data/lib/extensions/rholang/{lang_da.rb → rholang/lang_da.rb} +0 -0
- data/lib/extensions/rholang/{lang_de.rb → rholang/lang_de.rb} +0 -0
- data/lib/extensions/rholang/{lang_es.rb → rholang/lang_es.rb} +0 -0
- data/lib/extensions/rholang/{lang_es_ar.rb → rholang/lang_es_ar.rb} +0 -0
- data/lib/extensions/rholang/{lang_fi.rb → rholang/lang_fi.rb} +0 -0
- data/lib/extensions/rholang/{lang_fr.rb → rholang/lang_fr.rb} +0 -0
- data/lib/extensions/rholang/{lang_it.rb → rholang/lang_it.rb} +0 -0
- data/lib/extensions/rholang/{lang_ko.rb → rholang/lang_ko.rb} +0 -0
- data/lib/extensions/rholang/{lang_nl.rb → rholang/lang_nl.rb} +0 -0
- data/lib/extensions/rholang/{lang_no.rb → rholang/lang_no.rb} +0 -0
- data/lib/extensions/rholang/{lang_pt.rb → rholang/lang_pt.rb} +0 -0
- data/lib/extensions/rholang/{lang_pt_br.rb → rholang/lang_pt_br.rb} +0 -0
- data/lib/extensions/rholang/{lang_ru.rb → rholang/lang_ru.rb} +0 -0
- data/lib/extensions/rholang/{lang_se.rb → rholang/lang_se.rb} +0 -0
- data/lib/extensions/rholang/{lang_sr.rb → rholang/lang_sr.rb} +0 -0
- data/lib/extensions/rholang/{rhoerror_ru.rb → rholang/rhoerror_ru.rb} +0 -0
- data/lib/extensions/rholang/{rhomsg_ru.rb → rholang/rhomsg_ru.rb} +0 -0
- data/lib/framework/date/format.rb +2 -0
- data/lib/framework/dateOrig.rb +17 -8
- data/lib/framework/rational18.rb +532 -0
- data/lib/framework/res/back_btn.wp7.png +0 -0
- data/lib/framework/res/blue_pushpin.wp7.png +0 -0
- data/lib/framework/res/blue_pushpin_small.wp7.png +0 -0
- data/lib/framework/res/callout.wp7.png +0 -0
- data/lib/framework/res/callout_link.wp7.png +0 -0
- data/lib/framework/res/esri.wp7.png +0 -0
- data/lib/framework/res/forward_btn.wp7.png +0 -0
- data/lib/framework/res/home_btn.wp7.png +0 -0
- data/lib/framework/res/options_btn.wp7.png +0 -0
- data/lib/framework/res/refresh_btn.wp7.png +0 -0
- data/lib/framework/rho/render.rb +8 -1
- data/lib/framework/rho/rho.rb +30 -7
- data/lib/framework/rho/rhoapplication.rb +9 -4
- data/lib/framework/rho/rhofsconnector.rb +5 -1
- data/lib/framework/rho/rhotabbar.rb +8 -0
- data/lib/framework/rho/rhotoolbar.rb +1 -1
- data/lib/framework/rho/rhoviewhelpers.rb +18 -1
- data/lib/framework/rhodes.rb +1 -1
- data/lib/framework/rhoframework.rb +46 -1
- data/lib/framework/rholang/localization_simplified.rb +17 -16
- data/lib/framework/rhom/rhom_db_adapter.rb +2 -2
- data/lib/framework/rhom/rhom_object_factory.rb +115 -12
- data/lib/framework/rhosystem.rb +135 -0
- data/lib/framework/version.rb +1 -1
- data/lib/rhodes.rb +1 -1
- data/lib/test/apps/rhoconfig.txt +23 -23
- data/platform/android/Rhodes/AndroidManifest.full.xml +101 -0
- data/platform/android/Rhodes/AndroidManifest.xml +10 -15
- data/platform/android/Rhodes/default.properties +11 -0
- data/platform/android/Rhodes/gen/com/rhomobile/rhodes/R.java +59 -53
- data/platform/android/Rhodes/jni/include/rhodes.h +1 -0
- data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_RhodesApplication.h +21 -0
- data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_alert_PopupActivity.h +21 -0
- data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_file_RhoFileApi.h +10 -2
- data/platform/android/Rhodes/jni/src/alert.cpp +2 -1
- data/platform/android/Rhodes/jni/src/datetimepicker.cpp +2 -0
- data/platform/android/Rhodes/jni/src/fileapi.cpp +671 -84
- data/platform/android/Rhodes/jni/src/nativebar.cpp +18 -0
- data/platform/android/Rhodes/jni/src/rhodes.cpp +92 -1
- data/platform/android/Rhodes/res/values/styles.xml +7 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/BaseActivity.java +35 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/Capabilities.java +12 -13
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/LocalFileProvider.java +130 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/NativeBar.java +6 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushReceiver.java +5 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/PushService.java +6 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhoMenu.java +7 -36
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +43 -20
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +2 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +63 -28
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/Utils.java +2 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java +6 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/alert/Alert.java +19 -282
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/alert/PopupActivity.java +354 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/datetime/DateTimePickerScreen.java +4 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/event/EventStore.java +1 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java +71 -5
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java +107 -37
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +10 -7
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java +156 -56
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java +0 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactAccessorNew.java +40 -32
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/SignatureView.java +1 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/ExternalHttpHandler.java +14 -6
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/LocalFileHandler.java +46 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/MailUriHandler.java +4 -24
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/UriHandler.java +3 -1
- data/platform/android/build/RhodesSRC_build.files +28 -25
- data/platform/android/build/android.rake +230 -54
- data/platform/android/build/androidcommon.rb +1 -1
- data/platform/android/build/librhocommon_build.files +1 -0
- data/platform/bb/Hsqldb/BlackBerry_App_Descriptor.xml +20 -0
- data/platform/bb/Hsqldb/src/com/rho/db/HsqlDBResult.java +1 -5
- data/platform/bb/Hsqldb/src/com/rho/db/HsqlDBStorage.java +6 -1
- data/platform/bb/Hsqldb/src/org/hsqldb/rowio/RowOutputBase.java +1 -1
- data/platform/bb/Hsqldb/src/org/hsqldb/rowio/RowOutputBinary.java +1 -1
- data/platform/bb/RubyVM/BlackBerry_App_Descriptor.xml +20 -0
- data/platform/bb/RubyVM/src/com/rho/IRhoRubyHelper.java +2 -0
- data/platform/bb/RubyVM/src/com/rho/RhoLogOutputSink.java +0 -1
- data/platform/bb/RubyVM/src/com/rho/RhoLogger.java +12 -10
- data/platform/bb/RubyVM/src/com/rho/RhoThread.java +16 -0
- data/platform/bb/RubyVM/src/com/rho/RhoTimer.java +89 -0
- data/platform/bb/RubyVM/src/com/rho/RhodesApp.java +20 -13
- data/platform/bb/RubyVM/src/com/rho/SplashScreen.java +1 -2
- data/platform/bb/RubyVM/src/com/rho/ThreadQueue.java +2 -2
- data/platform/bb/RubyVM/src/com/rho/TimeInterval.java +5 -0
- data/platform/bb/RubyVM/src/com/rho/db/DBAdapter.java +54 -48
- data/platform/bb/RubyVM/src/com/rho/db/IDBResult.java +0 -1
- data/platform/bb/RubyVM/src/com/rho/db/IDBStorage.java +1 -0
- data/platform/bb/RubyVM/src/com/rho/net/AsyncHttp.java +1 -1
- data/platform/bb/RubyVM/src/com/rho/sync/ClientRegister.java +1 -1
- data/platform/bb/RubyVM/src/com/rho/sync/JSONStructIterator.java +1 -1
- data/platform/bb/RubyVM/src/com/rho/sync/SyncEngine.java +16 -8
- data/platform/bb/RubyVM/src/com/rho/sync/SyncNotify.java +2 -2
- data/platform/bb/RubyVM/src/com/rho/sync/SyncSource.java +52 -29
- data/platform/bb/RubyVM/src/com/rho/sync/SyncThread.java +1 -3
- data/platform/bb/build/RubyVM_build.files +1 -0
- data/platform/bb/build/bb.rake +29 -9
- data/platform/bb/rhodes/BlackBerry_App_Descriptor.xml +23 -0
- data/platform/bb/rhodes/platform/5.0/com/rho/RhodesApplicationPlatform.java +1 -1
- data/platform/bb/rhodes/platform/5.0/com/rho/db/SqliteCopyResult.java +0 -4
- data/platform/bb/rhodes/platform/5.0/com/rho/db/SqliteResult.java +13 -20
- data/platform/bb/rhodes/platform/5.0/com/rho/db/SqliteStorage.java +183 -157
- data/platform/bb/rhodes/src/com/rho/RhoRubyHelper.java +22 -0
- data/platform/bb/rhodes/src/com/rho/RhodesApplicationPlatform.java +1 -1
- data/platform/bb/rhodes/src/com/rho/db/SqliteCopyResult.java +0 -4
- data/platform/bb/rhodes/src/com/rho/db/SqliteResult.java +13 -20
- data/platform/bb/rhodes/src/com/rho/db/SqliteStorage.java +183 -157
- data/platform/bb/rhodes/src/com/rho/rubyext/System.java +46 -1
- data/platform/bb/rhodes/src/rhomobile/RhodesApplication.java +8 -1
- data/platform/bb/rhodes/src/rhomobile/camera/CameraFilesListener.java +13 -3
- data/platform/iphone/Classes/AppManager/AppManager.h +5 -1
- data/platform/iphone/Classes/AppManager/AppManager.m +170 -7
- data/platform/iphone/Classes/DateTimePicker.m +14 -1
- data/platform/iphone/Classes/DateTimePickerDelegate.h +2 -0
- data/platform/iphone/Classes/DateTimePickerDelegate.m +36 -2
- data/platform/iphone/Classes/NativeBar.h +1 -0
- data/platform/iphone/Classes/NativeBar.m +15 -3
- data/platform/iphone/Classes/Phonebook/phonebook.m +8 -9
- data/platform/iphone/Classes/Rhodes.m +50 -6
- data/platform/iphone/Classes/SimpleMainView.m +7 -6
- data/platform/iphone/Classes/SplitView/RightViewController.h +3 -1
- data/platform/iphone/Classes/SplitView/RightViewController.m +14 -1
- data/platform/iphone/Classes/TabbedMainView.h +4 -0
- data/platform/iphone/Classes/TabbedMainView.m +43 -26
- data/platform/iphone/Info.plist +1 -1
- data/platform/iphone/RhoLib/RhoLib.xcodeproj/project.pbxproj +4 -0
- data/platform/iphone/curl/curl.xcodeproj/project.pbxproj +3 -3
- data/platform/iphone/rbuild/iphone.rake +168 -119
- data/platform/iphone/rhoextlib/rhoextlib.xcodeproj/project.pbxproj +4 -2
- data/platform/iphone/rhorubylib/rhorubylib.xcodeproj/project.pbxproj +3 -3
- data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +2 -2
- data/platform/iphone/rhosynclib/rhosynclib.xcodeproj/project.pbxproj +3 -3
- data/platform/shared/SyncClient/SyncClient.cpp +20 -8
- data/platform/shared/SyncClient/SyncClient.h +2 -1
- data/platform/shared/common/RhoDefs.h +4 -0
- data/platform/shared/common/RhoPort.h +22 -0
- data/platform/shared/common/RhoStd.h +5 -0
- data/platform/shared/common/RhoTime.cpp +73 -0
- data/platform/shared/common/RhoTime.h +26 -53
- data/platform/shared/common/RhodesApp.cpp +29 -28
- data/platform/shared/common/RhodesApp.h +4 -1
- data/platform/shared/common/StringConverter.h +37 -10
- data/platform/shared/common/app_build_capabilities.h +2 -0
- data/platform/shared/common/rhoparams.cpp +25 -12
- data/platform/shared/common/rhoparams.h +10 -8
- data/platform/shared/db/DBAdapter.cpp +0 -22
- data/platform/shared/json/RJSONTokener.c +15 -23
- data/platform/shared/net/AsyncHttp.cpp +9 -8
- data/platform/shared/net/HttpServer.cpp +61 -19
- data/platform/shared/net/HttpServer.h +2 -0
- data/platform/shared/ruby/ext/datetimepicker/datetimepicker.i +3 -0
- data/platform/shared/ruby/ext/datetimepicker/datetimepicker_wrap.c +151 -402
- data/platform/shared/ruby/ext/nativebar/nativebar.i +3 -0
- data/platform/shared/ruby/ext/nativebar/nativebar_wrap.c +154 -403
- data/platform/shared/ruby/ext/rho/rhoruby.c +4 -0
- data/platform/shared/ruby/ext/rho/rhoruby.h +2 -0
- data/platform/shared/ruby/ext/system/system.i +8 -0
- data/platform/shared/ruby/ext/system/system_wrap.c +80 -5
- data/platform/shared/ruby/file.c +6 -4
- data/platform/shared/ruby/gc.c +1 -1
- data/platform/shared/ruby/linux/ruby/config.h +7 -2
- data/platform/shared/ruby/missing/acosh.c +3 -3
- data/platform/shared/ruby/wince/_time.h +1 -1
- data/platform/shared/ruby/wince/stdlib.c +1 -1
- data/platform/shared/ruby/wince/string_wce.c +2 -2
- data/platform/shared/ruby/wince/sys/timeb.c +1 -0
- data/platform/shared/ruby/wince/time_wce.c +8 -0
- data/platform/shared/ruby/wince/wince.c +7 -7
- data/platform/shared/ruby/wince/wince.h +22 -0
- data/platform/shared/rubyext/System.cpp +19 -1
- data/platform/shared/sqlite/sqlite3.c +18993 -8129
- data/platform/shared/sqlite/sqlite3.h +953 -358
- data/platform/shared/sqlite/sqlite3ext.h +42 -0
- data/platform/shared/sync/SyncEngine.cpp +10 -0
- data/platform/shared/sync/SyncSource.cpp +41 -19
- data/platform/shared/sync/SyncSource.h +1 -1
- data/platform/shared/tcmalloc/rhomem.h +7 -2
- data/platform/shared/tcmalloc/windows/port.h +2 -0
- data/platform/shared/unzip/unzip.cpp +1 -0
- data/platform/shared/xruby/src/com/xruby/compiler/parser/RubyParser.java +11 -1
- data/platform/wm/RhoLib/RhoLib.vcproj +182 -24
- data/platform/wm/build/wm.rake +16 -3
- data/platform/wm/rhodes.sln +106 -113
- data/platform/wm/rhodes/Alert.cpp +6 -7
- data/platform/wm/rhodes/AppManager.cpp +8 -17
- data/platform/wm/rhodes/DateTimePicker.cpp +3 -0
- data/platform/wm/rhodes/DateTimePicker.h +2 -0
- data/platform/wm/rhodes/MainWindow.cpp +36 -16
- data/platform/wm/rhodes/MainWindow.h +6 -3
- data/platform/wm/rhodes/OutlookApp.cpp +3 -3
- data/platform/wm/rhodes/Rhodes.cpp +46 -27
- data/platform/wm/rhodes/Rhodes.rc +16 -3
- data/platform/wm/rhodes/RingtoneManager.cpp +7 -7
- data/platform/wm/rhodes/RingtoneManager.h +1 -1
- data/platform/wm/rhodes/Utils.cpp +2 -1
- data/platform/wm/rhodes/bluetooth/Bluetooth.cpp +1 -13
- data/platform/wm/rhodes/bluetooth/Bluetooth.h +1 -2
- data/platform/wm/rhodes/camera/Camera.cpp +6 -12
- data/platform/wm/rhodes/phonebook/phonebook.cpp +11 -11
- data/platform/wm/rhodes/phonebook/phonebook.h +1 -1
- data/platform/wm/rhodes/resource.h +3 -1
- data/platform/wm/rhodes/rho/net/NetRequestImpl.cpp +7 -5
- data/platform/wm/rhodes/rho/rubyext/GeoLocationImpl.cpp +6 -6
- data/platform/wm/rhodes/rho/rubyext/GeoLocationImpl.h +1 -1
- data/platform/wm/rhodes/rho/rubyext/NativeToolbar.cpp +6 -1
- data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +84 -19
- data/platform/wm/rhodes/rho/rubyext/calendar.cpp +2 -2
- data/platform/wm/rhodes/rhodes.vcproj +316 -73
- data/platform/wm/rhodes/signature/Signature.cpp +336 -6
- data/platform/wm/rhodes/signature/Signature.h +55 -0
- data/platform/wm/rhodes/stdafx.h +7 -4
- data/platform/wm/rubylib/rubylib.vcproj +261 -91
- data/platform/wm/sqlite3/sqlite3.vcproj +223 -69
- data/platform/wm/syncengine/syncengine.vcproj +220 -66
- data/platform/wm/tcmalloc/tcmalloc.vcproj +197 -43
- data/platform/wp7/IronRuby/Languages/Ruby/Ruby/Builtins/ConsoleStream.cs +107 -0
- data/platform/wp7/IronRuby/Languages/Ruby/Ruby/Runtime/Loader.cs +1037 -0
- data/platform/wp7/IronRuby/Languages/Ruby/Ruby/Runtime/RubyUtils.cs +1476 -0
- data/platform/wp7/RhoAppRunner/Program.cs +55 -0
- data/platform/wp7/RhoAppRunner/Properties/AssemblyInfo.cs +36 -0
- data/platform/wp7/RhoAppRunner/RhoAppRunner.csproj +69 -0
- data/platform/wp7/RhoRubyExtGen/GenerateInitializers.cmd +7 -0
- data/platform/wp7/RhoRubyExtGen/Properties/AssemblyInfo.cs +36 -0
- data/platform/wp7/RhoRubyExtGen/RhoAsyncHttp.cs +38 -0
- data/platform/wp7/RhoRubyExtGen/RhoDatabase.cs +93 -0
- data/platform/wp7/RhoRubyExtGen/RhoJSON.cs +37 -0
- data/platform/wp7/RhoRubyExtGen/RhoNativeBar.cs +106 -0
- data/platform/wp7/RhoRubyExtGen/RhoRubyExtGen.csproj +75 -0
- data/platform/wp7/RhoRubyExtGen/RhoSyncEngine.cs +123 -0
- data/platform/wp7/RhoRubyExtGen/RhoWebView.cs +42 -0
- data/platform/wp7/RhoRubyLib/Initializers.Generated.cs +309 -0
- data/platform/wp7/RhoRubyLib/Properties/AssemblyInfo.cs +36 -0
- data/platform/wp7/RhoRubyLib/RhoAppAdapter.cs +96 -0
- data/platform/wp7/RhoRubyLib/RhoRuby.cs +296 -0
- data/platform/wp7/RhoRubyLib/RhoRubyLib.csproj +155 -0
- data/platform/wp7/RhoRubyLib/WP_PlatformAdaptationLayer.cs +107 -0
- data/platform/wp7/RhoRubyLib/common/IInputStream.cs +21 -0
- data/platform/wp7/RhoRubyLib/common/Mutex.cs +30 -0
- data/platform/wp7/RhoRubyLib/common/RhoConf.cs +389 -0
- data/platform/wp7/RhoRubyLib/common/RhoEmptyProfiler.cs +27 -0
- data/platform/wp7/RhoRubyLib/common/RhoFile.cs +332 -0
- data/platform/wp7/RhoRubyLib/common/RhoFilePath.cs +89 -0
- data/platform/wp7/RhoRubyLib/common/RhoParamArray.cs +33 -0
- data/platform/wp7/RhoRubyLib/common/RhoParams.cs +66 -0
- data/platform/wp7/RhoRubyLib/common/RhoProfiler.cs +145 -0
- data/platform/wp7/RhoRubyLib/common/RhoResourceMap.cs +68 -0
- data/platform/wp7/RhoRubyLib/common/RhoStd.cs +205 -0
- data/platform/wp7/RhoRubyLib/common/RhoThread.cs +114 -0
- data/platform/wp7/RhoRubyLib/common/RhodesApp.cs +504 -0
- data/platform/wp7/RhoRubyLib/common/ThreadQueue.cs +199 -0
- data/platform/wp7/RhoRubyLib/common/TimeInterval.cs +56 -0
- data/platform/wp7/RhoRubyLib/common/Tokenizer.cs +52 -0
- data/platform/wp7/RhoRubyLib/db/DBAdapter.cs +1129 -0
- data/platform/wp7/RhoRubyLib/db/DBAttrManager.cs +92 -0
- data/platform/wp7/RhoRubyLib/db/DBException.cs +35 -0
- data/platform/wp7/RhoRubyLib/db/IDBCallback.cs +10 -0
- data/platform/wp7/RhoRubyLib/db/IDBResult.cs +33 -0
- data/platform/wp7/RhoRubyLib/db/IDBStorage.cs +32 -0
- data/platform/wp7/RhoRubyLib/db/SqliteCopyResult.cs +79 -0
- data/platform/wp7/RhoRubyLib/db/SqliteResult.cs +267 -0
- data/platform/wp7/RhoRubyLib/db/SqliteStorage.cs +319 -0
- data/platform/wp7/RhoRubyLib/json/JSONArrayIterator.cs +63 -0
- data/platform/wp7/RhoRubyLib/json/JSONEntry.cs +96 -0
- data/platform/wp7/RhoRubyLib/json/JSONStructIterator.cs +77 -0
- data/platform/wp7/RhoRubyLib/json/JsonParser.cs +483 -0
- data/platform/wp7/RhoRubyLib/json/RJSONTokener.cs +406 -0
- data/platform/wp7/RhoRubyLib/logging/IRhoLogSink.cs +12 -0
- data/platform/wp7/RhoRubyLib/logging/RhoLogConf.cs +161 -0
- data/platform/wp7/RhoRubyLib/logging/RhoLogFileSink.cs +174 -0
- data/platform/wp7/RhoRubyLib/logging/RhoLogger.cs +320 -0
- data/platform/wp7/RhoRubyLib/net/AsyncHttp.cs +362 -0
- data/platform/wp7/RhoRubyLib/net/HttpServer.cs +466 -0
- data/platform/wp7/RhoRubyLib/net/NetRequest.cs +717 -0
- data/platform/wp7/RhoRubyLib/net/NetResponse.cs +64 -0
- data/platform/wp7/RhoRubyLib/net/URI.cs +187 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoAsyncHttp.cs +43 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoDatabase.cs +177 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoJSON.cs +39 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoKernelOps.cs +19 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoNativeBar.cs +117 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoSyncEngine.cs +199 -0
- data/platform/wp7/RhoRubyLib/rubyext/RhoWebView.cs +49 -0
- data/platform/wp7/RhoRubyLib/sync/ClientRegister.cs +142 -0
- data/platform/wp7/RhoRubyLib/sync/ISyncProtocol.cs +23 -0
- data/platform/wp7/RhoRubyLib/sync/ISyncStatusListener.cs +10 -0
- data/platform/wp7/RhoRubyLib/sync/SyncEngine.cs +1051 -0
- data/platform/wp7/RhoRubyLib/sync/SyncNotify.cs +651 -0
- data/platform/wp7/RhoRubyLib/sync/SyncProtocol_3.cs +79 -0
- data/platform/wp7/RhoRubyLib/sync/SyncSource.cs +1105 -0
- data/platform/wp7/RhoRubyLib/sync/SyncThread.cs +301 -0
- data/platform/wp7/WPApplication.sln +50 -0
- data/platform/wp7/WPApplication/App.xaml +19 -0
- data/platform/wp7/WPApplication/App.xaml.cs +211 -0
- data/platform/wp7/WPApplication/ApplicationIcon.png +0 -0
- data/platform/wp7/WPApplication/Background.png +0 -0
- data/platform/wp7/WPApplication/MainPage.xaml +44 -0
- data/platform/wp7/WPApplication/MainPage.xaml.cs +132 -0
- data/platform/wp7/WPApplication/Properties/AppManifest.xml +6 -0
- data/platform/wp7/WPApplication/Properties/AssemblyInfo.cs +35 -0
- data/platform/wp7/WPApplication/Properties/WMAppManifest.xml +32 -0
- data/platform/wp7/WPApplication/SplashScreenImage.jpg +0 -0
- data/platform/wp7/WPApplication/WPApplication.csproj +201 -0
- data/platform/wp7/WPApplication/WP_PlatformAdaptationLayer.cs +88 -0
- data/platform/wp7/WPApplication/app_manifest.txt +1 -0
- data/platform/wp7/WPApplication/readme.htm +40 -0
- data/platform/wp7/WPApplication/readme2.htm +37 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/edit.bb.erb +29 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/edit.erb +32 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/index.bb.erb +21 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/index.erb +26 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/model1.rb +10 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/model1_controller.rb +58 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/new.bb.erb +29 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/new.erb +31 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/show.bb.erb +26 -0
- data/platform/wp7/WPApplication/rho/apps/app/Model1/show.erb +28 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/controller.rb +75 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/home.bb.erb +17 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/home.erb +20 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/index.bb.erb +32 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/index.erb +30 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/login.bb.erb +35 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/login.erb +27 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/reset.bb.erb +15 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/reset.erb +17 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/wait.bb.erb +3 -0
- data/platform/wp7/WPApplication/rho/apps/app/Settings/wait.erb +5 -0
- data/platform/wp7/WPApplication/rho/apps/app/application.rb +16 -0
- data/platform/wp7/WPApplication/rho/apps/app/helpers/application_helper.rb +126 -0
- data/platform/wp7/WPApplication/rho/apps/app/helpers/browser_helper.rb +18 -0
- data/platform/wp7/WPApplication/rho/apps/app/index.bb.erb +26 -0
- data/platform/wp7/WPApplication/rho/apps/app/index.erb +26 -0
- data/platform/wp7/WPApplication/rho/apps/app/layout.erb +45 -0
- data/platform/wp7/WPApplication/rho/apps/app/loading.html +11 -0
- data/platform/wp7/WPApplication/rho/apps/app_manifest.txt +1 -0
- data/platform/wp7/WPApplication/rho/apps/public/css/android.css +330 -0
- data/platform/wp7/WPApplication/rho/apps/public/css/blackberry.css +115 -0
- data/platform/wp7/WPApplication/rho/apps/public/css/iphone.css +410 -0
- data/platform/wp7/WPApplication/rho/apps/public/css/windows_mobile.css +222 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/IUI_LICENSE.txt +21 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/android/btn_check_off.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/android/btn_check_on.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/android/btn_radio_off.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/android/btn_radio_on.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/android/disclosure.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/android/ic_menu_more.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/backButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/blueButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/cancel.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/grayButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/disclosure.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/disclosure_detail.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/backButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/blueButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/cancel.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/chevron.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/grayButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/listArrowSel.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/listGroup.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/loading.gif +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/on_off.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/pinstripes.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/selection.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/thumb.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/toggle.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/toggleOn.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/toolButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/toolbar.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/jqtouch/whiteButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/radiobutton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/select.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iphone/switch.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/iui-logo-touch-icon.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/listArrow.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/listArrowDown.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/listArrowSel.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/listGroup.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/loading.gif +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/pinstripes.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/right_button.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/selection.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/thumb.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/toggle.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/toggleOn.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/toolButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/toolButton_new.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/toolbar.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/images/whiteButton.png +0 -0
- data/platform/wp7/WPApplication/rho/apps/public/jqtouch/jqtouch-iphone.css +9 -0
- data/platform/wp7/WPApplication/rho/apps/public/jqtouch/jqtouch.css +374 -0
- data/platform/wp7/WPApplication/rho/apps/public/jqtouch/jqtouch.js +742 -0
- data/platform/wp7/WPApplication/rho/apps/public/jqtouch/jqtouch.transitions.js +60 -0
- data/platform/wp7/WPApplication/rho/apps/public/jqtouch/jquery.1.3.2.min.js +19 -0
- data/platform/wp7/WPApplication/rho/apps/public/js/application.js +1 -0
- data/platform/wp7/WPApplication/rho/apps/public/js/rho.js +4 -0
- data/platform/wp7/WPApplication/rho/apps/public/js/rhogeolocation-wm.js +59 -0
- data/platform/wp7/WPApplication/rho/apps/public/js/rhogeolocation.js +11 -0
- data/platform/wp7/WPApplication/rho/apps/rhoconfig.txt +32 -0
- data/platform/wp7/WPApplication/rhoconfig.txt +32 -0
- data/platform/wp7/WPApplication/windows_mobile.css +222 -0
- data/platform/wp7/build/wp.rake +261 -0
- data/platform/wp7/rhodes.sln +79 -0
- data/platform/wp7/rhodes/App.xaml +19 -0
- data/platform/wp7/rhodes/App.xaml.cs +144 -0
- data/platform/wp7/rhodes/Background.png +0 -0
- data/platform/wp7/rhodes/MainPage.xaml +44 -0
- data/platform/wp7/rhodes/MainPage.xaml.cs +98 -0
- data/platform/wp7/rhodes/Properties/AppManifest.xml +6 -0
- data/platform/wp7/rhodes/Properties/AssemblyInfo.cs +35 -0
- data/platform/wp7/rhodes/Properties/WMAppManifest.xml +31 -0
- data/platform/wp7/rhodes/Rhodes.csproj +127 -0
- data/platform/wp7/rhodes/SplashScreenImage.jpg +0 -0
- data/platform/wp7/rhodes/icon.png +0 -0
- data/platform/wp7/sqlite3/Properties/AssemblyInfo.cs +35 -0
- data/platform/wp7/sqlite3/SQLiteClient.cs +550 -0
- data/platform/wp7/sqlite3/SqliteWrapper/BtreeInt_h.cs +774 -0
- data/platform/wp7/sqlite3/SqliteWrapper/Btree_h.cs +280 -0
- data/platform/wp7/sqlite3/SqliteWrapper/ClassDiagram1.cd +1306 -0
- data/platform/wp7/sqlite3/SqliteWrapper/Delagates.cs +365 -0
- data/platform/wp7/sqlite3/SqliteWrapper/Hash_h.cs +133 -0
- data/platform/wp7/sqlite3/SqliteWrapper/VdbeInt_h.cs +620 -0
- data/platform/wp7/sqlite3/SqliteWrapper/Vdbe_h.cs +302 -0
- data/platform/wp7/sqlite3/SqliteWrapper/_Custom.cs +449 -0
- data/platform/wp7/sqlite3/SqliteWrapper/alter_c.cs +872 -0
- data/platform/wp7/sqlite3/SqliteWrapper/analyze_c.cs +757 -0
- data/platform/wp7/sqlite3/SqliteWrapper/attach_c.cs +628 -0
- data/platform/wp7/sqlite3/SqliteWrapper/auth_c.cs +268 -0
- data/platform/wp7/sqlite3/SqliteWrapper/backup_c.cs +737 -0
- data/platform/wp7/sqlite3/SqliteWrapper/bitvec_c.cs +509 -0
- data/platform/wp7/sqlite3/SqliteWrapper/btmutex_c.cs +379 -0
- data/platform/wp7/sqlite3/SqliteWrapper/btree_c.cs +9138 -0
- data/platform/wp7/sqlite3/SqliteWrapper/build_c.cs +4189 -0
- data/platform/wp7/sqlite3/SqliteWrapper/callback_c.cs +548 -0
- data/platform/wp7/sqlite3/SqliteWrapper/complete_c.cs +342 -0
- data/platform/wp7/sqlite3/SqliteWrapper/ctime_cs.cs +408 -0
- data/platform/wp7/sqlite3/SqliteWrapper/date_c.cs +1317 -0
- data/platform/wp7/sqlite3/SqliteWrapper/delete_c.cs +726 -0
- data/platform/wp7/sqlite3/SqliteWrapper/expr_c.cs +4406 -0
- data/platform/wp7/sqlite3/SqliteWrapper/fault_c.cs +115 -0
- data/platform/wp7/sqlite3/SqliteWrapper/fkey_c.cs +1330 -0
- data/platform/wp7/sqlite3/SqliteWrapper/func_c.cs +2025 -0
- data/platform/wp7/sqlite3/SqliteWrapper/global_c.cs +228 -0
- data/platform/wp7/sqlite3/SqliteWrapper/hash_c.cs +351 -0
- data/platform/wp7/sqlite3/SqliteWrapper/hwtime_c.cs +101 -0
- data/platform/wp7/sqlite3/SqliteWrapper/insert_c.cs +2122 -0
- data/platform/wp7/sqlite3/SqliteWrapper/journal_c.cs +247 -0
- data/platform/wp7/sqlite3/SqliteWrapper/keywordhash_h.cs +302 -0
- data/platform/wp7/sqlite3/SqliteWrapper/legacy_c.cs +223 -0
- data/platform/wp7/sqlite3/SqliteWrapper/loadext_c.cs +683 -0
- data/platform/wp7/sqlite3/SqliteWrapper/main_c.cs +2716 -0
- data/platform/wp7/sqlite3/SqliteWrapper/malloc_c.cs +977 -0
- data/platform/wp7/sqlite3/SqliteWrapper/mem_Pool.cs +394 -0
- data/platform/wp7/sqlite3/SqliteWrapper/memjournal_c.cs +315 -0
- data/platform/wp7/sqlite3/SqliteWrapper/mutex_c.cs +182 -0
- data/platform/wp7/sqlite3/SqliteWrapper/mutex_h.cs +91 -0
- data/platform/wp7/sqlite3/SqliteWrapper/mutex_noop_c.cs +202 -0
- data/platform/wp7/sqlite3/SqliteWrapper/mutex_w32.cs +344 -0
- data/platform/wp7/sqlite3/SqliteWrapper/notify_c.cs +347 -0
- data/platform/wp7/sqlite3/SqliteWrapper/opcodes_c.cs +171 -0
- data/platform/wp7/sqlite3/SqliteWrapper/opcodes_h.cs +346 -0
- data/platform/wp7/sqlite3/SqliteWrapper/os_c.cs +367 -0
- data/platform/wp7/sqlite3/SqliteWrapper/os_common_h.cs +174 -0
- data/platform/wp7/sqlite3/SqliteWrapper/os_h.cs +295 -0
- data/platform/wp7/sqlite3/SqliteWrapper/os_win_c.cs +1255 -0
- data/platform/wp7/sqlite3/SqliteWrapper/pager_c.cs +6078 -0
- data/platform/wp7/sqlite3/SqliteWrapper/pager_h.cs +188 -0
- data/platform/wp7/sqlite3/SqliteWrapper/parse_c.cs +4045 -0
- data/platform/wp7/sqlite3/SqliteWrapper/parse_h.cs +331 -0
- data/platform/wp7/sqlite3/SqliteWrapper/pcache1_c.cs +969 -0
- data/platform/wp7/sqlite3/SqliteWrapper/pcache_c.cs +712 -0
- data/platform/wp7/sqlite3/SqliteWrapper/pcache_h.cs +213 -0
- data/platform/wp7/sqlite3/SqliteWrapper/pragma_c.cs +1767 -0
- data/platform/wp7/sqlite3/SqliteWrapper/prepare_c.cs +1015 -0
- data/platform/wp7/sqlite3/SqliteWrapper/printf_c.cs +1300 -0
- data/platform/wp7/sqlite3/SqliteWrapper/random_c.cs +201 -0
- data/platform/wp7/sqlite3/SqliteWrapper/resolve_c.cs +1396 -0
- data/platform/wp7/sqlite3/SqliteWrapper/rowset_c.cs +519 -0
- data/platform/wp7/sqlite3/SqliteWrapper/select_c.cs +4878 -0
- data/platform/wp7/sqlite3/SqliteWrapper/sqlite3_h.cs +6253 -0
- data/platform/wp7/sqlite3/SqliteWrapper/sqlite3ext_h.cs +397 -0
- data/platform/wp7/sqlite3/SqliteWrapper/sqliteInt_h.cs +4075 -0
- data/platform/wp7/sqlite3/SqliteWrapper/sqliteLimit_h.cs +214 -0
- data/platform/wp7/sqlite3/SqliteWrapper/sqliteicu_h.cs +39 -0
- data/platform/wp7/sqlite3/SqliteWrapper/status_c.cs +155 -0
- data/platform/wp7/sqlite3/SqliteWrapper/table_c.cs +222 -0
- data/platform/wp7/sqlite3/SqliteWrapper/tokenize_c.cs +673 -0
- data/platform/wp7/sqlite3/SqliteWrapper/trigger_c.cs +1219 -0
- data/platform/wp7/sqlite3/SqliteWrapper/update_c.cs +766 -0
- data/platform/wp7/sqlite3/SqliteWrapper/utf_c.cs +612 -0
- data/platform/wp7/sqlite3/SqliteWrapper/util_c.cs +1476 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vacuum_c.cs +382 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vdbe_c.cs +6566 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vdbeapi_c.cs +1557 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vdbeaux_c.cs +4019 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vdbeblob_c.cs +396 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vdbemem_c.cs +1480 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vdbetrace_c.cs +181 -0
- data/platform/wp7/sqlite3/SqliteWrapper/vtab_c.cs +957 -0
- data/platform/wp7/sqlite3/SqliteWrapper/walker_c.cs +174 -0
- data/platform/wp7/sqlite3/SqliteWrapper/where_c.cs +4651 -0
- data/platform/wp7/sqlite3/sqlite3.csproj +155 -0
- data/rakefile.rb +60 -2
- data/res/build-tools/7za.exe +0 -0
- data/res/build-tools/RhoAppRunner.exe +0 -0
- data/res/build-tools/xruby-0.3.3.jar +0 -0
- data/res/generators/rhogen.rb +9 -1
- data/res/generators/templates/application/app/Settings/reset.erb +1 -1
- data/res/generators/templates/application/app/layout.erb +17 -10
- data/res/generators/templates/application/build.yml +5 -3
- data/res/generators/templates/application/public/jqtouch/changes.txt +20 -0
- data/res/generators/templates/application/public/jqtouch/jqtouch.js +12 -4
- data/res/generators/templates/application/public/jqtouch/jquery.1.3.2.min.js +1 -1
- data/res/generators/templates/application/public/js/wp7.js +7 -0
- data/res/generators/templates/model/controller.rb +5 -6
- data/rhobuild.yml.example +1 -0
- data/rhodes.gemspec +2 -1
- data/spec/framework_spec/app/spec/core/dir/close_spec.rb +1 -1
- data/spec/framework_spec/app/spec/core/dir/shared/pwd.rb +13 -11
- data/spec/framework_spec/app/spec/core/env/shared/store.rb +12 -10
- data/spec/framework_spec/app/spec/core/env/update_spec.rb +1 -0
- data/spec/framework_spec/app/spec/core/file/expand_path_spec.rb +3 -2
- data/spec/framework_spec/app/spec/core/file/fixtures/file_types.rb +7 -1
- data/spec/framework_spec/app/spec/core/file/flock_spec.rb +8 -1
- data/spec/framework_spec/app/spec/core/file/ftype_spec.rb +5 -3
- data/spec/framework_spec/app/spec/core/file/lchmod_spec.rb +1 -1
- data/spec/framework_spec/app/spec/core/file/setgid_spec.rb +1 -1
- data/spec/framework_spec/app/spec/core/file/setuid_spec.rb +1 -1
- data/spec/framework_spec/app/spec/core/file/stat/ftype_spec.rb +6 -4
- data/spec/framework_spec/app/spec/core/file/truncate_spec.rb +5 -1
- data/spec/framework_spec/app/spec/core/float/to_s_spec.rb +1 -1
- data/spec/framework_spec/app/spec/core/process/gid_spec.rb +5 -3
- data/spec/framework_spec/app/spec/core/process/groups_spec.rb +11 -9
- data/spec/framework_spec/app/spec/core/process/uid_spec.rb +5 -3
- data/spec/framework_spec/app/spec/language/execution_spec.rb +10 -6
- data/spec/framework_spec/app/spec/shared/file/directory.rb +6 -1
- data/spec/framework_spec/app/spec/shared/file/executable.rb +7 -1
- data/spec/framework_spec/app/spec/shared/file/file.rb +6 -1
- data/spec/framework_spec/app/spec/shared/file/readable.rb +13 -4
- data/spec/framework_spec/app/spec/shared/file/writable.rb +6 -1
- data/spec/phone_spec/app/spec/rho_controller_spec.rb +11 -0
- data/spec/phone_spec/app/spec/rho_spec.rb +11 -0
- data/spec/phone_spec/app/spec/rhom_object_spec.rb +102 -6
- data/spec/phone_spec/app/spec/string/end_with_spec.rb +4 -1
- data/spec/phone_spec/app/spec/string/slice_spec.rb +5 -1
- data/spec/phone_spec/app/spec/string/start_with_spec.rb +4 -0
- data/spec/phone_spec/app/spec/syncengine_spec.rb +73 -6
- data/spec/phone_spec/app/spec_runner.rb +7 -3
- metadata +380 -41
- data/Manifest.txt +0 -5819
- data/platform/bb/Hsqldb/Hsqldb.cso +0 -5
- data/platform/bb/Hsqldb/Hsqldb.jdp +0 -197
- data/platform/bb/RhoBundle/RhoBundle.cso +0 -5
- data/platform/bb/RhoBundle/RhoBundle.jdp +0 -42
- data/platform/bb/RubyVM/RubyVM.cso +0 -5
- data/platform/bb/RubyVM/RubyVM.jdp +0 -467
- data/platform/bb/rhodes/rhodes.csl +0 -3
- data/platform/bb/rhodes/rhodes.cso +0 -5
- data/platform/bb/rhodes/rhodes.jdp +0 -104
@@ -21,7 +21,6 @@ import com.rhomobile.rhodes.BaseActivity;
|
|
21
21
|
import com.rhomobile.rhodes.Logger;
|
22
22
|
import com.rhomobile.rhodes.RhodesActivity;
|
23
23
|
import com.rhomobile.rhodes.RhodesService;
|
24
|
-
import com.rhomobile.rhodes.mapview.MapTouch.Touch;
|
25
24
|
import com.rhomobile.rhodes.util.PerformOnUiThread;
|
26
25
|
|
27
26
|
public class MapView extends BaseActivity implements MapTouch {
|
@@ -24,25 +24,12 @@ import android.provider.ContactsContract.RawContacts;
|
|
24
24
|
public class ContactAccessorNew implements ContactAccessor {
|
25
25
|
|
26
26
|
private static final String TAG = "ContactsAccessorNew";
|
27
|
-
private static final boolean
|
28
|
-
|
29
|
-
/*
|
30
|
-
private static final String PB_ID = Phonebook.PB_ID;
|
31
|
-
private static final String PB_FIRST_NAME = Phonebook.PB_FIRST_NAME;
|
32
|
-
private static final String PB_LAST_NAME = Phonebook.PB_LAST_NAME;
|
33
|
-
private static final String PB_MOBILE_NUMBER = Phonebook.PB_MOBILE_NUMBER;
|
34
|
-
private static final String PB_HOME_NUMBER = Phonebook.PB_HOME_NUMBER;
|
35
|
-
private static final String PB_BUSINESS_NUMBER = Phonebook.PB_BUSINESS_NUMBER;
|
36
|
-
private static final String PB_EMAIL_ADDRESS = Phonebook.PB_EMAIL_ADDRESS;
|
37
|
-
private static final String PB_COMPANY_NAME = Phonebook.PB_COMPANY_NAME;
|
38
|
-
*/
|
27
|
+
private static final boolean DEBUG = false;
|
39
28
|
|
40
29
|
private ContentResolver cr;
|
41
30
|
private String accName;
|
42
31
|
private String accType;
|
43
32
|
|
44
|
-
|
45
|
-
|
46
33
|
public ContactAccessorNew() throws Exception {
|
47
34
|
Context ctx = RhodesService.getContext();
|
48
35
|
|
@@ -61,36 +48,54 @@ public class ContactAccessorNew implements ContactAccessor {
|
|
61
48
|
}
|
62
49
|
|
63
50
|
public void fillName(String id, Contact contact) {
|
64
|
-
if (
|
51
|
+
if (DEBUG)
|
52
|
+
Logger.D(TAG, "fillName("+id+")");
|
53
|
+
|
65
54
|
contact.setFieldInner(Phonebook.PB_I_FIRST_NAME, "");
|
66
55
|
contact.setFieldInner(Phonebook.PB_I_LAST_NAME, "");
|
67
56
|
|
68
57
|
Cursor cursor = cr.query(Data.CONTENT_URI,
|
69
|
-
new String[] {StructuredName.DISPLAY_NAME},
|
58
|
+
new String[] {StructuredName.GIVEN_NAME, StructuredName.FAMILY_NAME, StructuredName.DISPLAY_NAME},
|
70
59
|
Data.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
71
60
|
new String[] {id, StructuredName.CONTENT_ITEM_TYPE},
|
72
61
|
null);
|
73
62
|
try {
|
74
63
|
if (!cursor.moveToFirst()) {
|
75
|
-
if (
|
64
|
+
if (DEBUG)
|
65
|
+
Logger.D(TAG, "fillName() not found record with ID");
|
76
66
|
return;
|
77
67
|
}
|
78
68
|
|
79
|
-
String
|
80
|
-
|
81
|
-
|
82
|
-
if (
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
contact.setFieldInner(Phonebook.PB_I_LAST_NAME,
|
89
|
-
}
|
69
|
+
String firstName = cursor.getString(cursor.getColumnIndex(StructuredName.GIVEN_NAME));
|
70
|
+
String lastName = cursor.getString(cursor.getColumnIndex(StructuredName.FAMILY_NAME));
|
71
|
+
if (firstName != null || lastName != null) {
|
72
|
+
if (DEBUG)
|
73
|
+
Logger.D(TAG, "fillName() firstName=" + firstName + ", lastName=" + lastName);
|
74
|
+
|
75
|
+
if (firstName != null)
|
76
|
+
contact.setFieldInner(Phonebook.PB_I_FIRST_NAME, firstName);
|
77
|
+
if (lastName != null)
|
78
|
+
contact.setFieldInner(Phonebook.PB_I_LAST_NAME, lastName);
|
90
79
|
}
|
91
80
|
else {
|
92
|
-
|
81
|
+
String displayName = cursor.getString(cursor.getColumnIndex(StructuredName.DISPLAY_NAME));
|
82
|
+
if (DEBUG)
|
83
|
+
Logger.D(TAG, "fillName() displayName=" + displayName);
|
93
84
|
|
85
|
+
if (displayName != null) {
|
86
|
+
String[] names = displayName.split(" ");
|
87
|
+
if (names.length == 1) {
|
88
|
+
contact.setFieldInner(Phonebook.PB_I_FIRST_NAME, names[0]);
|
89
|
+
}
|
90
|
+
else if (names.length > 1) {
|
91
|
+
contact.setFieldInner(Phonebook.PB_I_FIRST_NAME, names[0]);
|
92
|
+
contact.setFieldInner(Phonebook.PB_I_LAST_NAME, names[1]);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
else {
|
96
|
+
if (DEBUG)
|
97
|
+
Logger.D(TAG, "fillName() name is null");
|
98
|
+
}
|
94
99
|
}
|
95
100
|
}
|
96
101
|
finally {
|
@@ -198,7 +203,8 @@ public class ContactAccessorNew implements ContactAccessor {
|
|
198
203
|
}
|
199
204
|
|
200
205
|
public Contact getContactByID(String id) {
|
201
|
-
if (
|
206
|
+
if (DEBUG)
|
207
|
+
Logger.D(TAG, "getContactByID("+id+")");
|
202
208
|
|
203
209
|
Contact contact = null;
|
204
210
|
|
@@ -210,7 +216,8 @@ public class ContactAccessorNew implements ContactAccessor {
|
|
210
216
|
|
211
217
|
try {
|
212
218
|
if (!cursor.moveToFirst()) {
|
213
|
-
if (
|
219
|
+
if (DEBUG)
|
220
|
+
Logger.D(TAG, "getContactByID() not found");
|
214
221
|
return null;
|
215
222
|
}
|
216
223
|
contact = new Contact();
|
@@ -222,7 +229,8 @@ public class ContactAccessorNew implements ContactAccessor {
|
|
222
229
|
finally {
|
223
230
|
cursor.close();
|
224
231
|
}
|
225
|
-
if (
|
232
|
+
if (DEBUG)
|
233
|
+
Logger.D(TAG, "getContactByID() found");
|
226
234
|
return contact;
|
227
235
|
}
|
228
236
|
|
@@ -47,6 +47,7 @@ class SignatureView extends SurfaceView implements SurfaceHolder.Callback {
|
|
47
47
|
|
48
48
|
public static String mStateID = "SignatureViewState";
|
49
49
|
|
50
|
+
@SuppressWarnings("serial")
|
50
51
|
public class SignatureViewState extends Object implements Serializable {
|
51
52
|
public Vector<PointSequence> mSequences;
|
52
53
|
|
@@ -1,10 +1,13 @@
|
|
1
1
|
package com.rhomobile.rhodes.uri;
|
2
2
|
|
3
|
+
import java.net.URISyntaxException;
|
4
|
+
|
3
5
|
import com.rhomobile.rhodes.Logger;
|
4
6
|
|
5
7
|
import android.content.Context;
|
6
8
|
import android.content.Intent;
|
7
9
|
import android.net.Uri;
|
10
|
+
import android.webkit.URLUtil;
|
8
11
|
|
9
12
|
public class ExternalHttpHandler implements UriHandler {
|
10
13
|
|
@@ -15,10 +18,10 @@ public class ExternalHttpHandler implements UriHandler {
|
|
15
18
|
ctx = c;
|
16
19
|
}
|
17
20
|
|
18
|
-
public boolean handle(String url) {
|
21
|
+
public boolean handle(String url) throws URISyntaxException {
|
19
22
|
Uri uri = Uri.parse(url);
|
20
|
-
|
21
|
-
if (!
|
23
|
+
|
24
|
+
if (!URLUtil.isHttpUrl(url) && !URLUtil.isHttpsUrl(url))
|
22
25
|
return false;
|
23
26
|
|
24
27
|
String target = uri.getQueryParameter("rho_open_target");
|
@@ -27,10 +30,15 @@ public class ExternalHttpHandler implements UriHandler {
|
|
27
30
|
|
28
31
|
Logger.D(TAG, "This is external 'http' uri, handle it");
|
29
32
|
|
30
|
-
|
31
|
-
|
33
|
+
//Remove 'rho_open_target' parameter from URL
|
34
|
+
final String rhoParam = "rho_open_target=_blank";
|
35
|
+
int pos = url.indexOf(rhoParam);
|
36
|
+
if (pos + rhoParam.length() == url.length())
|
37
|
+
url = url.substring(0, pos - 1);
|
38
|
+
else
|
39
|
+
url = url.substring(0, pos) + url.substring(pos + rhoParam.length() + 1 , url.length());
|
32
40
|
|
33
|
-
ctx.startActivity(Intent.createChooser(
|
41
|
+
ctx.startActivity(Intent.createChooser(Intent.parseUri(url, 0), "Open in..."));
|
34
42
|
return true;
|
35
43
|
}
|
36
44
|
|
@@ -0,0 +1,46 @@
|
|
1
|
+
package com.rhomobile.rhodes.uri;
|
2
|
+
|
3
|
+
import java.io.File;
|
4
|
+
import java.net.URISyntaxException;
|
5
|
+
|
6
|
+
import com.rhomobile.rhodes.LocalFileProvider;
|
7
|
+
import com.rhomobile.rhodes.Logger;
|
8
|
+
|
9
|
+
import android.content.Context;
|
10
|
+
import android.content.Intent;
|
11
|
+
import android.net.Uri;
|
12
|
+
import android.webkit.URLUtil;
|
13
|
+
|
14
|
+
public class LocalFileHandler implements UriHandler
|
15
|
+
{
|
16
|
+
private static final String TAG = "LocalFileHandler";
|
17
|
+
private Context ctx;
|
18
|
+
|
19
|
+
public LocalFileHandler(Context c) {
|
20
|
+
ctx = c;
|
21
|
+
}
|
22
|
+
|
23
|
+
public boolean handle(String url) throws URISyntaxException {
|
24
|
+
|
25
|
+
if(!URLUtil.isFileUrl(url))
|
26
|
+
return false;
|
27
|
+
|
28
|
+
Logger.D(TAG, "This is 'file' URI, handle it: " + url);
|
29
|
+
|
30
|
+
int intentFlags = 0;
|
31
|
+
String path = Uri.parse(url).getPath();
|
32
|
+
File file = new File(path);
|
33
|
+
|
34
|
+
if(path.startsWith(LocalFileProvider.PATH_PREFIX))
|
35
|
+
{
|
36
|
+
url = LocalFileProvider.uriFromLocalFile(file).toString();
|
37
|
+
intentFlags = Intent.FLAG_GRANT_READ_URI_PERMISSION;
|
38
|
+
}
|
39
|
+
|
40
|
+
Intent intent = Intent.parseUri(url, intentFlags);
|
41
|
+
ctx.startActivity(Intent.createChooser(intent, "Open in..."));
|
42
|
+
|
43
|
+
return true;
|
44
|
+
}
|
45
|
+
|
46
|
+
}
|
@@ -20,7 +20,7 @@
|
|
20
20
|
*/
|
21
21
|
package com.rhomobile.rhodes.uri;
|
22
22
|
|
23
|
-
import java.
|
23
|
+
import java.net.URISyntaxException;
|
24
24
|
|
25
25
|
import com.rhomobile.rhodes.Logger;
|
26
26
|
|
@@ -38,35 +38,15 @@ public class MailUriHandler implements UriHandler {
|
|
38
38
|
ctx = c;
|
39
39
|
}
|
40
40
|
|
41
|
-
public boolean handle(String url) {
|
41
|
+
public boolean handle(String url) throws URISyntaxException {
|
42
42
|
if (!MailTo.isMailTo(url))
|
43
43
|
return false;
|
44
44
|
|
45
45
|
Logger.D(TAG, "This is 'mailto' uri, handle it");
|
46
46
|
|
47
|
-
|
48
|
-
|
49
|
-
Intent intent = new Intent(Intent.ACTION_SEND);
|
50
|
-
intent.setType("message/rfc882");
|
51
|
-
|
52
|
-
String s = muri.getTo();
|
53
|
-
if (s != null) intent.putExtra(Intent.EXTRA_EMAIL, new String[]{s});
|
54
|
-
|
55
|
-
s = muri.getCc();
|
56
|
-
if (s != null) intent.putExtra(Intent.EXTRA_CC, new String[]{s});
|
57
|
-
|
58
|
-
s = muri.getSubject();
|
59
|
-
if (s != null) intent.putExtra(Intent.EXTRA_SUBJECT, s);
|
60
|
-
|
61
|
-
s = muri.getBody();
|
62
|
-
if (s != null) intent.putExtra(Intent.EXTRA_TEXT, s);
|
63
|
-
|
64
|
-
Map<String,String> headers = muri.getHeaders();
|
65
|
-
s = headers.get("bcc");
|
66
|
-
if (s != null) intent.putExtra(Intent.EXTRA_BCC, new String[]{s});
|
67
|
-
|
68
|
-
ctx.startActivity(Intent.createChooser(intent, "Send e-mail..."));
|
47
|
+
ctx.startActivity(Intent.createChooser(Intent.parseUri(url, 0), "Open in..."));
|
69
48
|
return true;
|
49
|
+
|
70
50
|
}
|
71
51
|
|
72
52
|
}
|
@@ -1,7 +1,29 @@
|
|
1
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/alert/Alert.java
|
2
1
|
platform/android/Rhodes/src/com/rhomobile/rhodes/AndroidR.java
|
3
2
|
platform/android/Rhodes/src/com/rhomobile/rhodes/Base64.java
|
4
3
|
platform/android/Rhodes/src/com/rhomobile/rhodes/BaseActivity.java
|
4
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/HttpLog.java
|
5
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/LocalFileProvider.java
|
6
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/Logger.java
|
7
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/NativeBar.java
|
8
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/NavBar.java
|
9
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/NetworkConnectivityListener.java
|
10
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/NetworkStateTracker.java
|
11
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/PushReceiver.java
|
12
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/PushService.java
|
13
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoConf.java
|
14
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoCryptImpl.java
|
15
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoLogConf.java
|
16
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoMenu.java
|
17
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java
|
18
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesAppOptions.java
|
19
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java
|
20
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java
|
21
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/RingtoneManager.java
|
22
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/SplashScreen.java
|
23
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/Utils.java
|
24
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java
|
25
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/alert/Alert.java
|
26
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/alert/PopupActivity.java
|
5
27
|
platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/IRhoBluetoothManager.java
|
6
28
|
platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothDeviceListActivity.java
|
7
29
|
platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothManager.java
|
@@ -11,17 +33,15 @@ platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/RhoBluetoothSession.j
|
|
11
33
|
platform/android/Rhodes/src/com/rhomobile/rhodes/bluetooth/UUIDHelper.java
|
12
34
|
platform/android/Rhodes/src/com/rhomobile/rhodes/camera/Camera.java
|
13
35
|
platform/android/Rhodes/src/com/rhomobile/rhodes/camera/FileList.java
|
14
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/camera/ImageCaptureCallback.java
|
15
36
|
platform/android/Rhodes/src/com/rhomobile/rhodes/camera/ImageCapture.java
|
37
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/camera/ImageCaptureCallback.java
|
16
38
|
platform/android/Rhodes/src/com/rhomobile/rhodes/datetime/DateTimePicker.java
|
17
39
|
platform/android/Rhodes/src/com/rhomobile/rhodes/datetime/DateTimePickerScreen.java
|
18
40
|
platform/android/Rhodes/src/com/rhomobile/rhodes/event/Event.java
|
19
41
|
platform/android/Rhodes/src/com/rhomobile/rhodes/event/EventStore.java
|
20
42
|
platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java
|
21
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java
|
22
43
|
platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocation.java
|
23
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/
|
24
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/Logger.java
|
44
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java
|
25
45
|
platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/MainView.java
|
26
46
|
platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java
|
27
47
|
platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java
|
@@ -33,50 +53,33 @@ platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java
|
|
33
53
|
platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MultiTouchHandler.java
|
34
54
|
platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/OneTouchHandler.java
|
35
55
|
platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/TouchHandler.java
|
36
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/NativeBar.java
|
37
56
|
platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoNativeViewManager.java
|
38
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/
|
39
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/NetworkConnectivityListener.java
|
40
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/NetworkStateTracker.java
|
57
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/Contact.java
|
41
58
|
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactAccessor.java
|
42
59
|
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactAccessorNew.java
|
43
60
|
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactAccessorOld.java
|
44
61
|
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/ContactField.java
|
45
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/Contact.java
|
46
62
|
platform/android/Rhodes/src/com/rhomobile/rhodes/phonebook/Phonebook.java
|
47
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/PushReceiver.java
|
48
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/PushService.java
|
49
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoConf.java
|
50
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoCryptImpl.java
|
51
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java
|
52
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java
|
53
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesAppOptions.java
|
54
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java
|
55
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoLogConf.java
|
56
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RhoMenu.java
|
57
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/RingtoneManager.java
|
58
63
|
platform/android/Rhodes/src/com/rhomobile/rhodes/signature/ImageCapture.java
|
59
64
|
platform/android/Rhodes/src/com/rhomobile/rhodes/signature/Signature.java
|
60
65
|
platform/android/Rhodes/src/com/rhomobile/rhodes/signature/SignatureView.java
|
61
66
|
platform/android/Rhodes/src/com/rhomobile/rhodes/socket/RhoSockAddr.java
|
62
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/socket/RhoSocketImpl.java
|
63
67
|
platform/android/Rhodes/src/com/rhomobile/rhodes/socket/RhoSocket.java
|
68
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/socket/RhoSocketImpl.java
|
64
69
|
platform/android/Rhodes/src/com/rhomobile/rhodes/socket/SSLImpl.java
|
65
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/SplashScreen.java
|
66
70
|
platform/android/Rhodes/src/com/rhomobile/rhodes/ui/AboutDialog.java
|
67
71
|
platform/android/Rhodes/src/com/rhomobile/rhodes/ui/LogOptionsDialog.java
|
68
72
|
platform/android/Rhodes/src/com/rhomobile/rhodes/ui/LogViewDialog.java
|
69
73
|
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/ExternalHttpHandler.java
|
74
|
+
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/LocalFileHandler.java
|
70
75
|
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/MailUriHandler.java
|
71
76
|
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/SmsUriHandler.java
|
72
77
|
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/TelUriHandler.java
|
73
78
|
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/UriHandler.java
|
74
79
|
platform/android/Rhodes/src/com/rhomobile/rhodes/uri/VideoUriHandler.java
|
75
80
|
platform/android/Rhodes/src/com/rhomobile/rhodes/util/PerformOnUiThread.java
|
76
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/Utils.java
|
77
81
|
platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientNew.java
|
78
82
|
platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientOld.java
|
79
|
-
platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java
|
80
83
|
platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettings.java
|
81
84
|
platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsNew.java
|
82
85
|
platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsOld.java
|
@@ -179,6 +179,42 @@ def set_app_name_android(newname)
|
|
179
179
|
manifest.delete(e) if name.to_s =~ /\.C2D_MESSAGE$/
|
180
180
|
end
|
181
181
|
|
182
|
+
app = doc.elements["manifest/application"]
|
183
|
+
|
184
|
+
app.elements.each("activity") do |a|
|
185
|
+
a.elements.each("intent-filter") do |filter|
|
186
|
+
filter.elements.each("action") do |act|
|
187
|
+
act_name = act.attribute("name", "android")
|
188
|
+
next if act_name.nil?
|
189
|
+
if act_name.to_s =~ /\.VIEW$/
|
190
|
+
default_filter = false
|
191
|
+
browsable_filter = false
|
192
|
+
filter.elements.each("category") do |c|
|
193
|
+
cat_name = c.attribute("name", "android")
|
194
|
+
next if cat_name.nil?
|
195
|
+
default_filter = true if cat_name.to_s =~ /\.DEFAULT$/
|
196
|
+
browsable_filter = true if cat_name.to_s =~ /\.BROWSABLE$/
|
197
|
+
end
|
198
|
+
if default_filter and browsable_filter
|
199
|
+
if $uri_custom.nil?
|
200
|
+
filter.add_element "data", { "android:scheme" => $uri_scheme }
|
201
|
+
else
|
202
|
+
filter.add_element( "data", { "android:scheme" => $uri_scheme, "android:host" => $uri_custom } )
|
203
|
+
end
|
204
|
+
end
|
205
|
+
end
|
206
|
+
end
|
207
|
+
end
|
208
|
+
end
|
209
|
+
|
210
|
+
provider = app.add_element(
|
211
|
+
"provider",
|
212
|
+
{ "android:name" => "#{JAVA_PACKAGE_NAME}.LocalFileProvider",
|
213
|
+
"android:authorities" => $app_package_name,
|
214
|
+
"android:grantUriPermissions" => "false" } )
|
215
|
+
|
216
|
+
provider.add_element "grant-uri-permission", { "android:pathPrefix" => "/rhodes/apps/" }
|
217
|
+
|
182
218
|
#manifest.elements.each('uses-permission') { |e| manifest.delete e }
|
183
219
|
|
184
220
|
caps.sort.each do |cap|
|
@@ -191,7 +227,12 @@ def set_app_name_android(newname)
|
|
191
227
|
p.call manifest
|
192
228
|
end
|
193
229
|
|
194
|
-
|
230
|
+
puts 'save updated application manifest'
|
231
|
+
app_f = File.open($appmanifest, "w")
|
232
|
+
doc.write app_f, 2
|
233
|
+
app_f.close
|
234
|
+
|
235
|
+
#File.open($appmanifest, "w") { |f| doc.write f, 2 }
|
195
236
|
|
196
237
|
buf = File.new($rho_android_r,"r").read.gsub(/^\s*import com\.rhomobile\..*\.R;\s*$/,"\nimport #{$app_package_name}.R;\n")
|
197
238
|
File.open($app_android_r,"w") { |f| f.write(buf) }
|
@@ -228,6 +269,9 @@ namespace "config" do
|
|
228
269
|
$emuversion = $app_config["android"]["version"] unless $app_config["android"].nil?
|
229
270
|
$emuversion = $config["android"]["version"] if $emuversion.nil? and !$config["android"].nil?
|
230
271
|
|
272
|
+
$uri_scheme = $app_config["android"]["BundleURLScheme"] unless $app_config["android"].nil?
|
273
|
+
$uri_scheme = $config["android"]["BundleURLScheme"] if $uri_scheme.nil? and not $config["android"].nil?
|
274
|
+
|
231
275
|
# Here is switch between release/debug configuration used for
|
232
276
|
# building native libraries
|
233
277
|
if $app_config["debug"].nil?
|
@@ -279,6 +323,11 @@ namespace "config" do
|
|
279
323
|
$app_package_name = "com.#{$vendor}." + $appname.downcase.gsub(/[^A-Za-z_0-9]/, '') unless $app_package_name
|
280
324
|
$app_package_name.gsub!(/\.[\d]/, "._")
|
281
325
|
|
326
|
+
if $uri_scheme.nil?
|
327
|
+
$uri_custom = $app_package_name
|
328
|
+
$uri_scheme = "http"
|
329
|
+
end
|
330
|
+
|
282
331
|
$rhomanifest = File.join $androidpath, "Rhodes", "AndroidManifest.xml"
|
283
332
|
$appmanifest = File.join $tmpdir, "AndroidManifest.xml"
|
284
333
|
|
@@ -400,6 +449,13 @@ namespace "config" do
|
|
400
449
|
$app_config["capabilities"] += ANDROID_CAPS_ALWAYS_ENABLED
|
401
450
|
$app_config["capabilities"].map! { |cap| cap.is_a?(String) ? cap : nil }.delete_if { |cap| cap.nil? }
|
402
451
|
$use_google_addon_api = true unless $app_config["capabilities"].index("push").nil?
|
452
|
+
|
453
|
+
$applog_path = nil
|
454
|
+
$applog_file = $app_config["applog"]
|
455
|
+
|
456
|
+
if !$applog_file.nil?
|
457
|
+
$applog_path = File.join( $app_path, $applog_file )
|
458
|
+
end
|
403
459
|
|
404
460
|
# Detect android targets
|
405
461
|
if $androidtargets.nil?
|
@@ -474,10 +530,8 @@ namespace "config" do
|
|
474
530
|
$avdname += "ext" if $use_google_addon_api
|
475
531
|
$avdtarget = $androidtargets[get_api_level($emuversion)]
|
476
532
|
|
477
|
-
$appavdname = nil
|
478
|
-
|
479
|
-
$appavdname = $app_config["android"]["emulator"]
|
480
|
-
end
|
533
|
+
$appavdname = $app_config["android"]["emulator"] if $app_config["android"] != nil
|
534
|
+
$appavdname = $config["android"]["emulator"] if $appavdname.nil? and !$config["android"].nil?
|
481
535
|
|
482
536
|
setup_ndk($androidndkpath, ANDROID_API_LEVEL)
|
483
537
|
|
@@ -1026,15 +1080,85 @@ namespace "build" do
|
|
1026
1080
|
puts 'ext_build.files found ! Addditional files for compilation :'
|
1027
1081
|
File.open(File.join($extensionsdir, "ext_build.files")) do |f|
|
1028
1082
|
while line = f.gets
|
1029
|
-
line
|
1083
|
+
line.chomp!
|
1030
1084
|
puts 'java file : ' + line
|
1031
|
-
lines << "\""+line
|
1085
|
+
lines << "\""+line+"\""
|
1032
1086
|
end
|
1033
1087
|
end
|
1034
1088
|
else
|
1035
1089
|
puts 'ext_build.files not found - no additional java files for compilation'
|
1036
1090
|
end
|
1037
1091
|
|
1092
|
+
ext_manifest = File.join($extensionsdir, "AndroidManifest.xml")
|
1093
|
+
if File.exists? ext_manifest
|
1094
|
+
puts 'AndroidManifest.xml from native extension found !'
|
1095
|
+
|
1096
|
+
#tappmanifest = $appmanifest + '_tmp'
|
1097
|
+
|
1098
|
+
#cp_r $appmanifest,tappmanifest
|
1099
|
+
|
1100
|
+
app_f = File.new($appmanifest)
|
1101
|
+
manifest_orig_doc = REXML::Document.new(app_f)
|
1102
|
+
app_f.close
|
1103
|
+
|
1104
|
+
manifest_ext_doc = REXML::Document.new(File.new(ext_manifest))
|
1105
|
+
|
1106
|
+
src_manifest = manifest_ext_doc.elements["manifest"]
|
1107
|
+
dst_manifest = manifest_orig_doc.elements["manifest"]
|
1108
|
+
|
1109
|
+
|
1110
|
+
src_application = manifest_ext_doc.elements["manifest/application"]
|
1111
|
+
dst_application = manifest_orig_doc.elements["manifest/application"]
|
1112
|
+
|
1113
|
+
if src_application != nil
|
1114
|
+
puts 'Extension Manifest process application item :'
|
1115
|
+
src_application.elements.each do |e|
|
1116
|
+
puts ' add item ['+e.xpath+']'
|
1117
|
+
dst_application.add e
|
1118
|
+
end
|
1119
|
+
end
|
1120
|
+
|
1121
|
+
puts 'Extension Manifest process root <manifest> item :'
|
1122
|
+
src_manifest.elements.each do |e|
|
1123
|
+
p = e.xpath
|
1124
|
+
if p != '/manifest/application'
|
1125
|
+
dst_e = manifest_orig_doc.elements[p]
|
1126
|
+
if dst_e != nil
|
1127
|
+
if p == '/manifest/uses-sdk'
|
1128
|
+
puts ' found and delete original item ['+p+']'
|
1129
|
+
manifest_orig_doc.elements.delete p
|
1130
|
+
end
|
1131
|
+
end
|
1132
|
+
puts ' and new item ['+p+']'
|
1133
|
+
dst_manifest.add e
|
1134
|
+
end
|
1135
|
+
end
|
1136
|
+
|
1137
|
+
#puts 'Result Manifest :'
|
1138
|
+
#manifest_orig_doc.elements['manifest'].elements.each do |e|
|
1139
|
+
# puts ' + '+e.xpath
|
1140
|
+
# if e.xpath == '/manifest/application'
|
1141
|
+
# manifest_orig_doc.elements['manifest/application'].elements.each do |t|
|
1142
|
+
# puts ' + '+t.xpath
|
1143
|
+
# end
|
1144
|
+
# end
|
1145
|
+
#end
|
1146
|
+
|
1147
|
+
puts 'delete original manifest'
|
1148
|
+
File.delete($appmanifest)
|
1149
|
+
|
1150
|
+
updated_f = File.open($appmanifest, "w")
|
1151
|
+
manifest_orig_doc.write updated_f, 2
|
1152
|
+
updated_f.close
|
1153
|
+
|
1154
|
+
#rm tappmanifest
|
1155
|
+
puts 'Manifest updated by extension saved!'
|
1156
|
+
|
1157
|
+
|
1158
|
+
else
|
1159
|
+
puts 'AndroidManifest.xml from native extension not found - no any changes in main AndroidManifest.xml'
|
1160
|
+
end
|
1161
|
+
|
1038
1162
|
File.open(newsrclist, "w") { |f| f.write lines.join("\n") }
|
1039
1163
|
srclist = newsrclist
|
1040
1164
|
|
@@ -1114,7 +1238,8 @@ namespace "package" do
|
|
1114
1238
|
|
1115
1239
|
puts "Packaging Assets and Jars"
|
1116
1240
|
|
1117
|
-
|
1241
|
+
# this task already caaled during build "build:android:all"
|
1242
|
+
#set_app_name_android($appname)
|
1118
1243
|
|
1119
1244
|
args = ["package", "-f", "-M", manifest, "-S", resource, "-A", assets, "-I", $androidjar, "-F", resourcepkg]
|
1120
1245
|
puts Jake.run($aapt, args)
|
@@ -1347,51 +1472,82 @@ def application_running(flag, pkgname)
|
|
1347
1472
|
false
|
1348
1473
|
end
|
1349
1474
|
|
1475
|
+
def kill_adb_and_emulator
|
1476
|
+
if RUBY_PLATFORM =~ /windows|cygwin|mingw/
|
1477
|
+
# Windows
|
1478
|
+
`taskkill /F /IM adb.exe`
|
1479
|
+
`taskkill /F /IM emulator.exe`
|
1480
|
+
else
|
1481
|
+
`killall -9 adb`
|
1482
|
+
`killall -9 emulator`
|
1483
|
+
end
|
1484
|
+
end
|
1485
|
+
|
1486
|
+
def logcat(device_flag = '-e', log_path = $applog_path)
|
1487
|
+
if !log_path.nil?
|
1488
|
+
Thread.new { Jake.run($adb, [device_flag, 'logcat', '>>', log_path], nil, true) }
|
1489
|
+
end
|
1490
|
+
end
|
1491
|
+
|
1492
|
+
def logclear(device_flag = '-e')
|
1493
|
+
Thread.new { Jake.run($adb, [device_flag, 'logcat', '-c'], nil, true) }
|
1494
|
+
end
|
1495
|
+
|
1350
1496
|
namespace "run" do
|
1351
1497
|
namespace "android" do
|
1352
1498
|
|
1353
1499
|
task :spec => ["device:android:debug"] do
|
1354
|
-
|
1355
|
-
|
1356
|
-
|
1357
|
-
log_name = $app_path + '/RhoLog.txt'
|
1500
|
+
|
1501
|
+
log_name = $app_path + '/RhoLogSpec.txt'
|
1358
1502
|
File.delete(log_name) if File.exist?(log_name)
|
1503
|
+
|
1504
|
+
device_flag = '-e'
|
1505
|
+
|
1506
|
+
logclear(device_flag)
|
1507
|
+
run_emulator :hidden => true
|
1508
|
+
do_uninstall(device_flag)
|
1359
1509
|
|
1360
1510
|
# Failsafe to prevent eternal hangs
|
1361
1511
|
Thread.new {
|
1362
|
-
sleep
|
1363
|
-
|
1364
|
-
if RUBY_PLATFORM =~ /windows|cygwin|mingw/
|
1365
|
-
# Windows
|
1366
|
-
`taskkill /F /IM adb.exe`
|
1367
|
-
`taskkill /F /IM emulator.exe`
|
1368
|
-
else
|
1369
|
-
`killall -9 adb`
|
1370
|
-
`killall -9 emulator`
|
1371
|
-
end
|
1512
|
+
sleep 2000
|
1513
|
+
kill_adb_and_emulator
|
1372
1514
|
}
|
1373
1515
|
|
1374
|
-
load_app_and_run
|
1516
|
+
load_app_and_run(device_flag)
|
1517
|
+
logcat(device_flag, log_name)
|
1375
1518
|
|
1376
1519
|
Jake.before_run_spec
|
1377
1520
|
start = Time.now
|
1378
1521
|
|
1379
|
-
puts "waiting for
|
1522
|
+
puts "waiting for application"
|
1523
|
+
|
1524
|
+
for i in 0..60
|
1525
|
+
if application_running(device_flag, $app_package_name)
|
1526
|
+
break
|
1527
|
+
else
|
1528
|
+
sleep(1)
|
1529
|
+
end
|
1530
|
+
end
|
1531
|
+
|
1532
|
+
puts "waiting for log: " + log_name
|
1380
1533
|
|
1381
1534
|
for i in 0..60
|
1382
1535
|
if !File.exist?(log_name)
|
1383
|
-
get_app_log($appname, false, true)
|
1384
1536
|
sleep(1)
|
1385
1537
|
else
|
1386
1538
|
break
|
1387
1539
|
end
|
1388
1540
|
end
|
1389
1541
|
|
1542
|
+
if !File.exist?(log_name)
|
1543
|
+
puts "Can not read log file: " + log_name
|
1544
|
+
exit(1)
|
1545
|
+
end
|
1546
|
+
|
1390
1547
|
puts "start read log"
|
1391
1548
|
|
1392
1549
|
end_spec = false
|
1393
1550
|
while !end_spec do
|
1394
|
-
get_app_log($appname, false, true)
|
1395
1551
|
io = File.new(log_name, "r")
|
1396
1552
|
|
1397
1553
|
io.each do |line|
|
@@ -1402,21 +1558,15 @@ namespace "run" do
|
|
1402
1558
|
end
|
1403
1559
|
io.close
|
1404
1560
|
|
1405
|
-
break unless application_running(
|
1561
|
+
break unless application_running(device_flag, $app_package_name)
|
1406
1562
|
sleep(5) unless end_spec
|
1407
1563
|
end
|
1408
1564
|
|
1409
1565
|
Jake.process_spec_results(start)
|
1410
1566
|
|
1411
1567
|
# stop app
|
1412
|
-
|
1413
|
-
|
1414
|
-
`taskkill /F /IM adb.exe`
|
1415
|
-
`taskkill /F /IM emulator.exe`
|
1416
|
-
else
|
1417
|
-
`killall -9 adb`
|
1418
|
-
`killall -9 emulator`
|
1419
|
-
end
|
1568
|
+
do_uninstall(device_flag)
|
1569
|
+
kill_adb
|
1420
1570
|
|
1421
1571
|
$stdout.flush
|
1422
1572
|
|
@@ -1435,21 +1585,34 @@ namespace "run" do
|
|
1435
1585
|
load_app_and_run
|
1436
1586
|
end
|
1437
1587
|
|
1438
|
-
def
|
1588
|
+
def kill_adb
|
1589
|
+
# stop app
|
1590
|
+
if RUBY_PLATFORM =~ /windows|cygwin|mingw/
|
1591
|
+
# Windows
|
1592
|
+
`taskkill /F /IM adb.exe`
|
1593
|
+
else
|
1594
|
+
`killall -9 adb`
|
1595
|
+
end
|
1596
|
+
end
|
1597
|
+
|
1598
|
+
def run_emulator(options = {})
|
1439
1599
|
apkfile = Jake.get_absolute $targetdir + "/" + $appname + "-debug.apk"
|
1440
1600
|
|
1441
|
-
|
1442
|
-
|
1443
|
-
#adb_start_server = $adb + ' start-server'
|
1444
|
-
Thread.new { Jake.run($adb, ['start-server']) }
|
1601
|
+
kill_adb
|
1602
|
+
Jake.run($adb, ['start-server'], nil, true)
|
1445
1603
|
puts 'Sleep for 5 sec. waiting for "adb start-server"'
|
1446
1604
|
sleep 5
|
1447
1605
|
|
1606
|
+
if !$applog_file.nil?
|
1607
|
+
Thread.new { Jake.run($adb, ['logcat', '>>', $applog_path], nil, true) }
|
1608
|
+
end
|
1609
|
+
|
1448
1610
|
if $appavdname != nil
|
1449
1611
|
$avdname = $appavdname
|
1450
1612
|
end
|
1451
|
-
|
1452
|
-
|
1613
|
+
|
1614
|
+
createavd = "\"#{$androidbin}\" create avd --name #{$avdname} --target #{$avdtarget} --sdcard 32M "
|
1615
|
+
system("echo no | #{createavd}") unless File.directory?( File.join(ENV['HOME'], ".android", "avd", "#{$avdname}.avd" ) )
|
1453
1616
|
|
1454
1617
|
if $use_google_addon_api
|
1455
1618
|
avdini = File.join(ENV['HOME'], '.android', 'avd', "#{$avdname}.ini")
|
@@ -1464,26 +1627,39 @@ namespace "run" do
|
|
1464
1627
|
|
1465
1628
|
if !running
|
1466
1629
|
# Start the emulator, check on it every 5 seconds until it's running
|
1467
|
-
|
1630
|
+
cmd = "\"#{$emulator}\" -cpu-delay 0 -no-boot-anim"
|
1631
|
+
cmd << " -no-window" if options[:hidden]
|
1632
|
+
cmd << " -avd #{$avdname}"
|
1633
|
+
Thread.new { system(cmd) }
|
1468
1634
|
puts "Waiting up to 180 seconds for emulator..."
|
1469
1635
|
startedWaiting = Time.now
|
1470
1636
|
adbRestarts = 1
|
1471
1637
|
while (Time.now - startedWaiting < 180 )
|
1472
1638
|
sleep 5
|
1473
1639
|
now = Time.now
|
1474
|
-
emulatorState = ""
|
1475
|
-
Jake.run2($adb,["-e", "get-state"],{:system => false, :hideerrors => :false}) do |line|
|
1476
|
-
|
1477
|
-
|
1640
|
+
#emulatorState = ""
|
1641
|
+
#Jake.run2($adb,["-e", "get-state"],{:system => false, :hideerrors => :false}) do |line|
|
1642
|
+
# puts "RET: " + line
|
1643
|
+
# emulatorState += line
|
1644
|
+
#end
|
1645
|
+
started = false
|
1646
|
+
Jake.run2 $adb, ["-e", "shell", "ps"], :system => false, :hideerrors => false do |line|
|
1647
|
+
started = true if line =~ /android\.process\.acore/
|
1648
|
+
true
|
1478
1649
|
end
|
1479
|
-
if emulatorState =~ /unknown/
|
1650
|
+
#if emulatorState =~ /unknown/
|
1651
|
+
unless started
|
1480
1652
|
printf("%.2fs: ",(now - startedWaiting))
|
1481
1653
|
if (now - startedWaiting) > (60 * adbRestarts)
|
1482
1654
|
# Restart the adb server every 60 seconds to prevent eternal waiting
|
1483
1655
|
puts "Appears hung, restarting adb server"
|
1484
|
-
|
1485
|
-
|
1656
|
+
kill_adb
|
1657
|
+
Jake.run($adb, ['start-server'], nil, true)
|
1486
1658
|
adbRestarts += 1
|
1659
|
+
|
1660
|
+
if !$applog_file.nil?
|
1661
|
+
Thread.new { Jake.run($adb, ['logcat', '>>', $applog_path], nil, true) }
|
1662
|
+
end
|
1487
1663
|
else
|
1488
1664
|
puts "Still waiting..."
|
1489
1665
|
end
|
@@ -1506,13 +1682,13 @@ namespace "run" do
|
|
1506
1682
|
$stdout.flush
|
1507
1683
|
end
|
1508
1684
|
|
1509
|
-
def load_app_and_run
|
1510
|
-
puts "Loading package
|
1685
|
+
def load_app_and_run(device_flag = '-e')
|
1686
|
+
puts "Loading package"
|
1511
1687
|
apkfile = Jake.get_absolute $targetdir + "/" + $appname + "-debug.apk"
|
1512
1688
|
count = 0
|
1513
1689
|
done = false
|
1514
1690
|
while count < 20
|
1515
|
-
f = Jake.run2($adb, [
|
1691
|
+
f = Jake.run2($adb, [device_flag, "install", "-r", apkfile], {:nowait => true})
|
1516
1692
|
theoutput = ""
|
1517
1693
|
while c = f.getc
|
1518
1694
|
$stdout.putc c
|
@@ -1533,7 +1709,7 @@ namespace "run" do
|
|
1533
1709
|
end
|
1534
1710
|
|
1535
1711
|
puts "Loading complete, starting application.." if done
|
1536
|
-
run_application(
|
1712
|
+
run_application(device_flag) if done
|
1537
1713
|
end
|
1538
1714
|
|
1539
1715
|
desc "build and install on device"
|