java/sql-dk/src/info/globalcode/sql/dk/CLIStarter.java
author František Kučera <franta-hg@frantovo.cz>
Sun, 15 Dec 2013 20:16:27 +0100
branchv_0
changeset 2 72da10f632b5
parent 1 f32dac78d13a
child 3 efdf2b886feb
permissions -rw-r--r--
more code
franta-hg@1
     1
package info.globalcode.sql.dk;
franta-hg@1
     2
franta-hg@1
     3
/**
franta-hg@1
     4
 *
franta-hg@1
     5
 * @author Ing. František Kučera (frantovo.cz)
franta-hg@1
     6
 */
franta-hg@1
     7
public class CLIStarter {
franta-hg@1
     8
franta-hg@2
     9
	public static final String DEFAULT_NAME_PREFIX = ":";
franta-hg@2
    10
franta-hg@1
    11
	public static void main(String[] args) {
franta-hg@2
    12
franta-hg@1
    13
		args = new String[]{"--sql", "SELECT * FROM tabulka;", "--db", "databáze_1"};
franta-hg@2
    14
franta-hg@1
    15
		CLIOptions options = parseOptions(args);
franta-hg@1
    16
	}
franta-hg@1
    17
franta-hg@1
    18
	private static CLIOptions parseOptions(String[] args) {
franta-hg@1
    19
		CLIOptions options = new CLIOptions();
franta-hg@1
    20
franta-hg@2
    21
		String typesString = null;
franta-hg@2
    22
		String namePrefix = DEFAULT_NAME_PREFIX;
franta-hg@2
    23
franta-hg@2
    24
franta-hg@1
    25
		for (int i = 0; i < args.length; i++) {
franta-hg@1
    26
			String arg = args[i];
franta-hg@2
    27
			switch (arg) {
franta-hg@2
    28
				case Tokens.TYPES:
franta-hg@2
    29
					typesString = args[++i];
franta-hg@2
    30
					break;
franta-hg@2
    31
				case Tokens.NAME_PREFIX:
franta-hg@2
    32
					namePrefix = args[++i];
franta-hg@2
    33
					break;
franta-hg@2
    34
			}
franta-hg@2
    35
		}
franta-hg@1
    36
franta-hg@2
    37
franta-hg@2
    38
		for (int i = 0; i < args.length; i++) {
franta-hg@2
    39
			String arg = args[i];
franta-hg@1
    40
			switch (arg) {
franta-hg@2
    41
				case Tokens.TYPES:
franta-hg@2
    42
				case Tokens.NAME_PREFIX:
franta-hg@2
    43
					i++;
franta-hg@2
    44
					break;
franta-hg@1
    45
				case Tokens.DB:
franta-hg@2
    46
					options.setDatabaseName(args[++i]);
franta-hg@1
    47
					break;
franta-hg@1
    48
				case Tokens.SQL:
franta-hg@2
    49
					options.setSql(args[++i]);
franta-hg@2
    50
					options.setCommandType(CLIOptions.COMMAND_TYPE.QUERY);
franta-hg@1
    51
					break;
franta-hg@1
    52
				case Tokens.SQL_UPDATE:
franta-hg@2
    53
				case Tokens.SQL_INSERT:
franta-hg@2
    54
					options.setSql(args[++i]);
franta-hg@2
    55
					options.setCommandType(CLIOptions.COMMAND_TYPE.UPDATE);
franta-hg@1
    56
					break;
franta-hg@1
    57
				case Tokens.BATCH:
franta-hg@2
    58
					options.setBatch(true);
franta-hg@1
    59
					break;
franta-hg@1
    60
				case Tokens.DATA:
franta-hg@1
    61
					break;
franta-hg@1
    62
			}
franta-hg@1
    63
		}
franta-hg@1
    64
franta-hg@1
    65
		return options;
franta-hg@1
    66
franta-hg@1
    67
	}
franta-hg@1
    68
franta-hg@1
    69
	public static class Tokens {
franta-hg@1
    70
franta-hg@1
    71
		public static final String DB = "--db";
franta-hg@1
    72
		public static final String SQL = "--sql";
franta-hg@1
    73
		public static final String SQL_UPDATE = "--sql-update";
franta-hg@2
    74
		public static final String SQL_INSERT = "--sql-insert";
franta-hg@1
    75
		public static final String BATCH = "--batch";
franta-hg@1
    76
		public static final String DATA = "--data";
franta-hg@2
    77
		public static final String NAME_PREFIX = "--name-prefix";
franta-hg@1
    78
		public static final String TYPES = "--types";
franta-hg@1
    79
franta-hg@1
    80
		private Tokens() {
franta-hg@1
    81
		}
franta-hg@1
    82
	}
franta-hg@1
    83
}