12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
# File 'lib/arql/cli.rb', line 12
def parse_options!
@options = OpenStruct.new(config_file: default_config_file,
initializer: default_initializer,
ssh: {})
OptionParser.new do |opts|
opts.banner = " Usage: arql [options] [ruby file]\n\n If neither [ruby file] nor -e option specified, and STDIN is not a tty, a Pry REPL will be launched,\n otherwise the specified ruby file or -e option value or ruby code read from STDIN will be run, and no REPL launched\n\n EOF\n\n opts.on('-cCONFIG_FILE', '--conf=CONFIG_FILE', 'Specify config file, default is $HOME/.arql.yml, or $HOME/.arql.d/init.yml.') do |config_file|\n @options.config_file = config_file\n end\n\n opts.on('-iINITIALIZER', '--initializer=INITIALIZER', 'Specify initializer ruby file, default is $HOME/.arql.rb, or $HOME/.arql.d/init.rb.') do |initializer|\n @options.initializer = initializer\n end\n\n opts.on('-eENVIRON', '--env=ENVIRON', 'Specify config environment.') do |env|\n @options.env = env\n end\n\n opts.on('-aDB_ADAPTER', '--db-adapter=DB_ADAPTER', 'Specify database Adapter, default is mysql2') do |db_adapter|\n @options.adapter = db_adapter\n end\n\n opts.on('-hDB_HOST', '--db-host=DB_HOST', 'Specify database host') do |db_host|\n @options.host = db_host\n end\n\n opts.on('-pDB_PORT', '--db-port=DB_PORT', 'Specify database port') do |db_port|\n @options.port = db_port.to_i\n end\n\n opts.on('-dDB_NAME', '--db-name=DB_NAME', 'Specify database name') do |db_name|\n @options.database = db_name\n end\n\n opts.on('-uDB_USER', '--db-user=DB_USER', 'Specify database user') do |db_user|\n @options.username = db_user\n end\n\n opts.on('-PDB_PASSWORD', '--db-password=DB_PASSWORD', 'Specify database password') do |db_password|\n @options.password = db_password\n end\n\n opts.on('-n', '--db-encoding=DB_ENCODING', 'Specify database encoding, default is utf8') do |db_encoding|\n @options.encoding = db_encoding\n end\n\n opts.on('-o', '--db-pool=DB_POOL', 'Specify database pool size, default is 5') do |db_pool|\n @options.pool = db_pool\n end\n\n opts.on('-HSSH_HOST', '--ssh-host=SSH_HOST', 'Specify SSH host') do |ssh_host|\n @options.ssh[:host] = ssh_host\n end\n\n opts.on('-OSSH_PORT', '--ssh-port=SSH_PORT', 'Specify SSH port') do |ssh_port|\n @options.ssh[:port] = ssh_port.to_i\n end\n\n opts.on('-USSH_USER', '--ssh-user=SSH_USER', 'Specify SSH user') do |ssh_user|\n @options.ssh[:user] = ssh_user\n end\n\n opts.on('-WSSH_PASSWORD', '--ssh-password=SSH_PASSWORD', 'Specify SSH password') do |ssh_password|\n @options.ssh[:password] = ssh_password\n end\n\n opts.on('-LSSH_LOCAL_PORT', '--ssh-local-port=SSH_LOCAL_PORT', 'Specify local SSH proxy port') do |local_port|\n @options.ssh[:local_port] = local_port.to_i\n end\n\n opts.on('-ECODE', '--eval=CODE', 'evaluate CODE') do |code|\n @options.code = code\n end\n\n opts.on('-S', '--show-sql', 'Show SQL on STDOUT') do\n @options.show_sql = true\n end\n\n opts.on('-wOUTOUT', '--write-sql=OUTPUT', 'Write SQL to OUTPUT file') do |file|\n @options.write_sql = file\n end\n\n opts.on('-AOUTPUT', '--append-sql=OUTPUT', 'Append SQL to OUTPUT file') do |file|\n @options.append_sql = file\n end\n\n opts.on('-V', '--version', 'Prints version') do\n puts \"ARQL \#{Arql::VERSION}\"\n exit\n end\n\n opts.on('', '--help', 'Prints this help') do\n puts opts\n exit\n end\n\n end.parse!\n\n @options.args = ARGV\nend\n"
|