Skip to content

Commit b372a8c

Browse files
committed
Add support for the --main argument
Using --main-class also works, for partial backwards compatibility. This feature leans on the new MainService to do most of the work.
1 parent 09e8a7d commit b372a8c

File tree

1 file changed

+99
-0
lines changed

1 file changed

+99
-0
lines changed
Lines changed: 99 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,99 @@
1+
/*
2+
* #%L
3+
* SciJava Common shared library for SciJava software.
4+
* %%
5+
* Copyright (C) 2009 - 2015 Board of Regents of the University of
6+
* Wisconsin-Madison, Broad Institute of MIT and Harvard, and Max Planck
7+
* Institute of Molecular Cell Biology and Genetics.
8+
* %%
9+
* Redistribution and use in source and binary forms, with or without
10+
* modification, are permitted provided that the following conditions are met:
11+
*
12+
* 1. Redistributions of source code must retain the above copyright notice,
13+
* this list of conditions and the following disclaimer.
14+
* 2. Redistributions in binary form must reproduce the above copyright notice,
15+
* this list of conditions and the following disclaimer in the documentation
16+
* and/or other materials provided with the distribution.
17+
*
18+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
22+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28+
* POSSIBILITY OF SUCH DAMAGE.
29+
* #L%
30+
*/
31+
32+
package org.scijava.main.console;
33+
34+
import java.util.ArrayList;
35+
import java.util.LinkedList;
36+
import java.util.List;
37+
38+
import org.scijava.console.AbstractConsoleArgument;
39+
import org.scijava.console.ConsoleArgument;
40+
import org.scijava.log.LogService;
41+
import org.scijava.main.MainService;
42+
import org.scijava.plugin.Parameter;
43+
import org.scijava.plugin.Plugin;
44+
45+
/**
46+
* Handles the {@code --main} command line argument, which launches an
47+
* alternative main class.
48+
*
49+
* @author Curtis Rueden
50+
*/
51+
@Plugin(type = ConsoleArgument.class)
52+
public class MainArgument extends AbstractConsoleArgument {
53+
54+
@Parameter(required = false)
55+
private MainService mainService;
56+
57+
@Parameter(required = false)
58+
private LogService log;
59+
60+
// -- ConsoleArgument methods --
61+
62+
@Override
63+
public void handle(final LinkedList<String> args) {
64+
if (!supports(args)) return;
65+
66+
args.removeFirst(); // --main / --main-class
67+
final String className = args.removeFirst();
68+
69+
final List<String> argList = new ArrayList<String>();
70+
while (!args.isEmpty() && !isMainFlag(args) && !isSeparator(args)) {
71+
argList.add(args.removeFirst());
72+
}
73+
if (isSeparator(args)) args.removeFirst(); // remove the -- separator
74+
final String[] mainArgs = argList.toArray(new String[argList.size()]);
75+
76+
mainService.addMain(className, mainArgs);
77+
}
78+
79+
// -- Typed methods --
80+
81+
@Override
82+
public boolean supports(final LinkedList<String> args) {
83+
return mainService != null && isMainFlag(args);
84+
}
85+
86+
// -- Helper methods --
87+
88+
private boolean isMainFlag(final LinkedList<String> args) {
89+
if (args == null || args.isEmpty()) return false;
90+
final String arg = args.getFirst();
91+
return arg.equals("--main") || arg.equals("--main-class");
92+
}
93+
94+
private boolean isSeparator(final LinkedList<String> args) {
95+
if (args == null || args.isEmpty()) return false;
96+
return args.getFirst().equals("--");
97+
}
98+
99+
}

0 commit comments

Comments
 (0)