rhodes 3.3.3.beta.4 → 3.3.3
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +7 -5
- data/CREDITS +2215 -0
- data/Rakefile +225 -59
- data/bin/c2dm.rb +0 -0
- data/bin/get-rhodes-info.bat +0 -0
- data/bin/migrate-rhodes-app +0 -0
- data/bin/migrate-rhodes-app.bat +0 -0
- data/bin/rhodes +0 -0
- data/bin/rhodes-setup +0 -0
- data/bin/rhodes-setup.bat +0 -0
- data/bin/rhogen +0 -0
- data/bin/rhogen.bat +0 -0
- data/bin/set-rhodes-sdk +0 -0
- data/bin/set-rhodes-sdk.bat +0 -0
- data/bin/upgrade-rhodes-app +0 -0
- data/bin/upgrade-rhodes-app.bat +0 -0
- data/doc/build.txt +20 -9
- data/doc/configuration.txt +8 -8
- data/doc/connect-to-web-services.txt +1 -1
- data/doc/device-caps.txt +63 -26
- data/doc/extensions.txt +14 -2
- data/doc/install.txt +28 -19
- data/doc/introduction.txt +6 -3
- data/doc/jqt-jqm-transition.txt +10 -9
- data/doc/release.txt +5 -1
- data/doc/rhodes-command-line.txt +130 -0
- data/doc/rhom.txt +16 -11
- data/doc/rhostudio-eclipse.txt +3 -3
- data/doc/simulator.txt +28 -31
- data/doc/syncengine-ajax-api.txt +246 -0
- data/doc/synchronization.txt +21 -3
- data/doc/test-log-debug.txt +3 -1
- data/doc/ui.txt +16 -16
- data/ext/extconf.rb +8 -0
- data/lib/build/jake.rb +5 -5
- data/lib/extensions/barcode/ext/barcode/platform/android/Rakefile +9 -9
- data/lib/extensions/barcode/ext/barcode/platform/android/jni/src/barcode.cpp +81 -1
- data/lib/extensions/barcode/ext/barcode/platform/android/src/com/google/zxing/client/android/CaptureActivityHandler.java +6 -13
- data/lib/extensions/barcode/ext/barcode/platform/android/src/com/google/zxing/client/android/DecodeHandler.java +2 -6
- data/lib/extensions/barcode/ext/barcode/platform/android/src/com/rhomobile/barcode/Barcode.java +12 -1
- data/lib/extensions/barcode/ext/barcode/platform/bb/run.bat +0 -0
- data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeCallbackHelper.h +2 -0
- data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeCallbackHelper.mm +36 -0
- data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeViewController.h +0 -0
- data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/BarcodeViewController.m +15 -5
- data/lib/extensions/barcode/ext/barcode/platform/iphone/Classes/barcode.m +64 -1
- data/lib/extensions/barcode/ext/barcode/shared/ruby/barcode.i +35 -1
- data/lib/extensions/barcode/ext/barcode/shared/ruby/barcode_wrap.c +126 -2
- data/lib/extensions/barcode/ext/barcode/shared/src/zbar.c +18 -1
- data/lib/extensions/barcode/ext/build +0 -0
- data/lib/extensions/barcode/ext/build.bat +0 -0
- data/lib/extensions/digest-md5/ext/Rakefile +12 -10
- data/lib/extensions/digest-md5/ext/build +0 -0
- data/lib/extensions/digest-md5/ext/build.bat +0 -0
- data/lib/extensions/digest-md5/ext/digest-md5.sln +2 -2
- data/lib/extensions/digest-md5/ext/digest-md5.vcproj +41 -28
- data/lib/extensions/digest-sha1/ext/Rakefile +11 -10
- data/lib/extensions/digest-sha1/ext/build +0 -0
- data/lib/extensions/digest-sha1/ext/build.bat +0 -0
- data/lib/extensions/digest-sha1/ext/digest-sha1.sln +2 -2
- data/lib/extensions/digest-sha1/ext/digest-sha1.vcproj +41 -28
- data/lib/extensions/digest/ext/Rakefile +12 -11
- data/lib/extensions/digest/ext/build +0 -0
- data/lib/extensions/digest/ext/build.bat +0 -0
- data/lib/extensions/digest/ext/digest.sln +44 -0
- data/lib/extensions/digest/ext/digest.vcproj +40 -27
- data/lib/extensions/esri/ext/build +0 -0
- data/lib/extensions/esri/ext/build.bat +0 -0
- data/lib/extensions/fcntl/ext/Rakefile +10 -9
- data/lib/extensions/fcntl/ext/build +0 -0
- data/lib/extensions/fcntl/ext/build.bat +0 -0
- data/lib/extensions/fcntl/ext/fcntl.vcproj +1 -1
- data/lib/extensions/nfc/ext/build +0 -0
- data/lib/extensions/nfc/ext/build.bat +0 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/Rakefile +11 -11
- data/lib/extensions/nfc/ext/nfc/platform/android/jni/src/nfc.cpp +0 -0
- data/lib/extensions/nfc/ext/nfc/platform/android/src/com/rhomobile/nfc/Nfc.java +12 -10
- data/lib/extensions/nfc/ext/nfc/shared/ruby/nfc_wrap.c +16 -9
- data/lib/extensions/pdf-writer/color.rb +145 -0
- data/lib/extensions/pdf-writer/color/cmyk.rb +279 -0
- data/lib/extensions/pdf-writer/color/css.rb +28 -0
- data/lib/extensions/pdf-writer/color/grayscale.rb +212 -0
- data/lib/extensions/pdf-writer/color/hsl.rb +221 -0
- data/lib/extensions/pdf-writer/color/palette.rb +16 -0
- data/lib/extensions/pdf-writer/color/palette/adobecolor.rb +272 -0
- data/lib/extensions/pdf-writer/color/palette/gimp.rb +116 -0
- data/lib/extensions/pdf-writer/color/palette/monocontrast.rb +180 -0
- data/lib/extensions/pdf-writer/color/rgb-colors.rb +355 -0
- data/lib/extensions/pdf-writer/color/rgb.rb +453 -0
- data/lib/extensions/pdf-writer/color/rgb/metallic.rb +43 -0
- data/lib/extensions/pdf-writer/color/yiq.rb +84 -0
- data/lib/extensions/pdf-writer/ext/LICENSES/color/Licence.txt +27 -0
- data/lib/extensions/pdf-writer/ext/LICENSES/color/README.txt +32 -0
- data/lib/extensions/pdf-writer/ext/LICENSES/pdf-writer/LICENCE +131 -0
- data/lib/extensions/pdf-writer/ext/LICENSES/pdf-writer/README +33 -0
- data/lib/extensions/pdf-writer/ext/LICENSES/transaction-simple/Licence.txt +25 -0
- data/lib/extensions/pdf-writer/ext/LICENSES/transaction-simple/Readme.txt +204 -0
- data/lib/extensions/pdf-writer/pdf/charts.rb +13 -0
- data/lib/extensions/pdf-writer/pdf/charts/stddev.rb +430 -0
- data/lib/extensions/pdf-writer/pdf/math.rb +108 -0
- data/lib/extensions/pdf-writer/pdf/quickref.rb +332 -0
- data/lib/extensions/pdf-writer/pdf/simpletable.rb +947 -0
- data/lib/extensions/pdf-writer/pdf/techbook.rb +901 -0
- data/lib/extensions/pdf-writer/pdf/writer.rb +2729 -0
- data/lib/extensions/pdf-writer/pdf/writer/arc4.rb +63 -0
- data/lib/extensions/pdf-writer/pdf/writer/fontmetrics.rb +203 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-Bold.afm +342 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-BoldOblique.afm +342 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier-Oblique.afm +342 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Courier.afm +342 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-Bold.afm +2827 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-BoldOblique.afm +2827 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica-Oblique.afm +3051 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Helvetica.afm +3051 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/MustRead.html +19 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Symbol.afm +213 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Bold.afm +2588 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-BoldItalic.afm +2384 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Italic.afm +2667 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/Times-Roman.afm +2419 -0
- data/lib/extensions/pdf-writer/pdf/writer/fonts/ZapfDingbats.afm +225 -0
- data/lib/extensions/pdf-writer/pdf/writer/graphics.rb +813 -0
- data/lib/extensions/pdf-writer/pdf/writer/graphics/imageinfo.rb +365 -0
- data/lib/extensions/pdf-writer/pdf/writer/lang.rb +43 -0
- data/lib/extensions/pdf-writer/pdf/writer/lang/en.rb +99 -0
- data/lib/extensions/pdf-writer/pdf/writer/object.rb +23 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/action.rb +35 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/annotation.rb +42 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/catalog.rb +39 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/contents.rb +65 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/destination.rb +40 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/encryption.rb +53 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/font.rb +72 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/fontdescriptor.rb +34 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/fontencoding.rb +40 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/image.rb +304 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/info.rb +51 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/outline.rb +30 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/outlines.rb +30 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/page.rb +195 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/pages.rb +115 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/procset.rb +46 -0
- data/lib/extensions/pdf-writer/pdf/writer/object/viewerpreferences.rb +74 -0
- data/lib/extensions/pdf-writer/pdf/writer/ohash.rb +58 -0
- data/lib/extensions/pdf-writer/pdf/writer/oreader.rb +25 -0
- data/lib/extensions/pdf-writer/pdf/writer/state.rb +48 -0
- data/lib/extensions/pdf-writer/pdf/writer/strokestyle.rb +138 -0
- data/lib/extensions/pdf-writer/transaction/simple.rb +486 -0
- data/lib/extensions/pdf-writer/transaction/simple/group.rb +146 -0
- data/lib/extensions/pdf-writer/transaction/simple/threadsafe.rb +68 -0
- data/lib/extensions/pdf-writer/transaction/simple/threadsafe/group.rb +36 -0
- data/lib/framework/builtinME.rb +0 -0
- data/lib/framework/dateOrig.rb +8 -2
- data/lib/framework/rational.rb +0 -0
- data/lib/framework/res/esri.wm.png +0 -0
- data/lib/framework/rho/rho.rb +6 -0
- data/lib/framework/rho/rhobluetooth.rb +0 -0
- data/lib/framework/rho/rhofsconnector.rb +0 -0
- data/lib/framework/rho/rhonativeviewmanager.rb +0 -0
- data/lib/framework/rhofsconnector.rb +0 -0
- data/lib/framework/rhom/rhom_object_factory.rb +8 -0
- data/lib/framework/rhomotoapi.rb +3 -2
- data/platform/android/Rhodes/jni/include/rhodes/JNIRhodes.h +9 -1
- data/platform/android/Rhodes/jni/include/rhodes/details/rhojava.inc +1 -0
- data/platform/android/Rhodes/jni/include/rhodes/jni/com_rhomobile_rhodes_file_RhoFileApi.h +26 -2
- data/platform/android/Rhodes/jni/src/callbacks.cpp +0 -5
- data/platform/android/Rhodes/jni/src/camera.cpp +1 -1
- data/platform/android/Rhodes/jni/src/fileapi.cpp +39 -19
- data/platform/android/Rhodes/jni/src/geolocation.cpp +3 -3
- data/platform/android/Rhodes/jni/src/mapview.cpp +206 -64
- data/platform/android/Rhodes/jni/src/nativeview.cpp +1 -1
- data/platform/android/Rhodes/jni/src/rhodes.cpp +13 -0
- data/platform/android/Rhodes/jni/src/rhodesapp.cpp +20 -0
- data/platform/android/Rhodes/jni/src/rhodessystem.cpp +36 -3
- data/platform/android/Rhodes/jni/src/signature.cpp +22 -2
- data/platform/android/Rhodes/res/drawable/alert_info.png +0 -0
- data/platform/android/Rhodes/res/drawable/esri.png +0 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/Capabilities.java +17 -16
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/Logger.java +4 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/MemoryInfoCollector.java +67 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +139 -114
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +106 -13
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +11 -3
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/WebView.java +71 -16
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraNewService.java +4 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/camera/CameraSemiService.java +4 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoExtension.java +22 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/Config.java +243 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtManager.java +19 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtension.java +9 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/{RhodesActivityListener.java → extmanager/IRhoListener.java} +16 -12
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManager.java +63 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManagerImpl.java +239 -14
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhodesStartupListeners.java +9 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/WebkitExtension.java +53 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/file/RhoFileApi.java +27 -12
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocation.java +124 -62
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java +49 -137
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +84 -114
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SplashScreen.java +75 -82
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/TabbedMainView.java +3 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/Callout.java +4 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapBitmapManager.java +124 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/MapView.java +232 -43
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/mapview/Request.java +193 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/IRhoCustomView.java +13 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoNativeViewManager.java +32 -23
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/nativeview/RhoVideoView.java +74 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality.java +6 -7
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality01.java +37 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality03.java +14 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality05.java +51 -38
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality07.java +9 -1
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality08.java +48 -31
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionalityManager.java +15 -16
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/signature/Signature.java +52 -15
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/uri/LocalFileHandler.java +20 -2
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientOld.java +1 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/GoogleWebView.java +77 -34
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/IRhoWebView.java +9 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebChromeClient.java +105 -0
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebViewClient.java +1 -1
- data/platform/android/build/RhodesSRC_build.files +8 -7
- data/platform/android/build/android.rake +326 -216
- data/platform/android/build/androidcommon.rb +27 -13
- data/platform/bb/RubyVM/src/com/rho/file/SimpleFile.java +27 -1
- data/platform/bb/RubyVM/src/j2me/io/File.java +104 -38
- data/platform/bb/build/bb.rake +1 -0
- data/platform/bb/build/runRAPC.bat +0 -0
- data/platform/bb/rhodes/resources/background.png +0 -0
- data/platform/bb/rhodes/resources/esri.png +0 -0
- data/platform/bb/rhodes/resources/mappin.png +0 -0
- data/platform/bb/rhodes/src/com/rho/rubyext/System.java +5 -1
- data/platform/bb/rhodes/src/rhomobile/PushListeningThread.java +2 -2
- data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapField.java +0 -0
- data/platform/bb/rhodes/src/rhomobile/mapview/ESRIMapProvider.java +0 -0
- data/platform/bb/rhodes/src/rhomobile/mapview/GeoCoding.java +0 -0
- data/platform/bb/rhodes/src/rhomobile/mapview/GoogleGeoCoding.java +0 -0
- data/platform/bb/rhodes/src/rhomobile/mapview/MapTools.java +0 -0
- data/platform/iphone/Classes/AppManager/AppManager.m +7 -1
- data/platform/iphone/Classes/Camera/PickImageDelegate.h +9 -0
- data/platform/iphone/Classes/Camera/PickImageDelegate.m +75 -4
- data/platform/iphone/Classes/GeoLocation/LocationController.h +8 -2
- data/platform/iphone/Classes/GeoLocation/LocationController.m +74 -76
- data/platform/iphone/Classes/InitMemoryInfoCollector.h +33 -0
- data/platform/iphone/Classes/InitMemoryInfoCollector.mm +52 -0
- data/platform/iphone/Classes/NativeView/NVViewController.h +0 -0
- data/platform/iphone/Classes/NativeView/NVViewController.m +34 -2
- data/platform/iphone/Classes/Rhodes.m +22 -2
- data/platform/iphone/Classes/Signature/SignatureDelegate.m +19 -0
- data/platform/iphone/Classes/Signature/SignatureViewController.h +0 -0
- data/platform/iphone/Classes/Signature/SignatureViewController.m +0 -0
- data/platform/iphone/Classes/SimpleMainView.h +0 -0
- data/platform/iphone/Classes/SimpleMainView.m +3 -3
- data/platform/iphone/ESRI/BluePushpin.png +0 -0
- data/platform/iphone/ESRI/BluePushpin@2x.png +0 -0
- data/platform/iphone/ESRI/esri.png +0 -0
- data/platform/iphone/ESRI/esri@2x.png +0 -0
- data/platform/iphone/rbuild/iphone.rake +75 -7
- data/platform/iphone/rhorunner.xcodeproj/project.pbxproj +13 -4
- data/platform/linux/target/compiler/rubylinux +0 -0
- data/platform/mac/target/compiler/RubyMac +0 -0
- data/platform/osx/Rhodes Launcher/rhorunner.app/rhorunner b/data/platform/osx/Rhodes → Launcher/rhorunner.app/rhorunner +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/Resources/qt_menu.nib/keyedobjects.nib +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/build/osx.rake +6 -8
- data/platform/shared/RhoConnectClient/RhoConnectClient.cpp +165 -33
- data/platform/shared/RhoConnectClient/RhoConnectClient.h +10 -1
- data/platform/shared/common/BundleManager.cpp +27 -16
- data/platform/shared/common/ExtManager.h +15 -2
- data/platform/shared/common/RhoConf.cpp +17 -2
- data/platform/shared/common/RhoConf.h +3 -1
- data/platform/shared/common/RhoDefs.h +6 -6
- data/platform/shared/common/RhoFatalError.h +1 -1
- data/platform/shared/common/RhoFile.cpp +9 -9
- data/platform/shared/common/RhoFilePath.h +7 -3
- data/platform/shared/common/RhoPort.h +3 -3
- data/platform/shared/common/RhoSystem.h +1 -1
- data/platform/shared/common/RhodesApp.cpp +426 -26
- data/platform/shared/common/RhodesApp.h +11 -3
- data/platform/shared/common/RhodesAppBase.cpp +4 -1
- data/platform/shared/common/StringConverter.h +3 -3
- data/platform/shared/common/app_build_capabilities.h +8 -0
- data/platform/shared/common/map/BaseMapEngine.cpp +302 -21
- data/platform/shared/common/map/BaseMapEngine.h +132 -6
- data/platform/shared/common/map/ESRIMapEngine.cpp +2 -1
- data/platform/shared/common/map/GeocodingMapEngine.cpp +22 -4
- data/platform/shared/common/map/GeocodingMapEngine.h +40 -0
- data/platform/shared/common/map/GoogleMapEngine.cpp +13 -1
- data/platform/shared/common/map/MapEngine.h +7 -0
- data/platform/shared/common/map/OSMMapEngine.cpp +12 -1
- data/platform/shared/json/JSONIterator.cpp +1 -1
- data/platform/shared/json/RJSONTokener.c +2 -0
- data/platform/shared/json/config.h +3 -3
- data/platform/shared/logging/RhoLog.cpp +12 -3
- data/platform/shared/logging/RhoLog.h +2 -1
- data/platform/shared/logging/RhoLogConf.cpp +147 -11
- data/platform/shared/logging/RhoLogConf.h +39 -1
- data/platform/shared/logging/RhoLogSink.cpp +1 -1
- data/platform/shared/net/HttpServer.cpp +8 -4
- data/platform/shared/net/INetRequest.cpp +7 -0
- data/platform/shared/net/INetRequest.h +2 -0
- data/platform/shared/net/RawSocket.cpp +1 -1
- data/platform/shared/qt/pbxproj2pro.pl +0 -0
- data/platform/shared/qt/pro_vcproj_diff.pl +0 -0
- data/platform/shared/qt/rhodes/QtMainWindow.cpp +1 -1
- data/platform/shared/qt/rhodes/impl/RhoClassFactoryImpl.h +2 -2
- data/platform/shared/qt/rhodes/impl/RhoThreadImpl.cpp +2 -2
- data/platform/shared/qt/rhodes/impl/SystemImpl.cpp +11 -1
- data/platform/shared/qt/rhodes/main.cpp +5 -5
- data/platform/shared/ruby/ext/alert/alert_wrap.c +8 -8
- data/platform/shared/ruby/ext/bluetooth/bluetooth.i +0 -0
- data/platform/shared/ruby/ext/bluetooth/bluetooth_wrap.c +16 -9
- data/platform/shared/ruby/ext/camera/camera.i +2 -2
- data/platform/shared/ruby/ext/camera/camera_wrap.c +18 -3
- data/platform/shared/ruby/ext/datetimepicker/datetimepicker_wrap.c +37 -8
- data/platform/shared/ruby/ext/geolocation/geolocation_wrap.c +8 -8
- data/platform/shared/ruby/ext/mapview/mapview_wrap.c +16 -9
- data/platform/shared/ruby/ext/nativebar/nativebar_wrap.c +16 -9
- data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager.i +0 -0
- data/platform/shared/ruby/ext/nativeviewmanager/nativeviewmanager_wrap.c +16 -9
- data/platform/shared/ruby/ext/phonebook/phonebook_wrap.c +8 -1
- data/platform/shared/ruby/ext/rho/rhoruby.c +7 -1
- data/platform/shared/ruby/ext/rho/rhoruby.h +1 -0
- data/platform/shared/ruby/ext/rhoconf/rhoconf_wrap.c +16 -9
- data/platform/shared/ruby/ext/signature/signature.i +0 -0
- data/platform/shared/ruby/ext/signature/signature_wrap.c +9 -9
- data/platform/shared/ruby/ext/syncengine/syncengine_wrap.c +16 -9
- data/platform/shared/ruby/ext/system/system_wrap.c +16 -9
- data/platform/shared/ruby/ext/webview/webview_wrap.c +16 -9
- data/platform/shared/ruby/gc.c +1 -0
- data/platform/shared/ruby/regint.h +6 -4
- data/platform/shared/ruby/vm.c +1 -0
- data/platform/shared/ruby/wince/wince.h +1 -1
- data/platform/shared/rubyext/System.cpp +1 -1
- data/platform/shared/shttpd/src/rdispatcher.c +3 -3
- data/platform/shared/shttpd/src/std_includes.h +1 -1
- data/platform/shared/sqlite/sqlite3.c +1 -0
- data/platform/shared/statistic/test/TestProfiling.cpp +1 -1
- data/platform/shared/stlport/build/lib/configure +0 -0
- data/platform/shared/stlport/build/lib/configure.bat +0 -0
- data/platform/shared/sync/SyncEngine.cpp +9 -12
- data/platform/shared/sync/SyncNotify.cpp +36 -3
- data/platform/shared/sync/SyncNotify.h +11 -4
- data/platform/shared/sync/SyncSource.cpp +32 -16
- data/platform/shared/sync/SyncSource.h +2 -3
- data/platform/shared/sync/SyncThread.cpp +13 -4
- data/platform/shared/sync/SyncThread.h +4 -0
- data/platform/shared/tcmalloc/page_heap.h +1 -1
- data/platform/shared/tcmalloc/rhomem.h +1 -1
- data/platform/shared/tcmalloc/windows/port.cpp +12 -3
- data/platform/shared/test/Tests.cpp +4 -4
- data/platform/shared/test/test_helper.cpp +4 -4
- data/platform/symbian/sqlite3/src/sqlite3.h +1 -1
- data/platform/win32/RhoSimulator/Microsoft.VC90.CRT.manifest +6 -0
- data/platform/win32/RhoSimulator/Microsoft.VC90.OpenMP.manifest +6 -0
- 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/libeay32.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/ssleay32.dll +0 -0
- data/platform/win32/RhoSimulator/vcomp90.dll +0 -0
- data/platform/win32/target/replaceicon/replaceicon.exe +0 -0
- data/platform/win32/target/updateresstring/updateresstring.exe +0 -0
- data/platform/wm/RhoLib/RhoLib.vcproj +394 -69
- data/platform/wm/build/build_inf.js +83 -23
- data/platform/wm/build/wm.rake +127 -81
- data/platform/wm/rhodes.sln +6 -6
- data/platform/wm/rhodes/DateTimePicker.h +2 -2
- data/platform/wm/rhodes/IBrowserEngine.h +3 -0
- data/platform/wm/rhodes/IEBrowserEngine.cpp +34 -2
- data/platform/wm/rhodes/IEBrowserEngine.h +4 -1
- data/platform/wm/rhodes/LicenseStub.cpp +73 -0
- data/platform/{android/Rhodes/src/com/rhomobile/rhodes/webview/ChromeClientNew.java → wm/rhodes/LogMemory.cpp} +32 -20
- data/platform/{android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettings.java → wm/rhodes/LogMemory.h} +11 -8
- data/platform/wm/rhodes/LogOptionsDlg.h +1 -1
- data/platform/wm/rhodes/LogView.cpp +10 -10
- data/platform/wm/rhodes/LogView.h +10 -10
- data/platform/wm/rhodes/MainWindow.cpp +431 -173
- data/platform/wm/rhodes/MainWindow.h +37 -19
- data/platform/wm/rhodes/MapView/MapViewManager.h +1 -1
- data/platform/wm/rhodes/OkCancelModalDialog.h +1 -1
- data/platform/wm/rhodes/Rhodes.cpp +210 -47
- data/platform/wm/rhodes/Rhodes.rc +38 -0
- data/platform/wm/rhodes/bluetooth/Bluetooth.cpp +2 -2
- data/platform/wm/rhodes/bluetooth/Bluetooth.h +3 -3
- data/platform/wm/rhodes/camera/Camera.cpp +2 -1
- data/platform/wm/rhodes/camera/Camera.h +1 -1
- data/platform/wm/rhodes/resource.h +1 -1
- data/platform/wm/rhodes/rho/common/ExtManager.cpp +93 -5
- data/platform/wm/rhodes/rho/net/NetRequestImpl.cpp +2 -2
- data/platform/wm/rhodes/rho/rubyext/NativeToolbar.cpp +2 -2
- data/platform/wm/rhodes/rho/rubyext/SystemImpl.cpp +13 -7
- data/platform/wm/rhodes/rhodes.vcproj +1409 -1008
- data/platform/wm/rhodes/simulator/MainWindowQt.h +1 -1
- data/platform/wm/rhodes/stdafx.h +2 -2
- data/platform/wm/rhoelements.sln +7 -9
- data/platform/wm/rubylib/rubylib.vcproj +62 -1
- data/platform/wm/sqlite3/sqlite3.vcproj +62 -1
- data/platform/wm/syncengine/syncengine.vcproj +62 -1
- data/platform/wm/tcmalloc/tcmalloc.vcproj +72 -53
- data/platform/wm/tools/detool/detool.cpp +1435 -1357
- data/platform/wp7/RhoRubyExtGen/GenerateInitializers.cmd +0 -0
- data/platform/wp7/RhoRubyLib/common/RhoLicense.cs +105 -0
- data/platform/wp7/RhoRubyLib/common/RhodesApp.cs +23 -5
- data/platform/wp7/RhoRubyLib/sync/SyncNotify.cs +5 -0
- data/platform/wp7/RhoRubyLib/views/RhoView.xaml.cs +22 -3
- data/platform/wp7/build/wp.rake +1 -0
- data/platform/wp7/rhodes/MainPage.xaml.cs +11 -0
- data/rakefile.rb +225 -59
- data/res/build-tools/7za.exe +0 -0
- data/res/build-tools/RhoAppRunner.exe +0 -0
- data/res/build-tools/RhoLogServer.exe +0 -0
- data/res/build-tools/RhoRuby.exe +0 -0
- data/res/build-tools/RubyMac +0 -0
- data/res/build-tools/detool.exe +0 -0
- data/res/build-tools/iphonesim/Source/iPhoneSimulator.m +1 -1
- data/res/build-tools/iphonesim/build/Release/iphonesim +0 -0
- data/res/build-tools/iphonesim/build/Release/iphonesim_43 +0 -0
- data/res/build-tools/license_rc.dll +0 -0
- data/res/build-tools/make.exe +0 -0
- data/res/build-tools/rubylinux +0 -0
- data/res/build-tools/swig_patch/Lib/typemaps/fragments.swg +235 -0
- data/res/build-tools/wmdc_connect.exe +0 -0
- data/res/build-tools/wp7explorer.exe +0 -0
- data/res/generators/rhogen.rb +2 -2
- data/res/generators/templates/application/app/Settings/controller.rb +1 -1
- data/res/generators/templates/application/app/layout.erb +1 -1
- data/res/generators/templates/application/app/loading.png +0 -0
- data/res/generators/templates/application/public/css/re_webkit.css +736 -0
- data/res/generators/templates/application/public/css/windows_mobile.css +0 -0
- data/res/generators/templates/application/public/images/listArrow.png +0 -0
- data/res/generators/templates/application/public/jqmobile/images/ajax-loader.png +0 -0
- data/res/generators/templates/application/public/jqmobile/images/icons-18-black.png +0 -0
- data/res/generators/templates/application/public/jqmobile/images/icons-18-white.png +0 -0
- data/res/generators/templates/application/public/jqmobile/images/icons-36-black.png +0 -0
- data/res/generators/templates/application/public/jqmobile/images/icons-36-white.png +0 -0
- data/res/generators/templates/application/public/js/syncengine.js +409 -52
- data/res/generators/templates/extension/extensions/montana/ext/build +0 -0
- data/res/generators/templates/extension/extensions/montana/ext/build.bat +0 -0
- data/res/generators/templates/extension/extensions/montana/ext/montana/platform/android/Rakefile +10 -10
- data/res/generators/templates/spec/app/SpecRunner/controller.rb +2 -0
- data/res/libs/motorolalicence/android/MotorolaLicence.h +13 -0
- data/res/libs/motorolalicence/android/libMotorolaLicence.a +0 -0
- data/res/libs/motorolalicence/iphone/MotorolaLicence.h +13 -0
- data/res/libs/motorolalicence/iphone/libMotorolaLicence.a +0 -0
- data/rhodes.gemspec +1 -1
- data/spec/framework_spec/app/SpecRunner/controller.rb +2 -0
- data/spec/phone_spec/app/SpecRunner/controller.rb +2 -0
- data/version +1 -1
- metadata +487 -412
- data/Manifest.txt +0 -7960
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivityStartupListeners.java +0 -12
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsNew.java +0 -52
- data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebSettingsOld.java +0 -62
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/Frameworks/phonon.framework/Versions/4/phonon +0 -0
- data/platform/osx/bin/RhoSimulator/RhoSimulator.app/Contents/PlugIns/phonon_backend/libphonon_qt7.dylib +0 -0
- data/platform/win32/RhoSimulator/Microsoft.VC80.CRT.manifest +0 -8
- data/platform/win32/RhoSimulator/Microsoft.VC80.OpenMP.manifest +0 -7
- data/platform/win32/RhoSimulator/msvcm80.dll +0 -0
- data/platform/win32/RhoSimulator/msvcp80.dll +0 -0
- data/platform/win32/RhoSimulator/msvcr80.dll +0 -0
- data/platform/win32/RhoSimulator/vcomp.dll +0 -0
- data/rhomobile-debug-1.0.6.gem +0 -0
@@ -38,16 +38,18 @@
|
|
38
38
|
|
39
39
|
@implementation RhoCameraSettings
|
40
40
|
|
41
|
-
@synthesize callback_url, camera_type, color_model, format, width, height, enable_editing;
|
41
|
+
@synthesize callback_url, camera_type, color_model, format, width, height, enable_editing, enable_editing_setted, save_to_shared_gallery;
|
42
42
|
|
43
43
|
- (id)init:(void*)data url:(NSString*)url{
|
44
44
|
self.callback_url = url;
|
45
45
|
self.camera_type = CAMERA_SETTINGS_TYPE_MAIN;
|
46
46
|
self.color_model = CAMERA_SETTINGS_COLOR_MODEL_RGB;
|
47
|
-
self.format =
|
47
|
+
self.format = CAMERA_SETTINGS_FORMAT_NOT_SETTED;
|
48
48
|
self.width = 0;
|
49
49
|
self.height = 0;
|
50
50
|
self.enable_editing = 1;
|
51
|
+
self.enable_editing_setted = 0;
|
52
|
+
self.save_to_shared_gallery = false;
|
51
53
|
|
52
54
|
if (data != NULL) {
|
53
55
|
rho_param* p =(rho_param*)data;
|
@@ -71,6 +73,10 @@
|
|
71
73
|
if (strcasecmp(value->v.string, "png") == 0) {
|
72
74
|
self.format = CAMERA_SETTINGS_FORMAT_PNG;
|
73
75
|
}
|
76
|
+
else {
|
77
|
+
self.format = CAMERA_SETTINGS_FORMAT_JPG;
|
78
|
+
}
|
79
|
+
|
74
80
|
}
|
75
81
|
if (strcasecmp(name, "desired_width") == 0) {
|
76
82
|
NSString* s = [NSString stringWithUTF8String:value->v.string];
|
@@ -82,10 +88,16 @@
|
|
82
88
|
}
|
83
89
|
if (strcasecmp(name, "enable_editing") == 0) {
|
84
90
|
self.enable_editing = 1;
|
91
|
+
self.enable_editing_setted = 1;
|
85
92
|
if (strcasecmp(value->v.string, "false") == 0) {
|
86
93
|
self.enable_editing = 0;
|
87
94
|
}
|
88
95
|
}
|
96
|
+
if (strcasecmp(name, "save_to_shared_gallery") == 0 ) {
|
97
|
+
if ( strcasecmp(value->v.string, "true") == 0 ) {
|
98
|
+
self.save_to_shared_gallery = true;
|
99
|
+
}
|
100
|
+
}
|
89
101
|
|
90
102
|
}
|
91
103
|
|
@@ -264,6 +276,9 @@
|
|
264
276
|
int imageWidth = (int)img.size.width;
|
265
277
|
int imageHeight = (int)img.size.height;
|
266
278
|
|
279
|
+
if ( settings.save_to_shared_gallery ) {
|
280
|
+
UIImageWriteToSavedPhotosAlbum(img, nil, nil, nil);
|
281
|
+
}
|
267
282
|
|
268
283
|
|
269
284
|
NSString *filename = nil;
|
@@ -321,10 +336,58 @@
|
|
321
336
|
// isError ? "Can't write image to the storage." : "", 0 );
|
322
337
|
}
|
323
338
|
|
339
|
+
|
340
|
+
- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
|
341
|
+
{
|
342
|
+
if (settings.format == CAMERA_SETTINGS_FORMAT_NOT_SETTED) {
|
343
|
+
NSURL* url = (NSURL*)[info objectForKey:UIImagePickerControllerReferenceURL];
|
344
|
+
//const char* cs_url = [[url path] UTF8String];
|
345
|
+
if (url != nil) {
|
346
|
+
NSString* ext = [url pathExtension];
|
347
|
+
//const char* cs_ext = [ext UTF8String];
|
348
|
+
if (ext != nil) {
|
349
|
+
if (([ext compare:@"jpg" options:NSCaseInsensitiveSearch] == NSOrderedSame) || ([ext compare:@"jpeg" options:NSCaseInsensitiveSearch] == NSOrderedSame)) {
|
350
|
+
// jpg
|
351
|
+
settings.format = CAMERA_SETTINGS_FORMAT_JPG;
|
352
|
+
}
|
353
|
+
if (([ext compare:@"png" options:NSCaseInsensitiveSearch] == NSOrderedSame)) {
|
354
|
+
// png
|
355
|
+
settings.format = CAMERA_SETTINGS_FORMAT_PNG;
|
356
|
+
}
|
357
|
+
}
|
358
|
+
}
|
359
|
+
if (settings.format == CAMERA_SETTINGS_FORMAT_NOT_SETTED) {
|
360
|
+
settings.format = CAMERA_SETTINGS_FORMAT_JPG;
|
361
|
+
}
|
362
|
+
}
|
363
|
+
UIImage* image = (UIImage*)[info objectForKey:UIImagePickerControllerEditedImage];
|
364
|
+
if (image == nil) {
|
365
|
+
image = (UIImage*)[info objectForKey:UIImagePickerControllerOriginalImage];
|
366
|
+
}
|
367
|
+
if (image != nil) {
|
368
|
+
[self useImage:image];
|
369
|
+
}
|
370
|
+
else {
|
371
|
+
rho_rhodesapp_callCameraCallback([postUrl UTF8String], "", "", 1);
|
372
|
+
}
|
373
|
+
// Remove the picker interface and release the picker object.
|
374
|
+
[picker dismissModalViewControllerAnimated:YES];
|
375
|
+
[picker.view removeFromSuperview];
|
376
|
+
//picker.view.hidden = YES;
|
377
|
+
[picker release];
|
378
|
+
#ifdef __IPHONE_3_2
|
379
|
+
[popover dismissPopoverAnimated:YES];
|
380
|
+
#endif
|
381
|
+
}
|
382
|
+
|
383
|
+
|
324
384
|
- (void)imagePickerController:(UIImagePickerController *)picker
|
325
385
|
didFinishPickingImage:(UIImage *)image
|
326
386
|
editingInfo:(NSDictionary *)editingInfo
|
327
387
|
{
|
388
|
+
if (settings.format == CAMERA_SETTINGS_FORMAT_NOT_SETTED) {
|
389
|
+
settings.format = CAMERA_SETTINGS_FORMAT_JPG;
|
390
|
+
}
|
328
391
|
//If image editing is enabled and the user successfully picks an image, the image parameter of the
|
329
392
|
//imagePickerController:didFinishPicking Image:editingInfo:method contains the edited image.
|
330
393
|
//You should treat this image as the selected image, but if you want to store the original image, you can get
|
@@ -373,14 +436,22 @@
|
|
373
436
|
void take_picture(char* callback_url, rho_param *options_hash) {
|
374
437
|
NSString *url = [NSString stringWithUTF8String:callback_url];
|
375
438
|
RhoCameraSettings* settings = [[RhoCameraSettings alloc] init:options_hash url:url];
|
439
|
+
if (settings.format == CAMERA_SETTINGS_FORMAT_NOT_SETTED) {
|
440
|
+
settings.format = CAMERA_SETTINGS_FORMAT_JPG;
|
441
|
+
}
|
376
442
|
[[Rhodes sharedInstance] performSelectorOnMainThread:@selector(takePicture:)
|
377
443
|
withObject:settings waitUntilDone:NO];
|
378
444
|
}
|
379
445
|
|
380
|
-
void choose_picture(char* callback_url) {
|
446
|
+
void choose_picture(char* callback_url, rho_param *options_hash) {
|
381
447
|
NSString *url = [NSString stringWithUTF8String:callback_url];
|
448
|
+
RhoCameraSettings* settings = [[RhoCameraSettings alloc] init:options_hash url:url];
|
449
|
+
if (!settings.enable_editing_setted) {
|
450
|
+
settings.enable_editing = 1;
|
451
|
+
}
|
452
|
+
settings.camera_type = CAMERA_SETTINGS_TYPE_CHOOSE_IMAGE;
|
382
453
|
[[Rhodes sharedInstance] performSelectorOnMainThread:@selector(choosePicture:)
|
383
|
-
withObject:
|
454
|
+
withObject:settings waitUntilDone:NO];
|
384
455
|
}
|
385
456
|
|
386
457
|
|
@@ -28,9 +28,11 @@
|
|
28
28
|
|
29
29
|
@interface LocationController : NSObject<CLLocationManagerDelegate> {
|
30
30
|
CLLocationManager* _locationManager;
|
31
|
-
|
32
|
-
|
31
|
+
NSTimer* timer;
|
32
|
+
int gps_callback_interval;
|
33
|
+
BOOL isFirstUpdateFromPlatform;
|
33
34
|
bool isErrorState;
|
35
|
+
BOOL isEnabled;
|
34
36
|
|
35
37
|
@public
|
36
38
|
double _dLatitude, _dLongitude, _dAccuracy;
|
@@ -60,6 +62,10 @@
|
|
60
62
|
- (void)locationManager:(CLLocationManager *)manager
|
61
63
|
didFailWithError:(NSError *)error;
|
62
64
|
|
65
|
+
- (void)onTimerFired:(NSTimer*)theTimer;
|
66
|
+
|
67
|
+
- (void)resetTimerWithNewInterval:(int)interval;
|
68
|
+
|
63
69
|
+ (LocationController *)sharedInstance;
|
64
70
|
|
65
71
|
@end
|
@@ -20,9 +20,9 @@
|
|
20
20
|
int rho_rhodesapp_check_mode();
|
21
21
|
int rho_conf_getInt(const char *);
|
22
22
|
|
23
|
-
|
24
|
-
static CFTimeInterval timeOutInSeconds = RHO_GEO_LOCATION_INACTIVITY_TIMEOUT;
|
25
|
-
static void _TimerCallBack(CFRunLoopTimerRef timer, void* context);
|
23
|
+
//#define RHO_GEO_LOCATION_INACTIVITY_TIMEOUT 25
|
24
|
+
//static CFTimeInterval timeOutInSeconds = RHO_GEO_LOCATION_INACTIVITY_TIMEOUT;
|
25
|
+
//static void _TimerCallBack(CFRunLoopTimerRef timer, void* context);
|
26
26
|
|
27
27
|
// This is a singleton class, see below
|
28
28
|
static LocationController *sharedLC = nil;
|
@@ -46,45 +46,56 @@ static LocationController *sharedLC = nil;
|
|
46
46
|
//@synthesize onUpdateLocation;
|
47
47
|
|
48
48
|
- (bool)update{
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
([CLLocationManager authorizationStatus] !=
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
(CFRunLoopTimerCallBack)_TimerCallBack,
|
65
|
-
NULL);
|
66
|
-
// Fail if unable to create the timer.
|
67
|
-
if (_timer == NULL)
|
68
|
-
return false;
|
69
|
-
CFRunLoopAddTimer(CFRunLoopGetCurrent(), _timer, kCFRunLoopCommonModes);
|
70
|
-
} else {
|
71
|
-
CFRunLoopTimerSetNextFireDate(_timer, CFAbsoluteTimeGetCurrent() + timeOutInSeconds);
|
72
|
-
}
|
73
|
-
|
74
|
-
_locationManager.delegate = self; // Tells the location manager to send updates to this object
|
75
|
-
[_locationManager startUpdatingLocation];
|
76
|
-
return true;
|
49
|
+
@synchronized(self) {
|
50
|
+
if (!_locationManager)
|
51
|
+
return false;
|
52
|
+
if (!_locationManager.locationServicesEnabled)
|
53
|
+
return false;
|
54
|
+
if (![CLLocationManager locationServicesEnabled])
|
55
|
+
return false;
|
56
|
+
if (([CLLocationManager authorizationStatus] != kCLAuthorizationStatusAuthorized) &&
|
57
|
+
([CLLocationManager authorizationStatus] != kCLAuthorizationStatusNotDetermined) )
|
58
|
+
return false;
|
59
|
+
isEnabled = YES;
|
60
|
+
_locationManager.delegate = self; // Tells the location manager to send updates to this object
|
61
|
+
[_locationManager startUpdatingLocation];
|
62
|
+
}
|
63
|
+
return true;
|
77
64
|
}
|
78
65
|
|
66
|
+
- (void)onTimerFired:(NSTimer*)theTimer {
|
67
|
+
if (isEnabled) {
|
68
|
+
isFirstUpdateFromPlatform = NO;
|
69
|
+
rho_geo_callcallback();
|
70
|
+
}
|
71
|
+
}
|
72
|
+
|
73
|
+
- (void)resetTimerCommand:(NSNumber*)value {
|
74
|
+
@synchronized(self){
|
75
|
+
if (timer != nil) {
|
76
|
+
[timer invalidate];
|
77
|
+
timer = nil;
|
78
|
+
}
|
79
|
+
gps_callback_interval = [value integerValue];
|
80
|
+
isFirstUpdateFromPlatform = YES;
|
81
|
+
if (gps_callback_interval > 0) {
|
82
|
+
timer = [NSTimer scheduledTimerWithTimeInterval:gps_callback_interval target:self selector:@selector(onTimerFired:) userInfo:nil repeats:YES];
|
83
|
+
}
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
- (void)resetTimerWithNewInterval:(int)interval {
|
88
|
+
[self performSelectorOnMainThread:@selector(resetTimerCommand:) withObject:[NSNumber numberWithInt:interval] waitUntilDone:NO];
|
89
|
+
}
|
90
|
+
|
91
|
+
|
92
|
+
|
79
93
|
- (void)doUpdateLocation {
|
80
94
|
[self update];
|
81
95
|
}
|
82
96
|
|
83
97
|
- (void) initLocationManager:(NSObject*)param {
|
84
|
-
|
85
|
-
if (timeout == 0)
|
86
|
-
timeout = RHO_GEO_LOCATION_INACTIVITY_TIMEOUT;
|
87
|
-
timeOutInSeconds = timeout;
|
98
|
+
|
88
99
|
self._locationManager = [[[CLLocationManager alloc] init] autorelease];
|
89
100
|
self._locationManager.desiredAccuracy = kCLLocationAccuracyBest;
|
90
101
|
self._locationManager.delegate = self; // Tells the location manager to send updates to this object
|
@@ -93,36 +104,40 @@ static LocationController *sharedLC = nil;
|
|
93
104
|
- (id) init {
|
94
105
|
self = [super init];
|
95
106
|
if (self != nil) {
|
96
|
-
//[Rhodes performOnUiThread:[LocationManagerInit class] wait:YES];
|
97
107
|
[self performSelectorOnMainThread:@selector(initLocationManager:) withObject:nil waitUntilDone:YES];
|
98
108
|
|
99
|
-
|
100
|
-
//self.onUpdateLocation = @selector(doUpdateLocation);
|
109
|
+
timer = nil;
|
101
110
|
_dLatitude = 0;
|
102
111
|
_dLongitude = 0;
|
103
112
|
_dAccuracy = 0;
|
104
113
|
_bKnownPosition = false;
|
105
114
|
isErrorState = false;
|
115
|
+
gps_callback_interval = 0;
|
116
|
+
isFirstUpdateFromPlatform = YES;
|
117
|
+
isEnabled = YES;
|
106
118
|
RAWLOG_INFO("init");
|
107
|
-
|
108
119
|
}
|
109
|
-
|
110
120
|
return self;
|
111
121
|
}
|
112
122
|
|
113
|
-
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
123
|
+
-(void) stopCommand:(NSNumber*)number {
|
124
|
+
@synchronized(self) {
|
125
|
+
isEnabled = NO;
|
126
|
+
if (!_locationManager)
|
127
|
+
return;
|
128
|
+
[_locationManager stopUpdatingLocation];
|
129
|
+
_locationManager.delegate = nil;
|
130
|
+
|
131
|
+
if (timer != nil) {
|
132
|
+
[timer invalidate];
|
133
|
+
timer = nil;
|
134
|
+
}
|
124
135
|
}
|
125
|
-
|
136
|
+
}
|
137
|
+
|
138
|
+
- (void) stop {
|
139
|
+
isEnabled = NO;
|
140
|
+
[self performSelectorOnMainThread:@selector(stopCommand:) withObject:nil waitUntilDone:NO];
|
126
141
|
}
|
127
142
|
|
128
143
|
// Called when the location is updated
|
@@ -134,20 +149,17 @@ static LocationController *sharedLC = nil;
|
|
134
149
|
if (!newLocation)
|
135
150
|
return;
|
136
151
|
|
137
|
-
bool bNotify = false;
|
138
|
-
|
139
152
|
@synchronized(self){
|
140
153
|
|
141
|
-
bNotify = _bKnownPosition==0 || _dLatitude != newLocation.coordinate.latitude || _dLongitude != newLocation.coordinate.longitude;
|
142
|
-
|
143
154
|
_dLatitude = newLocation.coordinate.latitude;
|
144
155
|
_dLongitude = newLocation.coordinate.longitude;
|
145
156
|
_dAccuracy = newLocation.horizontalAccuracy;//sqrt(newLocation.horizontalAccuracy*newLocation.horizontalAccuracy + newLocation.verticalAccuracy*newLocation.verticalAccuracy);
|
146
157
|
_bKnownPosition = true;
|
147
158
|
}
|
148
|
-
|
149
|
-
|
159
|
+
if (isFirstUpdateFromPlatform && isEnabled) {
|
160
|
+
isFirstUpdateFromPlatform = NO;
|
150
161
|
rho_geo_callcallback();
|
162
|
+
}
|
151
163
|
}
|
152
164
|
|
153
165
|
- (double) getLatitude{
|
@@ -187,17 +199,7 @@ static LocationController *sharedLC = nil;
|
|
187
199
|
- (bool) isAvailable{
|
188
200
|
bool res = false;
|
189
201
|
|
190
|
-
//bool service_enabled = false;
|
191
|
-
//bool service_enabled_f = false;
|
192
|
-
//int auth_status = -1;
|
193
|
-
|
194
202
|
@synchronized(self){
|
195
|
-
|
196
|
-
//if (_locationManager) {
|
197
|
-
// service_enabled = _locationManager.locationServicesEnabled;
|
198
|
-
// service_enabled_f = [CLLocationManager locationServicesEnabled];
|
199
|
-
// auth_status = [CLLocationManager authorizationStatus];
|
200
|
-
//}
|
201
203
|
res = _locationManager &&
|
202
204
|
_locationManager.locationServicesEnabled &&
|
203
205
|
[CLLocationManager locationServicesEnabled] &&
|
@@ -209,7 +211,7 @@ static LocationController *sharedLC = nil;
|
|
209
211
|
- (void)locationManager:(CLLocationManager *)manager
|
210
212
|
didFailWithError:(NSError *)error
|
211
213
|
{
|
212
|
-
/*
|
214
|
+
/* Do not remove it - this code used in debugging
|
213
215
|
if (error != nil) {
|
214
216
|
const char* description = [[error localizedDescription] UTF8String];
|
215
217
|
const char* reason = [[error localizedFailureReason] UTF8String];
|
@@ -217,7 +219,7 @@ static LocationController *sharedLC = nil;
|
|
217
219
|
int o = 0;
|
218
220
|
o = 9;
|
219
221
|
}
|
220
|
-
*/
|
222
|
+
*/
|
221
223
|
isErrorState = true;
|
222
224
|
_bKnownPosition = false;
|
223
225
|
RAWLOG_ERROR("Error in GeoLocation");
|
@@ -274,11 +276,7 @@ static LocationController *sharedLC = nil;
|
|
274
276
|
|
275
277
|
@end
|
276
278
|
|
277
|
-
|
278
|
-
_TimerCallBack(CFRunLoopTimerRef timer, void* context) {
|
279
|
-
RAWLOG_INFO("Stopping location controller on timeout");
|
280
|
-
[[LocationController sharedInstance] stop];
|
281
|
-
}
|
279
|
+
|
282
280
|
|
283
281
|
void geo_update() {
|
284
282
|
if (!rho_rhodesapp_check_mode())
|
@@ -319,7 +317,7 @@ int rho_geo_known_position() {
|
|
319
317
|
|
320
318
|
void rho_geoimpl_settimeout(int nTimeoutSec)
|
321
319
|
{
|
322
|
-
|
320
|
+
[[LocationController sharedInstance] resetTimerWithNewInterval:nTimeoutSec];
|
323
321
|
}
|
324
322
|
|
325
323
|
void rho_geoimpl_turngpsoff()
|
@@ -0,0 +1,33 @@
|
|
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
|
+
#ifdef __cplusplus
|
28
|
+
extern "C" {
|
29
|
+
#endif //__cplusplus
|
30
|
+
void InitMemoryInfoCollector();
|
31
|
+
#ifdef __cplusplus
|
32
|
+
}
|
33
|
+
#endif
|
@@ -0,0 +1,52 @@
|
|
1
|
+
|
2
|
+
#import "InitMemoryInfoCollector.h"
|
3
|
+
|
4
|
+
#include "../shared/common/RhoStd.h"
|
5
|
+
#include "../shared/common/AutoPointer.h"
|
6
|
+
#include "../shared/logging/RhoLogConf.h"
|
7
|
+
#include <sstream>
|
8
|
+
|
9
|
+
#import <mach/mach.h>
|
10
|
+
|
11
|
+
namespace rho
|
12
|
+
{
|
13
|
+
namespace common
|
14
|
+
{
|
15
|
+
|
16
|
+
class IPhoneMemoryInfoCollector : public IMemoryInfoCollector
|
17
|
+
{
|
18
|
+
public:
|
19
|
+
virtual String collect()
|
20
|
+
{
|
21
|
+
struct task_basic_info info;
|
22
|
+
mach_msg_type_number_t size = sizeof(info);
|
23
|
+
kern_return_t kerr = task_info(mach_task_self(),TASK_BASIC_INFO,(task_info_t)&info,&size);
|
24
|
+
if ( KERN_SUCCESS == kerr )
|
25
|
+
{
|
26
|
+
std::stringstream s;
|
27
|
+
s << info.resident_size;
|
28
|
+
return "Memory info: \nResident size: " + s.str() + "\n";
|
29
|
+
}
|
30
|
+
else
|
31
|
+
{
|
32
|
+
return "Can't get memory info\n";
|
33
|
+
}
|
34
|
+
|
35
|
+
}
|
36
|
+
};
|
37
|
+
|
38
|
+
}
|
39
|
+
|
40
|
+
}
|
41
|
+
|
42
|
+
static rho::common::CAutoPtr<rho::common::IPhoneMemoryInfoCollector> s_memory_info_collector(new rho::common::IPhoneMemoryInfoCollector());
|
43
|
+
|
44
|
+
extern "C"
|
45
|
+
{
|
46
|
+
|
47
|
+
void InitMemoryInfoCollector()
|
48
|
+
{
|
49
|
+
LOGCONF().setMemoryInfoCollector(s_memory_info_collector);
|
50
|
+
}
|
51
|
+
|
52
|
+
}
|