Привлечение Scala 2.8 в проект NBAndroid Netbeans ... Какие шаги я пропускаю? - PullRequest
1 голос
/ 13 апреля 2010

Из-за недавних ухищрений Apple по T + C я заинтересовался разработкой для Android.

В любом случае, я пытаюсь запустить проект Android 2.1 на смешанном языке в Netbeans 6.8 (с плагином NBAndroid 0.10). Два языка - Java и Scala (сборка 2,8 головы). Чтобы дать вам общее представление о том, что приложение делает прямо сейчас, это просто простое приложение «Hello World».

Чтобы собрать это, я изменил файл build.xml проектов:

 <target name="-pre-compile" depends="init">
   <property name="scala-home" value="/Users/development/Applications/scala-2.8.0/build/pack"/>
   <property name="scala-library" value="/Users/development/Applications/scala-2.8.0/build/pack/lib/scala-library.jar"/>
   <echo message="scala-library = ${scala-library}"/>
   <echo message="scala-home = ${scala-home}"/>
   <echo message="platform.bootcp = ${platform.bootcp}"/>
   <echo message="dist.apk.dir = ${dist.apk.dir}"/>
   <echo message="build.classes.dir = ${build.classes.dir}"/>
   <path id="build.classpath">
     <pathelement location="${scala-library}"   />
     <!--<pathelement location="${your.path}"   />-->
     <pathelement location="${build.classes.dir}"   />
   </path>
   <taskdef resource="scala/tools/ant/antlib.xml">
     <classpath>
       <pathelement location="${scala.home}/lib/scala-compiler.jar"   />
       <pathelement location="${scala-library}"   />
       <pathelement location="${javac.classpath}" /> 
     </classpath>
   </taskdef>
   <scalac srcdir="${src.ScalaSource.dir}" destdir="${build.classes.dir}" >
      <classpath>
       <pathelement location="/Users/development/Documents/AndroidTest/scala-library.jar"   />
       <pathelement location = "${scala-library}" />
       <pathelement location = "${file.reference.android.jar}" />
       <pathelement path="${javac.classpath}" /> 
     </classpath>
   </scalac>
   <echo message="file.reference.android.jar: ${file.reference.android.jar}"/>
   <echo message="file.reference.scala-library.jar: ${file.reference.scala-library.jar}"/>
 </target>

 <target name="-pre-jar">
        <!-- Empty placeholder for easier customization. -->
        <!-- You can override this target in the ../build.xml file. -->
 <taskdef resource="proguard/ant/task.properties"
   classpath="tools/proguard.jar" />
 <proguard>
   -injars ${scala-library}(!META-INF/MANIFEST.MF,!library.properties)
   -outjars "${build.classes.dir}/classes.min.jar"
   -libraryjars "${file.reference.android.jar}"
   -dontwarn
   -dontoptimize
   -dontobfuscate
   -keep public class * extends android.app.Activity
   -keep public class scala.xml.include.sax.Main**
 </proguard>
    </target>

Я получил проект, чтобы он собирался, но в моем эмуляторе Android возникают ошибки при запуске (внутри эмулятора Android сообщает, что мое приложение неожиданно остановилось).

Итак, мои вопросы: кто-нибудь видит, что я могу делать неправильно? И есть ли способ получить доступ к журналам, которые должен создать эмулятор?

спасибо

Редактировать : К вашему сведению, вот вывод из adb logcat:

I/dalvikvm(  369): Failed resolving Lorg/me/androidtest/MainActivity; interface 35 'Lscala/ScalaObject;'
W/dalvikvm(  369): Link of class 'Lorg/me/androidtest/MainActivity;' failed
D/AndroidRuntime(  369): Shutting down VM
W/dalvikvm(  369): threadid=3: thread exiting with uncaught exception (group=0x4001b188)
E/AndroidRuntime(  369): Uncaught handler: thread main exiting due to uncaught exception
E/AndroidRuntime(  369): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{org.me.androidtest/org.me.androidtest.MainActivity}: java.lang.ClassNotFoundException: org.me.androidtest.MainActivity in loader dalvik.system.PathClassLoader@43d02720
E/AndroidRuntime(  369):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2417)
E/AndroidRuntime(  369):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512)
E/AndroidRuntime(  369):    at android.app.ActivityThread.access$2200(ActivityThread.java:119)
E/AndroidRuntime(  369):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863)
E/AndroidRuntime(  369):    at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(  369):    at android.os.Looper.loop(Looper.java:123)
E/AndroidRuntime(  369):    at android.app.ActivityThread.main(ActivityThread.java:4363)
E/AndroidRuntime(  369):    at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(  369):    at java.lang.reflect.Method.invoke(Method.java:521)
E/AndroidRuntime(  369):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
E/AndroidRuntime(  369):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
E/AndroidRuntime(  369):    at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(  369): Caused by: java.lang.ClassNotFoundException: org.me.androidtest.MainActivity in loader dalvik.system.PathClassLoader@43d02720
E/AndroidRuntime(  369):    at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
E/AndroidRuntime(  369):    at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
E/AndroidRuntime(  369):    at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
E/AndroidRuntime(  369):    at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
E/AndroidRuntime(  369):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2409)
E/AndroidRuntime(  369):    ... 11 more
I/Process (   56): Sending signal. PID: 369 SIG: 3
I/dalvikvm(  369): threadid=7: reacting to signal 3
I/dalvikvm(  369): Wrote stack trace to '/data/anr/traces.txt'
W/ActivityManager(   56): Launch timeout has expired, giving up wake lock!

Ясно, что это какой-то тип загрузчика классов / classpath или что-то в этом роде (по крайней мере, это то, что я бы сказал, если бы это была JVM), но когда я смотрю в свой jarfile Proguard, я нахожу классы, которые я ожидал: scala.ScalaObject, org.me.androidtest.MainActivity и некоторые другие.

Если это помогает проекту со всеми его внутренними зависимостями, находится по адресу http://philosophicalsoftware.com/AndroidTest.zip

Ответы [ 2 ]

1 голос
/ 13 апреля 2010

Кто-нибудь видит, что я могу делать? неправильно?

Да. У вас нет исходного кода. : -)

И есть ли способ получить доступ к логи, которые должен эмулятор создать?

Я не уверен насчет внутри Netbeans, но вы можете использовать adb logcat или DDMS для проверки журналов, которые будут содержать ... ну ... что-то. Обычно я бы сказал «трассировка стека Java, показывающая причину вашего исключения», но я не на 100% уверен, что произойдет с приложением Scala (хотя я планирую в ближайшее время провести некоторые эксперименты со Scala / Android).

0 голосов
/ 10 декабря 2010

У меня была такая же проблема, и я наконец нашел решение:)

В моем случае я не менял значение свойства out.dex.input.absolute.dir (в SDK Tools r8) на файл jar, созданный Proguard. Итак, интерфейс ScalaObject действительно отсутствовал в файле apk.

(я обнаружил, что при использовании apktool .)

...