Fix location.js to use the way to create native methods.

This commit is contained in:
Yuan Xulei 2015-01-15 18:15:03 +08:00
Родитель c52b03e6e5
Коммит 61a7cf5150
2 изменённых файлов: 45 добавлений и 44 удалений

Просмотреть файл

@ -26,6 +26,7 @@ module J2ME {
export var yieldMap = { export var yieldMap = {
"java/lang/Thread.sleep.(J)V": YieldReason.Root, "java/lang/Thread.sleep.(J)V": YieldReason.Root,
"com/sun/cldc/isolate/Isolate.waitStatus.(I)V": YieldReason.Root, "com/sun/cldc/isolate/Isolate.waitStatus.(I)V": YieldReason.Root,
"com/sun/j2me/location/PlatformLocationProvider.waitForNewLocation.(IJ)Z": YieldReason.Root,
"com/sun/javame/sensor/NativeChannel.doMeasureData.(II)[B": YieldReason.Root, "com/sun/javame/sensor/NativeChannel.doMeasureData.(II)[B": YieldReason.Root,
"com/sun/midp/links/LinkPortal.getLinkCount0.()I": YieldReason.Root, "com/sun/midp/links/LinkPortal.getLinkCount0.()I": YieldReason.Root,
"com/sun/midp/links/Link.receive0.(Lcom/sun/midp/links/LinkMessage;Lcom/sun/midp/links/Link;)V": YieldReason.Root, "com/sun/midp/links/Link.receive0.(Lcom/sun/midp/links/LinkMessage;Lcom/sun/midp/links/Link;)V": YieldReason.Root,
@ -290,4 +291,4 @@ module J2ME {
yieldWriter && yieldWriter.leave("< " + methodInfo.implKey + " " + YieldReason[result]); yieldWriter && yieldWriter.leave("< " + methodInfo.implKey + " " + YieldReason[result]);
return yieldMap[methodInfo.implKey] = result; return yieldMap[methodInfo.implKey] = result;
} }
} }

Просмотреть файл

