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
@@ -0,0 +1,53 @@
|
|
1
|
+
package com.rhomobile.rhodes.extmanager;
|
2
|
+
|
3
|
+
import android.content.Context;
|
4
|
+
import android.graphics.Rect;
|
5
|
+
import android.view.inputmethod.InputMethodManager;
|
6
|
+
|
7
|
+
import com.rhomobile.rhodes.Logger;
|
8
|
+
import com.rhomobile.rhodes.util.ContextFactory;
|
9
|
+
|
10
|
+
public class WebkitExtension extends AbstractRhoExtension implements IRhoExtension {
|
11
|
+
public static final String EXTNAME = "MotorolaWebkit";
|
12
|
+
private static final String TAG = WebkitExtension.class.getSimpleName();
|
13
|
+
|
14
|
+
private static WebkitExtension mInstance;
|
15
|
+
|
16
|
+
private Config mConfig;
|
17
|
+
|
18
|
+
public static WebkitExtension getInstance() {
|
19
|
+
return mInstance;
|
20
|
+
}
|
21
|
+
|
22
|
+
private WebkitExtension(Config config) {
|
23
|
+
mConfig = config;
|
24
|
+
}
|
25
|
+
|
26
|
+
public Config getConfig() {
|
27
|
+
return mConfig;
|
28
|
+
}
|
29
|
+
|
30
|
+
@Override
|
31
|
+
public void onInputMethod(IRhoExtManager extManager, boolean enabled, String type, Rect rect, IRhoExtData ext) {
|
32
|
+
InputMethodManager imm = (InputMethodManager) ContextFactory.getUiContext().getSystemService(Context.INPUT_METHOD_SERVICE);
|
33
|
+
if (enabled) {
|
34
|
+
imm.showSoftInput(ext.getWebView(), 0);
|
35
|
+
} else {
|
36
|
+
imm.hideSoftInputFromWindow(ext.getWebView().getApplicationWindowToken(), 0);
|
37
|
+
}
|
38
|
+
}
|
39
|
+
|
40
|
+
@Override
|
41
|
+
public void startLocationUpdates(IRhoExtManager extManager, boolean highAccuracy, IRhoExtData ext) {
|
42
|
+
}
|
43
|
+
|
44
|
+
@Override
|
45
|
+
public void stopLocationUpdates(IRhoExtManager extManager, IRhoExtData ext) {
|
46
|
+
}
|
47
|
+
|
48
|
+
public static void registerWebkitExtension(Config config) {
|
49
|
+
mInstance = new WebkitExtension(config);
|
50
|
+
RhoExtManager.getInstance().registerExtension(EXTNAME, mInstance);
|
51
|
+
}
|
52
|
+
|
53
|
+
}
|
@@ -60,7 +60,8 @@ public class RhoFileApi {
|
|
60
60
|
private static final String DB_FILES_FOLDER = "db/db-files";
|
61
61
|
private static final String TMP_FOLDER = "tmp";
|
62
62
|
|
63
|
-
private static native void nativeInitPath(String rootPath, String sqliteJournalsPath, String apkPath);
|
63
|
+
private static native void nativeInitPath(String rootPath, String sqliteJournalsPath, String apkPath, String sharedPath);
|
64
|
+
private static native void nativeInitLogPath(String path);
|
64
65
|
private static native void nativeInit();
|
65
66
|
private static native void updateStatTable(String path, String type, long size, long mtime);
|
66
67
|
|
@@ -69,6 +70,9 @@ public class RhoFileApi {
|
|
69
70
|
|
70
71
|
private static native boolean needEmulate(String path);
|
71
72
|
private static native String makeRelativePath(String path);
|
73
|
+
|
74
|
+
public static native void setFsModeTransparrent(boolean transparrent);
|
75
|
+
public static native void removeBundleUpgrade();
|
72
76
|
|
73
77
|
private static void fillStatTable() throws IOException {
|
74
78
|
InputStream is = null;
|
@@ -127,12 +131,10 @@ public class RhoFileApi {
|
|
127
131
|
}
|
128
132
|
}
|
129
133
|
|
130
|
-
public static String initRootPath(String dataDir, String sourceDir) {
|
134
|
+
public static String initRootPath(String dataDir, String sourceDir, String sharedDir) {
|
131
135
|
|
132
136
|
root = dataDir + "/rhodata/";
|
133
137
|
String sqliteJournals = dataDir + "/sqlite_stmt_journals/";
|
134
|
-
Log.d(TAG, "App root path: " + root);
|
135
|
-
Log.d(TAG, "Sqlite journals path: " + sqliteJournals);
|
136
138
|
|
137
139
|
File f = new File(getRootPath());
|
138
140
|
f.mkdirs();
|
@@ -145,9 +147,21 @@ public class RhoFileApi {
|
|
145
147
|
|
146
148
|
String apkPath = sourceDir;
|
147
149
|
|
148
|
-
|
149
|
-
|
150
|
-
|
150
|
+
if (sharedDir == null || sharedDir.length() == 0) {
|
151
|
+
sharedDir = root;
|
152
|
+
}
|
153
|
+
|
154
|
+
Log.d(TAG, "App root path: " + root);
|
155
|
+
Log.d(TAG, "Sqlite journals path: " + sqliteJournals);
|
156
|
+
Log.d(TAG, "Shared path: " + sharedDir);
|
157
|
+
|
158
|
+
nativeInitPath(root, sqliteJournals, apkPath, sharedDir);
|
159
|
+
return root;
|
160
|
+
}
|
161
|
+
|
162
|
+
public static void initLogPath(String path) {
|
163
|
+
nativeInitLogPath(path);
|
164
|
+
}
|
151
165
|
|
152
166
|
public static String getRootPath() { return root; }
|
153
167
|
public static String getDbFilesUriPath() { return DB_FILES_FOLDER; }
|
@@ -163,10 +177,13 @@ public class RhoFileApi {
|
|
163
177
|
fillStatTable();
|
164
178
|
}
|
165
179
|
|
166
|
-
public static void
|
180
|
+
public static void initialCopy(Context ctx, String assets[])
|
167
181
|
{
|
168
182
|
am = ctx.getAssets();
|
169
|
-
|
183
|
+
for(String asset: assets)
|
184
|
+
{
|
185
|
+
forceFile(getRootPath() + asset);
|
186
|
+
}
|
170
187
|
}
|
171
188
|
|
172
189
|
public static boolean copy(String path)
|
@@ -175,8 +192,6 @@ public class RhoFileApi {
|
|
175
192
|
InputStream is = null;
|
176
193
|
OutputStream os = null;
|
177
194
|
try {
|
178
|
-
//RhodesService r = RhodesService.getInstance();
|
179
|
-
|
180
195
|
is = am.open(path);
|
181
196
|
|
182
197
|
File dst = new File(root, path);
|
@@ -272,7 +287,7 @@ public class RhoFileApi {
|
|
272
287
|
return is;
|
273
288
|
}
|
274
289
|
catch (IOException e) {
|
275
|
-
|
290
|
+
Log.e(TAG, e.getMessage());
|
276
291
|
return null;
|
277
292
|
}
|
278
293
|
}
|
@@ -25,6 +25,8 @@
|
|
25
25
|
*------------------------------------------------------------------------*/
|
26
26
|
package com.rhomobile.rhodes.geolocation;
|
27
27
|
|
28
|
+
import android.location.Location;
|
29
|
+
|
28
30
|
import com.rhomobile.rhodes.Capabilities;
|
29
31
|
import com.rhomobile.rhodes.Logger;
|
30
32
|
import com.rhomobile.rhodes.RhoConf;
|
@@ -33,75 +35,89 @@ import com.rhomobile.rhodes.util.PerformOnUiThread;
|
|
33
35
|
public class GeoLocation {
|
34
36
|
|
35
37
|
private static final String TAG = "GeoLocation";
|
36
|
-
private static final String inactivityTimeoutName = "geo_location_inactivity_timeout";
|
37
|
-
private static final String updatePeriodName = "gps_ping_timeout_sec";
|
38
38
|
private static volatile GeoLocationImpl locImpl = null;
|
39
|
-
private static volatile int inactivityTimerId = 0;
|
40
|
-
private static long updatePeriod = -1;
|
41
39
|
|
42
|
-
static
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
40
|
+
private static final String CALLBACK_UPDATE_INTERVAL = "gps_ping_timeout_sec";
|
41
|
+
|
42
|
+
private static double ourLatitude = 0;
|
43
|
+
private static double ourLongitude = 0;
|
44
|
+
private static double ourAccuracy = 0;
|
45
|
+
private static boolean ourIsKnownPosition = false;
|
46
|
+
private static boolean ourIsEnable = true;
|
47
|
+
private static boolean ourIsErrorState = false;
|
48
|
+
|
49
|
+
public static native void geoCallback();
|
50
|
+
public static native void geoCallbackError();
|
51
|
+
|
52
|
+
|
53
|
+
public static void onUpdateLocation() {
|
54
|
+
Location loc = getImpl().getLocation();
|
55
|
+
synchronized (GeoLocation.class) {
|
56
|
+
if (loc != null) {
|
57
|
+
ourLatitude = loc.getLatitude();
|
58
|
+
ourLongitude = loc.getLongitude();
|
59
|
+
ourAccuracy = loc.getAccuracy();
|
60
|
+
ourIsKnownPosition = true;
|
61
|
+
}
|
62
|
+
else {
|
63
|
+
ourLatitude = 0;
|
64
|
+
ourLongitude = 0;
|
65
|
+
ourAccuracy = 0;
|
66
|
+
ourIsKnownPosition = false;
|
67
|
+
}
|
51
68
|
}
|
52
|
-
|
53
|
-
return ret;
|
54
69
|
}
|
55
70
|
|
56
|
-
static
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
71
|
+
public static void onGeoCallback() {
|
72
|
+
Logger.T(TAG, "onGeoCallback()");
|
73
|
+
if (ourIsEnable && !ourIsErrorState) {
|
74
|
+
Logger.T(TAG, "onGeoCallback() run native Callback");
|
75
|
+
geoCallback();
|
76
|
+
}
|
77
|
+
else {
|
78
|
+
Logger.T(TAG, "onGeoCallback() SKIP");
|
79
|
+
}
|
80
|
+
}
|
81
|
+
|
82
|
+
public static void onGeoCallbackError() {
|
83
|
+
if (ourIsEnable && !ourIsErrorState) {
|
84
|
+
Logger.T(TAG, "onGeoCallbackError() run native Callback");
|
85
|
+
ourIsErrorState = true;
|
86
|
+
geoCallbackError();
|
87
|
+
ourIsErrorState = false;
|
88
|
+
}
|
89
|
+
else {
|
90
|
+
Logger.T(TAG, "onGeoCallbackError() SKIP");
|
91
|
+
}
|
65
92
|
}
|
66
93
|
|
94
|
+
private static Thread ourCallbackThread = null;
|
95
|
+
|
67
96
|
private static void checkState() throws IllegalAccessException {
|
68
97
|
if (!Capabilities.GPS_ENABLED)
|
69
98
|
throw new IllegalAccessException("Capability GPS disabled");
|
70
99
|
}
|
71
100
|
|
72
|
-
private static void updateInactivityTimer() {
|
73
|
-
final long inactivityTimeout = getInactivityTimeout();
|
74
|
-
Logger.T(TAG, "Updating inactivity timer: " + inactivityTimeout + "ms");
|
75
|
-
PerformOnUiThread.exec(new Runnable() {
|
76
|
-
int lastId = ++inactivityTimerId;
|
77
|
-
public void run() {
|
78
|
-
if ((inactivityTimerId != lastId) || (locImpl == null))
|
79
|
-
return;
|
80
|
-
|
81
|
-
Logger.T(TAG, "Stop geolocation by inactivity timeout: " + inactivityTimeout + "ms");
|
82
|
-
stop();
|
83
|
-
}
|
84
|
-
}, inactivityTimeout);
|
85
|
-
}
|
86
|
-
|
87
101
|
private static GeoLocationImpl getImpl() {
|
88
102
|
if (locImpl == null) {
|
89
103
|
synchronized (GeoLocation.class) {
|
90
104
|
if (locImpl == null) {
|
91
105
|
Logger.T(TAG, "Creating GeoLocationImpl instance.");
|
92
|
-
locImpl = new GeoLocationImpl(
|
106
|
+
locImpl = new GeoLocationImpl();
|
93
107
|
Logger.T(TAG, "GeoLocationImpl instance has created.");
|
108
|
+
//ourIsFirstUpdate = true;
|
94
109
|
locImpl.start();
|
95
110
|
Logger.T(TAG, "GeoLocation has started.");
|
96
111
|
}
|
97
112
|
}
|
98
113
|
}
|
99
|
-
updateInactivityTimer();
|
100
114
|
return locImpl;
|
101
115
|
}
|
102
116
|
|
103
117
|
public static void stop() {
|
104
118
|
Logger.T(TAG, "stop");
|
119
|
+
ourIsEnable = false;
|
120
|
+
resetCallbackThread(0);
|
105
121
|
try {
|
106
122
|
if (locImpl == null)
|
107
123
|
return;
|
@@ -117,18 +133,6 @@ public class GeoLocation {
|
|
117
133
|
}
|
118
134
|
}
|
119
135
|
|
120
|
-
public static void restart() {
|
121
|
-
try {
|
122
|
-
checkState();
|
123
|
-
Logger.T(TAG, "restart");
|
124
|
-
if (updatePeriod != -1)
|
125
|
-
getImpl().setTimeout(getUpdatePeriod());
|
126
|
-
}
|
127
|
-
catch (Exception e) {
|
128
|
-
Logger.E(TAG, e);
|
129
|
-
}
|
130
|
-
}
|
131
|
-
|
132
136
|
public static boolean isAvailable() {
|
133
137
|
Logger.T(TAG, "isAvailable...");
|
134
138
|
try {
|
@@ -147,10 +151,11 @@ public class GeoLocation {
|
|
147
151
|
}
|
148
152
|
|
149
153
|
public static double getLatitude() {
|
154
|
+
onUpdateLocation();
|
150
155
|
try {
|
151
156
|
checkState();
|
152
157
|
Logger.T(TAG, "getLatitude");
|
153
|
-
return
|
158
|
+
return ourLatitude;
|
154
159
|
}
|
155
160
|
catch (Exception e) {
|
156
161
|
Logger.E(TAG, e);
|
@@ -159,10 +164,11 @@ public class GeoLocation {
|
|
159
164
|
}
|
160
165
|
|
161
166
|
public static double getLongitude() {
|
167
|
+
onUpdateLocation();
|
162
168
|
try {
|
163
169
|
checkState();
|
164
170
|
Logger.T(TAG, "getLongitude");
|
165
|
-
return
|
171
|
+
return ourLongitude;
|
166
172
|
}
|
167
173
|
catch (Exception e) {
|
168
174
|
Logger.E(TAG, e);
|
@@ -171,10 +177,11 @@ public class GeoLocation {
|
|
171
177
|
}
|
172
178
|
|
173
179
|
public static float getAccuracy() {
|
180
|
+
onUpdateLocation();
|
174
181
|
try {
|
175
182
|
checkState();
|
176
183
|
Logger.T(TAG, "getAccuracy");
|
177
|
-
return
|
184
|
+
return (float)ourAccuracy;
|
178
185
|
}
|
179
186
|
catch (Exception e) {
|
180
187
|
Logger.E(TAG, e);
|
@@ -183,10 +190,11 @@ public class GeoLocation {
|
|
183
190
|
}
|
184
191
|
|
185
192
|
public static boolean isKnownPosition() {
|
193
|
+
onUpdateLocation();
|
186
194
|
try {
|
187
195
|
checkState();
|
188
196
|
Logger.T(TAG, "isKnownPosition");
|
189
|
-
return
|
197
|
+
return ourIsKnownPosition;
|
190
198
|
}
|
191
199
|
catch (Exception e) {
|
192
200
|
Logger.E(TAG, e);
|
@@ -194,17 +202,71 @@ public class GeoLocation {
|
|
194
202
|
return false;
|
195
203
|
}
|
196
204
|
|
205
|
+
private static void resetCallbackThread(int period) {
|
206
|
+
Logger.T(TAG, "resetCallbackThread: " + period + "s");
|
207
|
+
if (ourCallbackThread != null) {
|
208
|
+
ourCallbackThread.interrupt();
|
209
|
+
ourCallbackThread = null;
|
210
|
+
}
|
211
|
+
if (period > 0) {
|
212
|
+
final int sleep_period = period;
|
213
|
+
ourCallbackThread = new Thread(new Runnable() {
|
214
|
+
private boolean ourLastCommandProcessed = true;
|
215
|
+
public void run() {
|
216
|
+
Logger.I(TAG, "\"callback\" thread started");
|
217
|
+
for (;;) {
|
218
|
+
if (!ourIsEnable) {
|
219
|
+
break;
|
220
|
+
}
|
221
|
+
try {
|
222
|
+
if (ourLastCommandProcessed) {
|
223
|
+
ourLastCommandProcessed = false;
|
224
|
+
Logger.T(TAG, "callback thread: perform callback in UI thread");
|
225
|
+
PerformOnUiThread.exec(new Runnable() {
|
226
|
+
public void run() {
|
227
|
+
Logger.T(TAG, "callback thread: callback in UI thread START");
|
228
|
+
onGeoCallback();
|
229
|
+
Logger.T(TAG, "callback thread: callback in UI thread FINISH");
|
230
|
+
ourLastCommandProcessed = true;
|
231
|
+
}
|
232
|
+
});
|
233
|
+
}
|
234
|
+
else {
|
235
|
+
Logger.T(TAG, "callback thread: previous command not processed - skip current callback");
|
236
|
+
}
|
237
|
+
Thread.sleep(sleep_period);
|
238
|
+
}
|
239
|
+
catch (InterruptedException e) {
|
240
|
+
Logger.T(TAG, "\"callback\" thread interrupted");
|
241
|
+
break;
|
242
|
+
}
|
243
|
+
}
|
244
|
+
}
|
245
|
+
});
|
246
|
+
ourCallbackThread.start();
|
247
|
+
}
|
248
|
+
else {
|
249
|
+
Logger.T(TAG, "resetCallbackThread: zero period - not make any thread");
|
250
|
+
}
|
251
|
+
|
252
|
+
}
|
253
|
+
|
197
254
|
public static void setTimeout(int nsec) {
|
198
255
|
try {
|
199
|
-
|
200
|
-
|
201
|
-
|
256
|
+
int p = nsec*1000;
|
257
|
+
if (p < 0) {
|
258
|
+
p = RhoConf.getInt(CALLBACK_UPDATE_INTERVAL) * 1000;
|
202
259
|
}
|
203
260
|
|
204
261
|
checkState();
|
205
262
|
Logger.T(TAG, "setTimeout: " + nsec + "s");
|
206
|
-
|
207
|
-
|
263
|
+
|
264
|
+
ourIsEnable = true;
|
265
|
+
if (p <= 0) {
|
266
|
+
p = 250;
|
267
|
+
}
|
268
|
+
resetCallbackThread(p);
|
269
|
+
|
208
270
|
}
|
209
271
|
catch (Exception e) {
|
210
272
|
Logger.E(TAG, e);
|
@@ -44,14 +44,11 @@ import android.os.Looper;
|
|
44
44
|
public class GeoLocationImpl {
|
45
45
|
|
46
46
|
private static final String TAG = "GeoLocationImpl";
|
47
|
-
private static final long TIMEOUT_STOP = -1;
|
48
47
|
|
49
|
-
private
|
50
|
-
private volatile Location lastLocation;
|
48
|
+
private static final int UPDATE_PERIOD_IN_MILLISECONDS = 250;
|
51
49
|
|
52
|
-
|
53
|
-
private
|
54
|
-
private volatile long pingTimeout = Long.MAX_VALUE;
|
50
|
+
private LocationManager locationManager = null;
|
51
|
+
private volatile Location lastLocation = null;
|
55
52
|
|
56
53
|
private List<RhoLocationListener> mListeners = new LinkedList<RhoLocationListener>();
|
57
54
|
private List<RhoLocationListener> mSwitchedOffListeners = new LinkedList<RhoLocationListener>();
|
@@ -60,7 +57,6 @@ public class GeoLocationImpl {
|
|
60
57
|
private String providerName;
|
61
58
|
private LocationManager manager;
|
62
59
|
private LocationProvider provider;
|
63
|
-
private long updatePeriod = 0;
|
64
60
|
private boolean available = false;
|
65
61
|
|
66
62
|
boolean isAvailable() { return available; }
|
@@ -72,7 +68,7 @@ public class GeoLocationImpl {
|
|
72
68
|
|
73
69
|
String getProviderName() { return this.providerName; }
|
74
70
|
|
75
|
-
synchronized boolean register(
|
71
|
+
synchronized boolean register() {
|
76
72
|
Logger.T(TAG, "Registering location listener for '" + this.providerName + "'.");
|
77
73
|
if (this.provider != null) {
|
78
74
|
this.manager.removeUpdates(this);
|
@@ -80,8 +76,7 @@ public class GeoLocationImpl {
|
|
80
76
|
this.provider = this.manager.getProvider(this.providerName);
|
81
77
|
}
|
82
78
|
if(this.provider != null) {
|
83
|
-
this.
|
84
|
-
this.manager.requestLocationUpdates(providerName, this.updatePeriod, 0, this, Looper.getMainLooper());
|
79
|
+
this.manager.requestLocationUpdates(providerName, UPDATE_PERIOD_IN_MILLISECONDS, 0, this, Looper.getMainLooper());
|
85
80
|
available = this.manager.isProviderEnabled(this.providerName);
|
86
81
|
}
|
87
82
|
return available;
|
@@ -102,28 +97,14 @@ public class GeoLocationImpl {
|
|
102
97
|
void requestLastLocation() {
|
103
98
|
if (this.provider != null && this.manager != null) {
|
104
99
|
Location location = this.manager.getLastKnownLocation(this.providerName);
|
105
|
-
|
106
|
-
long time = location.getTime();
|
107
|
-
StringBuilder message = new StringBuilder();
|
108
|
-
message.append("Last known location from ").append(location.getProvider());
|
109
|
-
if((System.currentTimeMillis() - time) > invalidateLocationPeriod) {
|
110
|
-
message.append(" time is very old: ").append(location.getTime());
|
111
|
-
message.append(". Current time: ").append(System.currentTimeMillis());
|
112
|
-
message.append(". Invalitate period: ").append(invalidateLocationPeriod).append(".");
|
113
|
-
} else {
|
114
|
-
message.append(" time os ok: ").append(location.getTime());
|
115
|
-
message.append(". Current time: ").append(System.currentTimeMillis());
|
116
|
-
message.append(". Invalidate period: ").append(invalidateLocationPeriod).append(".");
|
117
|
-
onLocationChanged(location);
|
118
|
-
}
|
119
|
-
Logger.T(TAG, message.toString());
|
120
|
-
}
|
100
|
+
onLocationChanged(location);
|
121
101
|
}
|
122
102
|
}
|
123
103
|
|
124
104
|
@Override
|
125
105
|
public void onStatusChanged(String provider, int status, Bundle extras) {
|
126
106
|
Logger.T(TAG, "onStatusChanged: provider=" + provider + ", status=" + status);
|
107
|
+
requestLastLocation();
|
127
108
|
}
|
128
109
|
|
129
110
|
@Override
|
@@ -147,62 +128,21 @@ public class GeoLocationImpl {
|
|
147
128
|
}
|
148
129
|
};
|
149
130
|
|
150
|
-
|
151
|
-
public void run() {
|
152
|
-
Logger.I(TAG, "\"watchdog\" thread started");
|
153
|
-
for (;;) {
|
154
|
-
if (pingTimeout < 0)
|
155
|
-
break;
|
156
|
-
try {
|
157
|
-
final long curTimeout = errorTimeout(pingTimeout);
|
158
|
-
Logger.T(TAG, "\"watchdog\" thread waits (" + curTimeout + "ms)...");
|
159
|
-
Thread.sleep(curTimeout);
|
160
|
-
}
|
161
|
-
catch (InterruptedException e) {
|
162
|
-
Logger.T(TAG, "\"watchdog\" thread interrupted");
|
163
|
-
continue;
|
164
|
-
}
|
165
|
-
Logger.I(TAG, "Watchdog timed out.");
|
166
|
-
if (isKnownPosition()) {
|
167
|
-
if (System.currentTimeMillis() - getTime() > invalidateLocationPeriod) {
|
168
|
-
Logger.T(TAG, "Position became very old. Invalidate and call back to inform.");
|
169
|
-
clearLocation();
|
170
|
-
} else {
|
171
|
-
Logger.I(TAG, "Lost signal but position still up to date. Call back with error to inform.");
|
172
|
-
}
|
173
|
-
} else {
|
174
|
-
Logger.T(TAG, "Position is still unknown. Call back to inform.");
|
175
|
-
}
|
176
|
-
|
177
|
-
PerformOnUiThread.exec(new Runnable() {
|
178
|
-
public void run() {
|
179
|
-
geoCallbackError();
|
180
|
-
}
|
181
|
-
});
|
182
|
-
}
|
183
|
-
PerformOnUiThread.exec(new Runnable() { public void run() { geoCallbackStop();} });
|
184
|
-
Logger.I(TAG, "\"watchdog\" thread stopped");
|
185
|
-
}
|
186
|
-
});
|
187
|
-
|
188
|
-
// Sleep greater then ping time to do not interfere with real location updates
|
189
|
-
private static long errorTimeout(long time) { return (time == Long.MAX_VALUE) ? time : (time * 5); }
|
190
|
-
|
191
|
-
private static native void geoCallback();
|
192
|
-
private static native void geoCallbackError();
|
193
|
-
private static native void geoCallbackStop();
|
194
|
-
|
195
|
-
GeoLocationImpl(long invalidateLocationPeriod) {
|
196
|
-
this.invalidateLocationPeriod = invalidateLocationPeriod;
|
131
|
+
GeoLocationImpl() {
|
197
132
|
Logger.T(TAG, "GeoLocationImpl instance created");
|
198
133
|
Context ctx = ContextFactory.getContext();
|
199
134
|
locationManager = (LocationManager)ctx.getSystemService(Context.LOCATION_SERVICE);
|
200
135
|
createListeners();
|
201
|
-
thWatchdog.start();
|
202
136
|
}
|
203
137
|
|
204
138
|
private void createListeners() {
|
205
|
-
|
139
|
+
LocationManager man = locationManager;
|
140
|
+
if (man == null) {
|
141
|
+
Logger.E(TAG, "createListeners() : Location Manager is NULL !");
|
142
|
+
return;
|
143
|
+
}
|
144
|
+
|
145
|
+
List<String> providers = man.getAllProviders();
|
206
146
|
Iterator<String> it = providers.iterator();
|
207
147
|
|
208
148
|
synchronized (mListeners) {
|
@@ -211,7 +151,7 @@ public class GeoLocationImpl {
|
|
211
151
|
if (provider.equals(LocationManager.PASSIVE_PROVIDER))
|
212
152
|
continue;
|
213
153
|
|
214
|
-
RhoLocationListener listener = new RhoLocationListener(provider,
|
154
|
+
RhoLocationListener listener = new RhoLocationListener(provider, man);
|
215
155
|
mSwitchedOffListeners.add(listener);
|
216
156
|
}
|
217
157
|
}
|
@@ -226,7 +166,7 @@ public class GeoLocationImpl {
|
|
226
166
|
|
227
167
|
Logger.T(TAG, "Registering location listener: " + listener.getProviderName());
|
228
168
|
|
229
|
-
listener.register(
|
169
|
+
listener.register();
|
230
170
|
mListeners.add(listener);
|
231
171
|
}
|
232
172
|
mSwitchedOffListeners.removeAll(mListeners);
|
@@ -259,6 +199,11 @@ public class GeoLocationImpl {
|
|
259
199
|
}
|
260
200
|
}
|
261
201
|
|
202
|
+
|
203
|
+
public void doUpdate() {
|
204
|
+
|
205
|
+
}
|
206
|
+
|
262
207
|
private void checkProviderEnabled(RhoLocationListener listener) {
|
263
208
|
}
|
264
209
|
|
@@ -273,29 +218,11 @@ public class GeoLocationImpl {
|
|
273
218
|
}
|
274
219
|
}
|
275
220
|
|
276
|
-
private static boolean isLocationsEqual(Location prev, Location current) {
|
277
|
-
if (prev == null && current != null)
|
278
|
-
return false;
|
279
|
-
if (prev != null && current == null)
|
280
|
-
return true;
|
281
|
-
|
282
|
-
do {
|
283
|
-
if (prev.getLatitude() != current.getLatitude() ||
|
284
|
-
prev.getLongitude() == current.getLongitude())
|
285
|
-
break;
|
286
|
-
|
287
|
-
if(current.hasAccuracy()) {
|
288
|
-
if(!prev.hasAccuracy())
|
289
|
-
break;
|
290
|
-
if (prev.getAccuracy() != current.getAccuracy())
|
291
|
-
break;
|
292
|
-
}
|
293
|
-
return true;
|
294
|
-
} while(false);
|
295
|
-
return false;
|
296
|
-
}
|
297
|
-
|
298
221
|
private synchronized void setLocation(Location location) {
|
222
|
+
if (location == null) {
|
223
|
+
Logger.T(TAG, "setCurrentGpsLocation: location = null");
|
224
|
+
return;
|
225
|
+
}
|
299
226
|
Logger.T(TAG, "setCurrentGpsLocation: location=" + location);
|
300
227
|
try {
|
301
228
|
// We've received location update
|
@@ -307,21 +234,25 @@ public class GeoLocationImpl {
|
|
307
234
|
unregisterListeners(LocationManager.GPS_PROVIDER);
|
308
235
|
}
|
309
236
|
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
Logger.T(TAG, "Geo location information changed, notify about that");
|
314
|
-
lastLocation = location;
|
315
|
-
PerformOnUiThread.exec(new Runnable() { public void run() { geoCallback();} }, 10);
|
237
|
+
LocationManager man = locationManager;
|
238
|
+
if (man != null) {
|
239
|
+
dumpStatus(man.getAllProviders());
|
316
240
|
}
|
317
|
-
|
241
|
+
|
242
|
+
lastLocation = location;
|
318
243
|
} catch (Exception e) {
|
319
244
|
lastLocation = null;
|
245
|
+
GeoLocation.onGeoCallbackError();
|
320
246
|
Logger.E(TAG, e);
|
321
247
|
}
|
322
248
|
}
|
323
249
|
|
324
250
|
private void dumpStatus(List<String> providers) {
|
251
|
+
LocationManager man = locationManager;
|
252
|
+
if (man == null) {
|
253
|
+
Logger.E(TAG, "dumpStatus() : Location Manager is NULL !");
|
254
|
+
return;
|
255
|
+
}
|
325
256
|
StringBuffer log = new StringBuffer();
|
326
257
|
log.append("Status of location providers: ");
|
327
258
|
Iterator<String> it = providers.iterator();
|
@@ -335,7 +266,7 @@ public class GeoLocationImpl {
|
|
335
266
|
log.append("\"");
|
336
267
|
log.append(provider);
|
337
268
|
log.append("\" - ");
|
338
|
-
if (
|
269
|
+
if (man.isProviderEnabled(provider))
|
339
270
|
log.append("enabled");
|
340
271
|
else
|
341
272
|
log.append("disabled");
|
@@ -343,18 +274,19 @@ public class GeoLocationImpl {
|
|
343
274
|
Logger.T(TAG, log.toString());
|
344
275
|
log = new StringBuffer();
|
345
276
|
log.append("location is");
|
346
|
-
|
277
|
+
Location ll = lastLocation;
|
278
|
+
if (ll == null) {
|
347
279
|
log.append(" not determined");
|
348
280
|
} else {
|
349
281
|
log.append(" determined");
|
350
|
-
log.append(": longitude=").append(Double.toString(
|
351
|
-
log.append(", latitude=").append(Double.toString(
|
282
|
+
log.append(": longitude=").append(Double.toString(ll.getLongitude()));
|
283
|
+
log.append(", latitude=").append(Double.toString(ll.getLatitude()));
|
352
284
|
if (lastLocation.hasAccuracy())
|
353
|
-
log.append(", accuracy=").append(Float.toString(
|
285
|
+
log.append(", accuracy=").append(Float.toString(ll.getAccuracy()));
|
354
286
|
if (lastLocation.hasSpeed())
|
355
|
-
log.append(", speed=").append(Float.toString(
|
287
|
+
log.append(", speed=").append(Float.toString(ll.getSpeed()));
|
356
288
|
if (lastLocation.hasAltitude())
|
357
|
-
log.append(", altitude=").append(Double.toString(
|
289
|
+
log.append(", altitude=").append(Double.toString(ll.getAltitude()));
|
358
290
|
}
|
359
291
|
Logger.T(TAG, log.toString());
|
360
292
|
}
|
@@ -365,16 +297,7 @@ public class GeoLocationImpl {
|
|
365
297
|
|
366
298
|
|
367
299
|
synchronized void stop() {
|
368
|
-
// Stop thCancel thread
|
369
|
-
pingTimeout = TIMEOUT_STOP;
|
370
|
-
thWatchdog.interrupt();
|
371
|
-
|
372
|
-
if (locationManager == null)
|
373
|
-
return;
|
374
|
-
|
375
300
|
unregisterListeners(null);
|
376
|
-
|
377
|
-
locationManager = null;
|
378
301
|
}
|
379
302
|
|
380
303
|
synchronized boolean isAvailable() {
|
@@ -390,6 +313,10 @@ public class GeoLocationImpl {
|
|
390
313
|
return available > 0;
|
391
314
|
}
|
392
315
|
|
316
|
+
synchronized Location getLocation() {
|
317
|
+
return lastLocation;
|
318
|
+
}
|
319
|
+
|
393
320
|
synchronized double getLatitude() {
|
394
321
|
return lastLocation != null ? lastLocation.getLatitude() : 0;
|
395
322
|
}
|
@@ -418,20 +345,5 @@ public class GeoLocationImpl {
|
|
418
345
|
return lastLocation != null;
|
419
346
|
}
|
420
347
|
|
421
|
-
synchronized void clearLocation() {
|
422
|
-
lastLocation = null;
|
423
|
-
}
|
424
348
|
|
425
|
-
synchronized void setTimeout(long msec) {
|
426
|
-
if (pingTimeout != msec) {
|
427
|
-
pingTimeout = msec;
|
428
|
-
thWatchdog.interrupt();
|
429
|
-
registerListeners();// do reregister for new timeout
|
430
|
-
Logger.T(TAG, "Set new ping timeout: " + pingTimeout + "ms");
|
431
|
-
} else {
|
432
|
-
// Just renew timer in case same value
|
433
|
-
thWatchdog.interrupt();
|
434
|
-
}
|
435
|
-
|
436
|
-
}
|
437
349
|
}
|