Плагин Cordova, написанный на Swift, не вызывает плагин через cordova.exec()
Я добавил CordovaLib 3.8.0 в проект Swift (как автономное веб-представление (Cleaver), а не как полностью основанный на Cordova проект). Для этого я следовал инструкциям на сайте PhoneGap, а затем создал и добавил следующий заголовок:
// Cordova-Bridging-Header.h
#import <Cordova/CDV.h>
Затем я создал простой плагин:
// HelloPlugin.swift
import Foundation
@objc(HelloPlugin) class HelloPlugin: CDVPlugin {
override func pluginInitialize() {
super.pluginInitialize();
}
func sayHello( command: CDVInvokedUrlCommand ) {
let pluginResult = CDVPluginResult(status: CDVCommandStatus_OK, messageAsString: "hello");
commandDelegate.sendPluginResult( pluginResult, callbackId: command.callbackId );
}
}
А потом я добавил его в мой config.xml
// config.xml
[...]
<feature name="HelloPlugin">
<param name="ios-package" value="HelloPlugin" />
<param name="onload" value="true" />
</feature>
Когда я запускаю свое приложение (в симуляторе), я вижу, что и Cordova, и плагин загружаются:
2015-04-07 20:28:09.277 Test[32687:4349827] Apache Cordova native platform version 3.8.0 is starting.
2015-04-07 20:28:09.278 Test[32687:4349827] Multi-tasking -> Device: YES, App: YES
2015-04-07 20:28:09.279 Test[32687:4349827] Unlimited access to network resources
2015-04-07 20:28:09.362 Test[32687:4349827] [CDVTimer][helloplugin] 0.042975ms
2015-04-07 20:28:09.362 Test[32687:4349827] [CDVTimer][TotalPluginStartup] 0.176013ms
Однако, если я захожу в консоль JS через safari и пытаюсь вызвать функцию sayHello, я ничего не получаю.
// JS (ran manually on console)
cordova.exec(
// success
function(){
console.log( 'success ->', this, arguments );
},
// failure
function(){
console.log( 'fail ->', this, arguments );
},
// plugin name
'HelloPlugin',
// method name
'sayHello',
// arguments
['a', 'b', 2]
);
Затем я вошел в CDVViewController.m и поместил точку останова в обработчик схемы URL:
- (BOOL)webView:(UIWebView*)theWebView shouldStartLoadWithRequest:(NSURLRequest*)request navigationType:(UIWebViewNavigationType)navigationType
{
NSURL* url = [request URL];
/*
* Execute any commands queued with cordova.exec() on the JS side.
* The part of the URL after gap:// is irrelevant.
*/
if ([[url scheme] isEqualToString:@"gap"]) {
Я обнаружил, что этот код вообще не вызывается при выполнении cordova.exec(). Я поставил точку останова в том же месте в моем проекте Objective-C, который использует Cordova в основном таким же образом, и точка останова срабатывает.
Я что-то пропустил или должен попробовать?