-
Notifications
You must be signed in to change notification settings - Fork 77
Export Your Project to a Jar
Currently, the Java Project Manager offers two effective modes to help you export a workspace to a jar. The primary one offers an exporting wizard, which will guide you to export your workspace to a jar by some steps. The advanced one exports jar by custom tasks. You can create your own export task by defining some attributes. You can run it to export jar without any extra step then.
In the Java Project
explorer, you can see an export button on the title. When you hover on it, you will see Export Jar...
as the following picture shows:
You can click this button to start the export process.
If your VS Code workspace has multiple workspace folders, you may choose one workspace folder to export:
The other way to export jar with a specific workspace is clicking the inline button in the workspace of the Java Project
explorer, as the following picture shows:
note: If you use inline button to export jar, the export process will automatically export the chosen workspace and you don't need to choose it manually. If your workspace has only one workspace folder, no action is required in this step.
Then, if one or more executable classes containing main method are found in your workspace, you will see the wizard to choose the main class:
In this step, your chosen main class will be the Main-Class
attribute in the MANIFEST.MF
of the output jar. You can choose <without main class>
to keep the Main-Class
of the MANIFEST.MF
empty.
note: You can click the back button on the top left corner of the wizard to return to the last step. If no executable class is found in the workspace folder, no action is required in this step.
After that, you will see the wizard choosing the elements of the output jar. You will see a list including output folders and the dependency artifacts of the workspace:
As shown in the above picture, each element has a description to present the scope. The runtime
elements are chosen by default while the test
ones are not. You can choose the elements you need and click OK
.
note: If only one element is found in your workspace, this step will be skipped and the element will be included in the export jar automatically.
After that, the export process will start and show progress message in the status bar.
If everything goes well, you will see a notification telling you that the export process is successfully finished.
You can change the setting java.project.exportJar.targetPath
to specific the output path of the exported jar. If you want to select the output location manually when exporting the jar file, simply leave it empty or set it to askUser
.
note: VS Code variables are allowed in this setting. For example, you can use
${workspaceFolder}
to represent the path of workspace folder. To know more about VS Code variables, see: VS Code Variables Reference.
For advanced usages such as automatic exporting jar, you can customize what to export by changing the attributes of export task. The available template of tasks can be found at Terminal->Configure Tasks...
.
Here is an example of tasks.json including an export jar task:
{
"version": "2.0.0",
"tasks": [
{
"type": "java",
"label": "java: exportjar:demo",
"mainClass": "demo.App",
"targetPath": "${workspaceFolder}/${workspaceFolderBasename}.jar",
"elements": [
"${compileOutput}",
"${testCompileOutput}",
"${dependencies}",
"${testDependencies}",
"!${compileOutput}/demo/innerPkg",
"C:/work/demo/test.iml"
],
"problemMatcher": []
}
]
}
The following attributes are mandatory for every task configuration:
-
type
- the type of export jar task, should always bejava
. -
label
- the name of export jar task. When you are going to run a task fromTerminal->Run Task...
, the labels of all available tasks will appear in the list.
Here are some optional attributes available to all launch configurations:
-
mainClass
- theMain-Class
inMANIFEST.MF
. If this attribute is not specified, the wizard to select the mainClass will appear during the export process. -
targetPath
- the target path of jar. VS Code variables is available in this attribute. If this attribute is not specified, the export process will apply the settingjava.project.exportJar.targetPath
. -
elements
- The array of elements to export. If this attribute is not specified, the wizard to select the elements will appear during the export process. This attribute is using glob patterns so you can also use!
to specify which not to include. Both absolute path and relative path to the workspace folder are supported here.
These reserved words are available in the elements
:
-
${compileOutput}
- the folders containing output class files in the runtime scope. -
${testCompileOutput}
- the folders containing output class files in the test scope. -
${dependencies}
- the artifact dependencies in the runtime scope. -
${testDependencies}
- the artifact dependencies in the test scope.
note : The reserved words can be used to stand for a specific project. For example, if your workspace includes more than one workspace folder, one of them is
demo
. The${compileOutput}
will stand for the folders containing output class files in the runtime scope of all the workspace folders while the${compileOutput:demo}
stands for those of folderdemo
only.
You can run the custom task by clicking Terminal->Run Task
:
and select the java
type:
Then the wizard will show all the available export jar tasks. You can find your custom task here and click it to export your customized jar.