Solved

MIDP preverification snag: "java/lang/NoClassDefFoundError: javax/microedition/lcdui/CommandListener"

Posted on 2004-08-16
9
1,383 Views
Last Modified: 2013-11-24
Java MIDP applications must be preverified before they can be executed on target devices.  (See http://developers.sun.com/techtopics/mobility/midp/articles/setup/#compile.)

While attempting to preverify \\midp2.0fcs\src\example\HelloMIDlet.java (which compiles just fine), I get the following error:

"Error preverifying class HelloMIDlet
    java/lang/NoClassDefFoundError: javax/microedition/lcdui/CommandListener"

This is odd, considering javax/microedition/lcdui/ (which does indeed contain CommandListener.class) is a subfolder of my classpath.  (If it wasn't, then the HelloMIDlet.java source obviously wouldn't have compiled in the first place.)

I did a search and found that the problem dates back to the year 2000.  (Nice.)  The only solution I found -- unpacking a midp.jar file and directing the classpath to a folder with its contents -- is no good, since there is no midp.jar file.

Has anyone successfully compiled HelloMIDlet.java?  What is the solution to the java/lang/NoClassDefFoundError: javax/microedition/lcdui/CommandListener problem?
0
Comment
Question by:MiloDC
  • 5
  • 3
9 Comments
 
LVL 35

Expert Comment

by:girionis
ID: 11808515
How do you compile it? Do you specify the classpath on the command line? If yes then you will also need to specify the classpath upon verification.
0
 

Author Comment

by:MiloDC
ID: 11808607
> girionis wrote:

> How do you compile it? Do you specify the classpath on the command line? If yes then you will also need to specify the classpath upon verification.

I do indeed specify the classpath during compilation and preverification.  Specifically:

Compile:
javac -bootclasspath C:\midp2.0fcs\classes -deprecation -g -d "TmpClasses" -classpath C:\j2sdk1.4.2_05\lib\tools.jar;C:\j2sdk1.4.2_05\lib\;C:\midp2.0fcs\classes\;. HelloMIDlet.java

Preverify:
preverify -cldc -classpath C:\j2sdk1.4.2_05\lib\tools.jar;C:\j2sdk1.4.2_05\lib\;C:\midp2.0fcs\classes\;. TmpClasses -d "Classes"

Nevertheless, I get the error upon preverification.

Very odd.

0
 
LVL 35

Expert Comment

by:girionis
ID: 11808626
> Nevertheless, I get the error upon preverification.

Hmm.. You might not be able to use the -classpath switch with preverification. Can you do a preverify -help (or preverify --help)? YOu will probably get all the available switches that you can use with preverify.
0
Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

 

Author Comment

by:MiloDC
ID: 11808928
> girionis wrote:

> You might not be able to use the -classpath switch with preverification.

-classpath is a valid option.  This is confirmed in the documentation from Sun Microsystems.
0
 
LVL 35

Accepted Solution

by:
girionis earned 125 total points
ID: 11809028
Weird, can you try that one:

preverify -cldc -classpath C:\j2sdk1.4.2_05\lib\tools.jar;C:\j2sdk1.4.2_05\lib\;C:\midp2.0fcs\classes;. TmpClasses -d "Classes"

(note that classes folder does not have a \ at the end). Not sure if this will help though.
0
 
LVL 35

Expert Comment

by:girionis
ID: 11809046
Can you also tell me if this class:

javax/microedition/lcdui/CommandListener is in a jar file or not? What happens if you put that jar file in the classpath?
0
 
LVL 18

Expert Comment

by:armoghan
ID: 11810029
I use IDE JBuilderX. You can also download the trial version from JBuilder Site. It has 5-6 sample projects including HelloMIDlet.java. Just run them using the IDE. I just changed the classpath a littlebit and they run fine in the emulator. .Jad files are also automatically made. I just sink them and they are running fine on my PocketPC
0
 

Author Comment

by:MiloDC
ID: 11812011
Thanks for the answer, girionis.  :)

The slash after "C:\midp2.0fcs\classes" was the culprit.  How lame.
0
 
LVL 35

Expert Comment

by:girionis
ID: 11812058
Well, computing is a bizarre field, even a little dot counts :)

Thank you for accepting, glad I was of help :)
0

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Java contains several comparison operators (e.g., <, <=, >, >=, ==, !=) that allow you to compare primitive values. However, these operators cannot be used to compare the contents of objects. Interface Comparable is used to allow objects of a cl…
Introduction Java can be integrated with native programs using an interface called JNI(Java Native Interface). Native programs are programs which can directly run on the processor. JNI is simply a naming and calling convention so that the JVM (Java…
Video by: Michael
Viewers learn about how to reduce the potential repetitiveness of coding in main by developing methods to perform specific tasks for their program. Additionally, objects are introduced for the purpose of learning how to call methods in Java. Define …
This theoretical tutorial explains exceptions, reasons for exceptions, different categories of exception and exception hierarchy.

860 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question