Исключение нулевого указателя Kotlin при попытке получить контекст из Registar во Flutter - PullRequest
1 голос
/ 10 апреля 2019

Я пытаюсь создать плагин Flutter, который использует собственный Android SDK

Я могу скомпилировать библиотеки .aar SDK и использовать их в проекте, но SDK требует от меня получитьконтекст основного действия

вот ошибка, которую я получаю

E/MethodChannel#mychart_plugin(16277): Failed to handle method call
E/MethodChannel#mychart_plugin(16277): kotlin.KotlinNullPointerException
E/MethodChannel#mychart_plugin(16277):  at org.ccf.flutter.plugin.mychart_plugin.MychartPlugin.getContext(MychartPlugin.kt:79)
E/MethodChannel#mychart_plugin(16277):  at epic.mychart.android.library.api.authentication.WPAPIAuthentication$1.getContext(WPAPIAuthentication.java:564)
E/MethodChannel#mychart_plugin(16277):  at epic.mychart.android.library.prelogin.AuthenticationService.libraryLogin(AuthenticationService.java:461)
E/MethodChannel#mychart_plugin(16277):  at epic.mychart.android.library.api.authentication.WPAPIAuthentication.login(WPAPIAuthentication.java:411)
E/MethodChannel#mychart_plugin(16277):  at org.ccf.flutter.plugin.mychart_plugin.MychartPlugin.onMethodCall(MychartPlugin.kt:42)
E/MethodChannel#mychart_plugin(16277):  at io.flutter.plugin.common.MethodChannel$IncomingMethodCallHandler.onMessage(MethodChannel.java:201)
E/MethodChannel#mychart_plugin(16277):  at io.flutter.embedding.engine.dart.DartMessenger.handleMessageFromDart(DartMessenger.java:88)
E/MethodChannel#mychart_plugin(16277):  at io.flutter.embedding.engine.FlutterJNI.handlePlatformMessage(FlutterJNI.java:219)
E/MethodChannel#mychart_plugin(16277):  at android.os.MessageQueue.nativePollOnce(Native Method)
E/MethodChannel#mychart_plugin(16277):  at android.os.MessageQueue.next(MessageQueue.java:325)
E/MethodChannel#mychart_plugin(16277):  at android.os.Looper.loop(Looper.java:142)
E/MethodChannel#mychart_plugin(16277):  at android.app.ActivityThread.main(ActivityThread.java:6541)
E/MethodChannel#mychart_plugin(16277):  at java.lang.reflect.Method.invoke(Native Method)
E/MethodChannel#mychart_plugin(16277):  at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
E/MethodChannel#mychart_plugin(16277):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)

вот мой код для получения контекста

class MychartPlugin: MethodCallHandler, WPAPIAuthentication.IWPOnLoginListener {
private var registrar: PluginRegistry.Registrar? = null
private val LOGIN_REQUEST_CODE = 9876

fun MychartPlugin(registrar: PluginRegistry.Registrar) {
  this.registrar = registrar
}
companion object {
  @JvmStatic
  fun registerWith(registrar: Registrar) {
    val channel = MethodChannel(registrar.messenger(), "mychart_plugin")
    channel.setMethodCallHandler(MychartPlugin())
  }
}

override fun onMethodCall(call: MethodCall, result: Result) {
  if (call.method == "getPlatformVersion") {
    result.success("Android ${android.os.Build.VERSION.RELEASE}")
  } else if (call.method == "MyChartSdkLogin") {
  WPAPIAuthentication.login(this, "TURKJ123", "TurkJ123", LOGIN_REQUEST_CODE)
    result.success("called MyChartSdkLogin")
  }  else {
    result.notImplemented()
  }
}


override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) {
  // super.onActivityResult(requestCode, resultCode, data)
  if (requestCode == LOGIN_REQUEST_CODE) {
    if (resultCode == Activity.RESULT_OK) {
      // login successful
      Log.i("LoginFragment", "OK")

    } else {
      // login failed
      val result = WPAPIAuthentication.getLoginResult(data)
      Log.i("LoginFragment", result.toString())
      val errorMessage = result.getErrorMessage(getContext())
      if (!errorMessage.isEmpty()) {
        Toast.makeText(getContext(), errorMessage, Toast.LENGTH_LONG).show()
      }
    }
  }
}

override fun startActivityForResult(p0: Intent, p1: Int) {
  // super.startActivityForResult(p0, p1)
}

override fun getSupportFragmentManager(): FragmentManager {
  val act = registrar!!.activity() as FragmentActivity
  return act.getSupportFragmentManager()
}

override fun getContext(): Context {
  val cxt = registrar!!.context()
  return cxt
}

}

обратите внимание на переопределение getContext ()метод, который я переопределяю из sdk, я думаю, что этот контекстный вызов для регистратора - то, откуда исходит мое исключение KotlinNullPointerException

1 Ответ

1 голос
/ 10 апреля 2019

В getContext у вас есть registrar!!registrar - это пустое поле, которое вы инициализируете для null, и оно может быть установлено только в методе, который вы никогда не вызываете.Обратите внимание, что fun MychartPlugin не является конструктором, вы бы назвали его, например,

val plugin = MychartPlugin()
plugin.MychartPlugin(registrar)

Но, похоже, нет никаких оснований делать registrar обнуляемым или изменяемым во-первых,Вы можете изменить на

class MychartPlugin(private val registrar: Registrar): ...

и

fun registerWith(registrar: Registrar) {
  val channel = MethodChannel(registrar.messenger(), "mychart_plugin")
  channel.setMethodCallHandler(MychartPlugin(registrar))
}
...