8

I have the following code generated by Eclipse (.java file).

import org.eclipse.swt.widgets.Shell;

import org.eclipse.swt.widgets.Display;

public class HelloWorldSWT {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub

        Display display = new Display();
        Shell shell = new Shell(display);
        shell.setText("Hello world!");
        shell.open();
        while (!shell.isDisposed()) {
        if (!display.readAndDispatch()) display.sleep();
        }
        display.dispose();
    }

}

Now I want to compile the above file from the command line. I went to the directory where the source code is located and I tried two commands:
1. javac HelloWorldSWT.java
2. javac -d /home/myname/workspace/ HelloWorldSWT.java

In both cases I have the same error "The import org.eclipse cannot be resolved". /home/myname/workspace/ - is the directory where the class file is located.

As far as I understand the compiler does not see the org.eclipse.swt package. Why?

Can it be because the problematic package is located in "/home/myname/workspace/org.eclipse.swt/" (not in "/home/myname/workspace/org/eclipse/swt/")?

1
  • 1
    I know this is a serious question but i just had to point out what a hilarious sounding title "How to compile a .java file in Java?" is. Commented Oct 1, 2016 at 1:41

7 Answers 7

5

You need to set your classpath so that the Java compiler knows where to find the org.eclipse.* classes. You can do that with a command line switch or an environment variable.

Sign up to request clarification or add additional context in comments.

6 Comments

But I though that I specify the "classpath" during the compilation (using -d option). I though that after the "-d" option I put the name of directory where all my packages are located. Do I understand that wrongly?
Roman - the /d is where the compiled classes (ie the .class files) go... The classpath (isn't Java fun?) can be set with either the CLASSPATH Environment variable, or using the -classpath option of the javac program.
Thank you, Martin. Now it is more clear to me. However, I still get the same error message when I try "javac -d /home/myname/workspace/HelloWorldSWT/ -classpath /home/myname/workspace/ HelloWorldSWT.java".
my guess it org.eclipse.* class files are not in your directory but in some eclipse directory
They are in the plugins directory in your eclipse installation. But good luck figuring which of the 100 or so JAR files in that directory you actually need!
|
5

Ok, Stephen C I did this job by hand. I used only Notepad++ (I promise)

  1. Start Notepad++ and create file HelloWorldSWT.java
  2. Copy example from author
  3. Save it!
  4. Open cmd and go to the directory with HelloWorldSWT.java
  5. Run the command javac HelloWorldSWT.java

  6. Ok, go to the Eclipse directory and find the correct jar swt-3.4.2-win32-win32-x86.jar

  7. Run this again

    D:\workspaces\spf_workspace\hand-made>javac -cp "D:\Program files\eclipse3_5\plugins\org.eclipse.swt.win32.win32.x86_3.5.1.v3555a.jar" HelloWorldSWT.java

All process take 2 minutes.

Don't try to run this:

`D:\workspaces\spf_workspace\hand-made>java -cp "D:\Program files\eclipse3_5\plugins\org.eclipse.swt.win32.win32.x86_3.5.1.v3555a.jar;." HelloWorldSWT`

Note: I add current dir . to classpath too.

2 Comments

If you run it like that, how is SWT going to find its native (JNI) library?
org.eclipse.swt.win32.win32.x86_3.5.1.v3555a.jar contains native dll inside and during running it unzip it to system tmp dir (java use system tmp as placeholder for native libs by default as I know)
2

Since you are doing Eclipse RCP development, you should let Eclipse handle your compilation as well. (You will most likely find your classes in a "build" or "bin" directory in the project). In addition to compilation, there will be some "packaging" steps to create the final application, and Eclipse has tools for that, too.

If you really want to build outside of Eclipse, you need to manage a potentially large list of dependencies (such as org.eclipse.swt.widgets), which makes a pure javac unfeasible. You would need to look at Ant or Maven.

Also note that you will need the classpath to include dependencies not only for compilation, but also when you run the program.

12 Comments

But for understanding classpath/dependancy mechanism in java fully - compiling from shell is the best way. And using Notepad++ as IDE -)
Many people says that I will find my classes in "build" or "bin". But I found my class-file in the /home/myname/workspace/HelloWorldSWT/. Or we talking about different things? Can the dependencies problem be large in my simple case? I just want javac to see one package (org.eclipse)?
For learning classpath/dependency issues, maybe an SWT project is not a good way to start...
@St Shadow - that is true in theory. In practice, you should not pick an example as messy as Eclipse SWT / RCP for learning about these mechanisms.
Normal. SWT project is the same as any project where used at least one jar :)
|
0

But I though that I specify the "classpath" during the compilation (using -d option). I though that after the "-d" option I put the name of directory where all my packages are located. Do I understand that wrongly?

try

javac -help

to see what the different command line options do. also note the other post above that explains this.

compiling from the command line and setting up classpath and everything right is a pain. however, it is useful to do it so that you understand what the ide actually does when it automates this for you.

1 Comment

Thanks. I thing I got the idea. -d specify the directory where the class files, generated during the compilation, should go. And -classpath specify the directory where the packages are located. But when I use "javac -d /home/myname/workspace/HelloWorldSWT/ -classpath /home/myname/workspace/ HelloWorldSWT.java" I still get the old error message.
0

The classpath variable or command line switch needs to point to where the org.eclipse.swt.widgets.Shell class resides, if this class is inside a jar file, then the classpath needs to contain the actual jar file,

i.e. javac -classpath /root/to/jar/eclipse.jar

Otherwise, if the org.eclipse.swt.widgets.Shell class is just a loose class file (which I doubt, I assume it will be inside one of the eclipse jar files, which you can list using jar -tvf jar-you-think-it-might-be-in.jar)...then you will need the javac -classpath to point to the location of the top level directory within the org/eclipse/swt/widgets/ path.

Comments

0

@Roman - this problem is too complicated for a beginner to try to address. The problem is that SWT has complicated dependencies, including dependencies on native code libraries.

You are best off running your SWT application using Eclipse "RunAs" ... or trying to find some Eclipse-specific documentation on running SWT-based applications from the command line.

1 Comment

Stephen, I was able to run the application from the Eclipse. And I just managed to compile the class file (by javac -d /home/myname/workspace/HelloWorldSWT/ -cp /home/myname/workspace/org.eclipse.swt/swt.jar). But I still do not know how can I run the generated class file (but it is already another question).
-2

You forgot about classpath

2 Comments

But I though that I specify the "classpath" during the compilation (using -d option). I though that after the "-d" option I put the name of directory where all my packages are located. Do I understand that wrongly?
Yes, you understand me wrongly. Specify classpath exactly via -cp option: javac -cp <path_to_needed_jars>/jarname.jar;<path_to_needed_jars>/another_jarname.jar;<path_to_dir_with_compiled_classes> and so on

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.