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