IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Android Discussion :

JIBX sous android. LogCat affiche: Could not find class 'X', referenced from method 'Y


Sujet :

Android

  1. #1
    Membre averti
    Avatar de Heavy Metal Hero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2007
    Messages : 152
    Points : 333
    Points
    333
    Billets dans le blog
    13
    Par défaut JIBX sous android. LogCat affiche: Could not find class 'X', referenced from method 'Y
    Bonjour,
    Je développe une application sous Eclipse devant utiliser la lib JIBX. J'ai commencé par suivre ce tutoriel. Tout fonctionne parfaitement dans un projet JAVA classique. Je peux générer un xsd à partir de classe, générer des classes à partir d'un xsd puis exécuter le programme qui retourne les bons résultats.

    J'ai voulu refaire ce tuto mais sur android. J'ai réimporté les mêmes libs que le projet classique pour que ça compile (JIBX est censé être compatible avec Android). Je peux générer les classes et les objets, mais lorsque j'essaye de compiler ce projet, une erreur apparait sur le téléphone virtuel et le LogCat affiche le message suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    09-10 12:33:54.957: I/Process(1905): Sending signal. PID: 1905 SIG: 9
    09-10 12:34:05.047: I/dalvikvm(1944): Could not find method org.jibx.runtime.BindingDirectory.getFactory, referenced from method com.example.jibxtestandroid.MainActivity.calcul
    09-10 12:34:05.079: W/dalvikvm(1944): VFY: unable to resolve static method 25: Lorg/jibx/runtime/BindingDirectory;.getFactory (Ljava/lang/Class;)Lorg/jibx/runtime/IBindingFactory;
    09-10 12:34:05.079: D/dalvikvm(1944): VFY: replacing opcode 0x71 at 0x0004
    09-10 12:34:05.079: W/dalvikvm(1944): VFY: unable to resolve exception class 34 (Lorg/jibx/runtime/JiBXException;)
    09-10 12:34:05.079: W/dalvikvm(1944): VFY: unable to find exception handler at addr 0x8
    09-10 12:34:05.087: W/dalvikvm(1944): VFY:  rejected Lcom/example/jibxtestandroid/MainActivity;.calcul ()Ljava/lang/String;
    09-10 12:34:05.087: W/dalvikvm(1944): VFY:  rejecting opcode 0x0d at 0x0008
    09-10 12:34:05.087: W/dalvikvm(1944): VFY:  rejected Lcom/example/jibxtestandroid/MainActivity;.calcul ()Ljava/lang/String;
    09-10 12:34:05.087: W/dalvikvm(1944): Verifier rejected class Lcom/example/jibxtestandroid/MainActivity;
    09-10 12:34:05.087: W/dalvikvm(1944): Class init failed in newInstance call (Lcom/example/jibxtestandroid/MainActivity;)
    09-10 12:34:05.087: D/AndroidRuntime(1944): Shutting down VM
    09-10 12:34:05.087: W/dalvikvm(1944): threadid=1: thread exiting with uncaught exception (group=0x414c4700)
    09-10 12:34:05.147: E/AndroidRuntime(1944): FATAL EXCEPTION: main
    09-10 12:34:05.147: E/AndroidRuntime(1944): java.lang.VerifyError: com/example/jibxtestandroid/MainActivity
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at java.lang.Class.newInstanceImpl(Native Method)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at java.lang.Class.newInstance(Class.java:1130)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.app.ActivityThread.access$600(ActivityThread.java:141)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.os.Handler.dispatchMessage(Handler.java:99)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.os.Looper.loop(Looper.java:137)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at android.app.ActivityThread.main(ActivityThread.java:5103)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at java.lang.reflect.Method.invokeNative(Native Method)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at java.lang.reflect.Method.invoke(Method.java:525)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
    09-10 12:34:05.147: E/AndroidRuntime(1944): 	at dalvik.system.NativeStart.main(Native Method)
    09-10 12:39:05.443: I/Process(1944): Sending signal. PID: 1944 SIG: 9
    J'ai commencé par référencer jibx-run.jar et à le cocher dans le buildpath, à l'onglet order and export. Je l'ai même mis au top. ça n'a rien changé. Le message d'erreur restait le même. J'ai alors pensé à référencer et cocher toutes les libs importées de JIBX. Là, éclipse plante et affiche un message d'erreur : "Unable to execute dex: Java heap space ", qui veut sûrement dire que les libs chargées sont trop lourdes (l'ensemble fait 7Mo).

    Avez-vous une idée d'où viens l'erreur ? Les librairies sont correctement incluses et il n'y pas d'erreur eclipse.
    Merci

  2. #2
    Rédacteur
    Avatar de MrDuChnok
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2002
    Messages
    2 112
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 112
    Points : 4 240
    Points
    4 240
    Par défaut
    Si la librairie n'est pas prévu pour Android elle ne fonctionnera pas.
    Si vous jugez mon post utile dans la résolution de votre problème, n'hésitez pas à utiliser le système de vote afin d'améliorer la qualité du forum

  3. #3
    Membre averti
    Avatar de Heavy Metal Hero
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Juin 2007
    Messages : 152
    Points : 333
    Points
    333
    Billets dans le blog
    13
    Par défaut
    Elle est prévue. Elle est basée sur XmlPull.
    En fait j'ai trouvé la solution. il fallait que j'ajoute au build path uniquement jibx-schema.jar, qui a ajouté automatiquement jibx-run.jar et quelques autres librairies (pas toutes justement). Ensuite il fallait cocher cette librairie dans l'onglet order and export

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [JDOM] "Could not find class 'org.jdom.input.SAXBuilder'"
    Par Sussu49 dans le forum Format d'échange (XML, JSON...)
    Réponses: 3
    Dernier message: 13/05/2012, 02h35
  2. Réponses: 4
    Dernier message: 10/02/2011, 21h14
  3. wsgen ant Could not find class file
    Par pcouas dans le forum Services Web
    Réponses: 1
    Dernier message: 28/07/2010, 12h44
  4. Réponses: 0
    Dernier message: 16/05/2008, 11h07
  5. Réponses: 3
    Dernier message: 30/03/2005, 23h15

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo