/* * * SchemaCrawler * http://sourceforge.net/projects/schemacrawler * Copyright (c) 2000-2009, Sualeh Fatehi. * * This library is free software; you can redistribute it and/or modify it under the terms * of the GNU Lesser General Public License as published by the Free Software Foundation; * either version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License along with this * library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, * Boston, MA 02111-1307, USA. * */ package schemacrawler.tools.main; import schemacrawler.schemacrawler.Config; import schemacrawler.schemacrawler.DatabaseConnectionOptions; import schemacrawler.schemacrawler.SchemaCrawlerException; import sf.util.Utility; import sf.util.CommandLineParser.Option; import sf.util.CommandLineParser.StringOption; /** * Options for the command line. * * @author sfatehi */ public final class CommandLineConnectionOptionsParser extends BaseDatabaseConnectionOptionsParser { private final StringOption optionDriver = new StringOption(Option.NO_SHORT_FORM, "driver", null); private final StringOption optionConnectionUrl = new StringOption(Option.NO_SHORT_FORM, "url", null); /** * Parses the command line into options. * * @param args */ public CommandLineConnectionOptionsParser(final String[] args, final Config config) { super(args, config); } @Override public DatabaseConnectionOptions getOptions() throws SchemaCrawlerException { parse(new Option[] { optionDriver, optionConnectionUrl, optionUser, optionPassword, }); final DatabaseConnectionOptions conenctionOptions; if (optionDriver.isFound() && optionConnectionUrl.isFound()) { final String jdbcDriverClassName = optionDriver.getValue(); final String connectionUrl = optionConnectionUrl.getValue(); if (Utility.isBlank(jdbcDriverClassName) || Utility.isBlank(connectionUrl)) { conenctionOptions = null; } else { conenctionOptions = new DatabaseConnectionOptions(jdbcDriverClassName, connectionUrl); conenctionOptions.setUser(optionUser.getValue()); conenctionOptions.setPassword(optionPassword.getValue()); } } else { conenctionOptions = null; } return conenctionOptions; } @Override protected String getHelpResource() { return "/help/Commands.readme.txt"; } }