@ -63,99 +63,99 @@ LocationProvider.prototype.requestData = function() {
}.bind(this)); }.bind(this));
}; };
Native.create("com/sun/j2me/location/PlatformLocationProvider.getListOfLocationProviders.()Ljava/lang/String;", function() { Native["com/sun/j2me/location/PlatformLocationProvider.getListOfLocationProviders.()Ljava/lang/String;"] = function() {
// If there are more than one providers, separate them by comma. // If there are more than one providers, separate them by comma.
return Location.PROVIDER_NAME; return util.newString(Location.PROVIDER_NAME);
}); };
Native.create("com/sun/j2me/location/CriteriaImpl.initNativeClass.()V", function() { Native["com/sun/j2me/location/CriteriaImpl.initNativeClass.()V"] = function() {
console.warn("com/sun/j2me/location/CriteriaImpl.initNativeClass.()V not implemented"); console.warn("com/sun/j2me/location/CriteriaImpl.initNativeClass.()V not implemented");
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.getBestProviderByCriteriaImpl.(Lcom/sun/j2me/location/CriteriaImpl;)Z", function(criteria) { Native["com/sun/j2me/location/PlatformLocationProvider.getBestProviderByCriteriaImpl.(Lcom/sun/j2me/location/CriteriaImpl;)Z"] = function(criteria) {
criteria.class.getField("I.providerName.Ljava/lang/String;") criteria.klass.classInfo.getField("I.providerName.Ljava/lang/String;")
.set(criteria, util.newString(Location.PROVIDER_NAME)); .set(criteria, util.newString(Location.PROVIDER_NAME));
return true; return true;
}); };
Native.create("com/sun/j2me/location/LocationProviderInfo.initNativeClass.()V", function() { Native["com/sun/j2me/location/LocationProviderInfo.initNativeClass.()V"] = function() {
console.warn("com/sun/j2me/location/LocationProviderInfo.initNativeClass.()V not implemented"); console.warn("com/sun/j2me/location/LocationProviderInfo.initNativeClass.()V not implemented");
}); };
Native.create("com/sun/j2me/location/LocationInfo.initNativeClass.()V", function() { Native["com/sun/j2me/location/LocationInfo.initNativeClass.()V"] = function() {
console.warn("com/sun/j2me/location/LocationInfo.initNativeClass.()V not implemented"); console.warn("com/sun/j2me/location/LocationInfo.initNativeClass.()V not implemented");
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.open.(Ljava/lang/String;)I", function(name) { Native["com/sun/j2me/location/PlatformLocationProvider.open.(Ljava/lang/String;)I"] = function(name) {
var provider = new LocationProvider(); var provider = new LocationProvider();
provider.start(); provider.start();
var id = Location.Providers.nextId; var id = Location.Providers.nextId;
Location.Providers.nextId = Location.Providers.nextId % 0xff + 1; Location.Providers.nextId = Location.Providers.nextId % 0xff + 1;
Location.Providers[id] = provider; Location.Providers[id] = provider;
return id; return id;
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.resetImpl.(I)V", function(providerId) { Native["com/sun/j2me/location/PlatformLocationProvider.resetImpl.(I)V"] = function(providerId) {
var provider = Location.Providers[providerId]; var provider = Location.Providers[providerId];
provider.stop(); provider.stop();
Location.Providers[providerId] = null; Location.Providers[providerId] = null;
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.getCriteria.(Ljava/lang/String;Lcom/sun/j2me/location/LocationProviderInfo;)Z", function(name, criteria) { Native["com/sun/j2me/location/PlatformLocationProvider.getCriteria.(Ljava/lang/String;Lcom/sun/j2me/location/LocationProviderInfo;)Z"] = function(name, criteria) {
criteria.class.getField("I.canReportAltitude.Z") criteria.klass.classInfo.getField("I.canReportAltitude.Z")
.set(criteria, true); .set(criteria, true);
criteria.class.getField("I.canReportSpeedCource.Z") criteria.klass.classInfo.getField("I.canReportSpeedCource.Z")
.set(criteria, true); .set(criteria, true);
criteria.class.getField("I.averageResponseTime.I") criteria.klass.classInfo.getField("I.averageResponseTime.I")
.set(criteria, 10000); .set(criteria, 10000);
return true; return true;
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.setUpdateIntervalImpl.(II)V", function(providerId, interval) { Native["com/sun/j2me/location/PlatformLocationProvider.setUpdateIntervalImpl.(II)V"] = function(providerId, interval) {
console.warn("com/sun/j2me/location/PlatformLocationProvider.setUpdateIntervalImpl.(II)V not implemented"); console.warn("com/sun/j2me/location/PlatformLocationProvider.setUpdateIntervalImpl.(II)V not implemented");
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.getLastLocationImpl.(ILcom/sun/j2me/location/LocationInfo;)Z", function(providerId, locationInfo) { Native["com/sun/j2me/location/PlatformLocationProvider.getLastLocationImpl.(ILcom/sun/j2me/location/LocationInfo;)Z"] = function(providerId, locationInfo) {
var provider = Location.Providers[providerId]; var provider = Location.Providers[providerId];
var pos = provider.position; var pos = provider.position;
locationInfo.class.getField("I.isValid.Z") locationInfo.klass.classInfo.getField("I.isValid.Z")
.set(locationInfo, true); .set(locationInfo, true);
locationInfo.class.getField("I.timestamp.J") locationInfo.klass.classInfo.getField("I.timestamp.J")
.set(locationInfo, Long.fromNumber(pos.timestamp)); .set(locationInfo, Long.fromNumber(pos.timestamp));
locationInfo.class.getField("I.latitude.D") locationInfo.klass.classInfo.getField("I.latitude.D")
.set(locationInfo, pos.latitude); .set(locationInfo, pos.latitude);
locationInfo.class.getField("I.longitude.D") locationInfo.klass.classInfo.getField("I.longitude.D")
.set(locationInfo, pos.longitude); .set(locationInfo, pos.longitude);
locationInfo.class.getField("I.altitude.F") locationInfo.klass.classInfo.getField("I.altitude.F")
.set(locationInfo, pos.altitude); .set(locationInfo, pos.altitude);
locationInfo.class.getField("I.horizontalAccuracy.F") locationInfo.klass.classInfo.getField("I.horizontalAccuracy.F")
.set(locationInfo, pos.horizontalAccuracy); .set(locationInfo, pos.horizontalAccuracy);
locationInfo.class.getField("I.verticalAccuracy.F") locationInfo.klass.classInfo.getField("I.verticalAccuracy.F")
.set(locationInfo, pos.verticalAccuracy); .set(locationInfo, pos.verticalAccuracy);
locationInfo.class.getField("I.speed.F") locationInfo.klass.classInfo.getField("I.speed.F")
.set(locationInfo, pos.speed); .set(locationInfo, pos.speed);
locationInfo.class.getField("I.course.F") locationInfo.klass.classInfo.getField("I.course.F")
.set(locationInfo, pos.heading); .set(locationInfo, pos.heading);
locationInfo.class.getField("I.method.I") locationInfo.klass.classInfo.getField("I.method.I")
.set(locationInfo, 0); .set(locationInfo, 0);
return true; return true;
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.getStateImpl.(I)I", function(providerId) { Native["com/sun/j2me/location/PlatformLocationProvider.getStateImpl.(I)I"] = function(providerId) {
var provider = Location.Providers[providerId]; var provider = Location.Providers[providerId];
return provider.state; return provider.state;
}); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.waitForNewLocation.(IJ)Z", function(providerId, timeout) { Native["com/sun/j2me/location/PlatformLocationProvider.waitForNewLocation.(IJ)Z"] = function(providerId, timeout) {
return new Promise(function(resolve, reject) { asyncImpl("Z", new Promise(function(resolve, reject) {
var provider = Location.Providers[providerId]; var provider = Location.Providers[providerId];
provider.requestData().then(resolve.bind(null, true)); provider.requestData().then(resolve.bind(null, true));
setTimeout(resolve.bind(null, false), timeout); setTimeout(resolve.bind(null, false), timeout);
}); }));
}, true); };
Native.create("com/sun/j2me/location/PlatformLocationProvider.receiveNewLocationImpl.(IJ)Z", function(providerId, timestamp) { Native["com/sun/j2me/location/PlatformLocationProvider.receiveNewLocationImpl.(IJ)Z"] = function(providerId, timestamp) {
var provider = Location.Providers[providerId]; var provider = Location.Providers[providerId];
return Math.abs(timestamp.toNumber() - provider.position.timestamp) < 10000; return Math.abs(timestamp.toNumber() - provider.position.timestamp) < 10000;
}); };