From bada6666c70977a058755ccf232e7d67b24adeed Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rg=20Frings-F=C3=BCrst?= Date: Wed, 23 Jul 2014 15:21:29 +0200 Subject: New upstream release --- libcult/cult/cli/arguments.cxx | 22 -- libcult/cult/cli/arguments.hxx | 85 ----- libcult/cult/cli/arguments.ixx | 21 -- libcult/cult/cli/exceptions.hxx | 136 ------- libcult/cult/cli/file-arguments.cxx | 118 ------ libcult/cult/cli/file-arguments.hxx | 59 --- libcult/cult/cli/mapper.hxx.m4 | 65 ---- libcult/cult/cli/options-parser.cxx | 40 -- libcult/cult/cli/options-parser.hxx | 570 ---------------------------- libcult/cult/cli/options-parser.ixx | 12 - libcult/cult/cli/options-parser.txx | 34 -- libcult/cult/cli/options-spec.cxx | 14 - libcult/cult/cli/options-spec.hxx | 723 ------------------------------------ libcult/cult/cli/options-spec.ixx | 12 - libcult/cult/cli/options-spec.txx | 320 ---------------- libcult/cult/cli/options.cxx | 17 - libcult/cult/cli/options.hxx | 502 ------------------------- libcult/cult/cli/options.ixx | 12 - libcult/cult/cli/options.txx | 320 ---------------- libcult/cult/cli/scanner.cxx | 17 - libcult/cult/cli/scanner.hxx | 132 ------- libcult/cult/cli/scanner.ixx | 12 - 22 files changed, 3243 deletions(-) delete mode 100644 libcult/cult/cli/arguments.cxx delete mode 100644 libcult/cult/cli/arguments.hxx delete mode 100644 libcult/cult/cli/arguments.ixx delete mode 100644 libcult/cult/cli/exceptions.hxx delete mode 100644 libcult/cult/cli/file-arguments.cxx delete mode 100644 libcult/cult/cli/file-arguments.hxx delete mode 100644 libcult/cult/cli/mapper.hxx.m4 delete mode 100644 libcult/cult/cli/options-parser.cxx delete mode 100644 libcult/cult/cli/options-parser.hxx delete mode 100644 libcult/cult/cli/options-parser.ixx delete mode 100644 libcult/cult/cli/options-parser.txx delete mode 100644 libcult/cult/cli/options-spec.cxx delete mode 100644 libcult/cult/cli/options-spec.hxx delete mode 100644 libcult/cult/cli/options-spec.ixx delete mode 100644 libcult/cult/cli/options-spec.txx delete mode 100644 libcult/cult/cli/options.cxx delete mode 100644 libcult/cult/cli/options.hxx delete mode 100644 libcult/cult/cli/options.ixx delete mode 100644 libcult/cult/cli/options.txx delete mode 100644 libcult/cult/cli/scanner.cxx delete mode 100644 libcult/cult/cli/scanner.hxx delete mode 100644 libcult/cult/cli/scanner.ixx (limited to 'libcult/cult/cli') diff --git a/libcult/cult/cli/arguments.cxx b/libcult/cult/cli/arguments.cxx deleted file mode 100644 index 28805d0..0000000 --- a/libcult/cult/cli/arguments.cxx +++ /dev/null @@ -1,22 +0,0 @@ -// file : cult/cli/arguments.cxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include - -namespace Cult -{ - namespace CLI - { - Arguments:: - ~Arguments () - { - } - - BasicArguments:: - ~BasicArguments () - { - } - } -} diff --git a/libcult/cult/cli/arguments.hxx b/libcult/cult/cli/arguments.hxx deleted file mode 100644 index 5381172..0000000 --- a/libcult/cult/cli/arguments.hxx +++ /dev/null @@ -1,85 +0,0 @@ -// file : cult/cli/arguments.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_ARGUMENTS_HXX -#define CULT_CLI_ARGUMENTS_HXX - -#include - -#include - -namespace Cult -{ - namespace CLI - { - class Arguments: public NonCopyable - { - public: - virtual - ~Arguments (); - - public: - class Bounds: public virtual Exception {}; - - virtual Size - size () const = 0; - - virtual Char const* - operator[] (Index) const = 0; - - virtual Void - erase (Index) = 0; - }; - - class BasicArguments: public Arguments - { - public: - virtual - ~BasicArguments (); - - BasicArguments (Int& argc, Char** argv); - - public: - virtual Size - size () const - { - return static_cast (argc_); - } - - virtual Char const* - operator[] (Index i) const - { - if (i >= size ()) - throw Bounds (); - - return argv_[i]; - } - - virtual Void - erase (Index i) - { - if (i >= size ()) - throw Bounds (); - - for (++i; i < size (); ++i) - { - argv_[i - 1] = argv_[i]; - } - - --argc_; - - argv_[argc_] = 0; - } - - private: - Int& argc_; - Char** argv_; - }; - } -} - -#include - -#endif // CULT_CLI_ARGUMENTS_HXX diff --git a/libcult/cult/cli/arguments.ixx b/libcult/cult/cli/arguments.ixx deleted file mode 100644 index b05295d..0000000 --- a/libcult/cult/cli/arguments.ixx +++ /dev/null @@ -1,21 +0,0 @@ -// file : cult/cli/arguments.ixx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include - -namespace Cult -{ - namespace CLI - { - inline - BasicArguments:: - BasicArguments (Int& argc, Char** argv) - : argc_ (argc), argv_ (argv) - { - assert (argc > 0); - } - } -} - diff --git a/libcult/cult/cli/exceptions.hxx b/libcult/cult/cli/exceptions.hxx deleted file mode 100644 index 886e008..0000000 --- a/libcult/cult/cli/exceptions.hxx +++ /dev/null @@ -1,136 +0,0 @@ -// file : cult/cli/exceptions.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_EXCEPTIONS_HXX -#define CULT_CLI_EXCEPTIONS_HXX - -#include - -#include - -namespace Cult -{ - namespace CLI - { - // - // - class Exception: public virtual EH::Exception - { - }; - - // Exception for FileArguments class. - // - class OptionFile: public virtual Exception - { - public: - ~OptionFile () throw () - { - } - - OptionFile (String const& description) - : description_ (description) - { - } - - OptionFile (String const& value, - String const& description) - : value_ (value), description_ (description) - { - } - - String const& - value () const - { - return value_; - } - - String const& - description () const - { - return description_; - } - - private: - String value_; - String description_; - }; - - // - // - class UnexpectedOption: public virtual Exception - { - public: - ~UnexpectedOption () throw () - { - } - - UnexpectedOption (String const& option) - : option_ (option) - { - } - - String const& - option () const - { - return option_; - } - - private: - String option_; - }; - - - // - // - class UnexpectedArgument: public virtual Exception - { - public: - ~UnexpectedArgument () throw () - { - } - - UnexpectedArgument (String const& argument) - : argument_ (argument) - { - } - - String const& - argument () const - { - return argument_; - } - - private: - String argument_; - }; - - - // - // - class OptionFormat: public virtual Exception - { - public: - ~OptionFormat () throw () - { - } - - OptionFormat (String const& option) - : option_ (option) - { - } - - String const& - option () const - { - return option_; - } - - private: - String option_; - }; - } -} - -#endif // CULT_CLI_EXCEPTIONS_HXX diff --git a/libcult/cult/cli/file-arguments.cxx b/libcult/cult/cli/file-arguments.cxx deleted file mode 100644 index 4f082dc..0000000 --- a/libcult/cult/cli/file-arguments.cxx +++ /dev/null @@ -1,118 +0,0 @@ -// file : cult/cli/file-arguments.cxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include // strcmp -#include - -#include - -namespace Cult -{ - namespace CLI - { - FileArguments:: - ~FileArguments () - { - } - - FileArguments:: - FileArguments (Int argc, Char const* const* argv, Char const* op) - { - using namespace std; - - if (argc == 0) - return; - - args_.push_back (argv[0]); - - Boolean skip (false); - - for (Int i (1); i < argc; ++i) - { - if (!skip) - { - if (strcmp (argv[i], "--") == 0) - { - skip = true; - } - else if (strcmp (argv[i], op) == 0) - { - ++i; - - if (i >= argc) - throw OptionFile ("missing file name"); - - ifstream is (argv[i]); - - if (!is.is_open ()) - throw OptionFile (argv[i], "unable to open in read mode"); - - while (!is.eof ()) - { - String line; - getline (is, line); - - if (is.fail () && !is.eof ()) - throw OptionFile (argv[i], "read failure"); - - Size size (line.size ()); - - // Trim the line from leading and trailing whitespaces. - // - if (size != 0) - { - const Char* f (line.data ()); - const Char* l (f + size); - - const Char* of (f); - while (f < l && (*f == ' ' || *f == '\t' || *f == '\r')) - ++f; - - --l; - - const Char* ol (l); - while (l > f && (*l == ' ' || *l == '\t' || *l == '\r')) - --l; - - if (f != of || l != ol) - line = f <= l ? String (f, l - f + 1) : String (); - } - - if (line.empty () || line[0] == '#') - continue; // Ignore empty lines, those that start with # - - Size pos (line.find (' ')); - - if (pos == String::npos) - args_.push_back (line); - else - { - Size size (line.size ()); - - args_.push_back (String (line, 0, pos)); - - // Skip leading whitespaces in the argument. - // - for (pos++; pos < size; pos++) - { - Char c (line[pos]); - - if (c != ' ' && c != '\t' && c != '\r') - break; - } - - args_.push_back (String (line, pos)); - } - } - - continue; - } - } - - args_.push_back (argv[i]); - } - } - } -} diff --git a/libcult/cult/cli/file-arguments.hxx b/libcult/cult/cli/file-arguments.hxx deleted file mode 100644 index e14f53c..0000000 --- a/libcult/cult/cli/file-arguments.hxx +++ /dev/null @@ -1,59 +0,0 @@ -// file : cult/cli/file-arguments.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_FILE_ARGUMENTS_HXX -#define CULT_CLI_FILE_ARGUMENTS_HXX - -#include -#include - -#include -#include - -namespace Cult -{ - namespace CLI - { - class FileArguments: public Arguments - { - public: - virtual - ~FileArguments (); - - FileArguments (Int argc, - Char const* const* argv, - Char const* file_option); - public: - virtual Size - size () const - { - return args_.size (); - } - - virtual Char const* - operator[] (Index i) const - { - if (i >= size ()) - throw Bounds (); - - return args_[i].c_str (); - } - - virtual Void - erase (Index i) - { - if (i >= size ()) - throw Bounds (); - - args_.erase (args_.begin () + i); - } - - private: - Containers::Vector args_; - }; - } -} - -#endif // CULT_CLI_FILE_ARGUMENTS_HXX diff --git a/libcult/cult/cli/mapper.hxx.m4 b/libcult/cult/cli/mapper.hxx.m4 deleted file mode 100644 index 7ac6760..0000000 --- a/libcult/cult/cli/mapper.hxx.m4 +++ /dev/null @@ -1,65 +0,0 @@ -divert(-1) - -# file : cult/cli/mapper.hxx.m4 -# author : Boris Kolpackov -# copyright : Copyright (c) 2005-2010 Boris Kolpackov -# license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -define(`N', 100) - -define(`forloop', - `pushdef(`$1', `$2')_forloop(`$1', `$2', `$3', `$4')popdef(`$1')') - -define(`_forloop', - `$4`'ifelse($1, `$3', , - `define(`$1', incr($1))_forloop(`$1', `$2', `$3', `$4')')') - -define(`specialization',` -template -< -forloop(`i', 1, $1, ` char const* x`'i, typename Y`'i`'ifelse(i, $1, ,`,') -')dnl -> -struct Mapper -< -forloop(`i', 1, $1, ` x`'i, Y`'i, -')dnl -forloop(`i', $1, N, ` null, Null`'ifelse(i, N, ,`,') -')dnl -> -{ -`#ifdef __GNUC__' -forloop(`i', 1, $1, ` static Y`'i f (Tag*); -')dnl - - template - struct Selector - { - typedef typeof (Mapper::f ((Tag*) (0))) Type; - }; -`#else' - template - struct Selector - { - typedef typename if_::r, Y1,ifelse($1, 1, ` Void', ` - typename Mapper - < -forloop(`i', 2, $1, ` x`'i, Y`'i`'ifelse(i, $1, ,`,') -') >::template Selector::Type')>::Type Type; - }; -`#endif' -}; -') - -divert(0)dnl - -template -< -forloop(`i', 1, incr(N), - ` char const* x`'i`'ifelse(i, 1, ,`= null'), dnl -typename Y`'i`'ifelse(i, 1, ,`= Null')`'ifelse(i, incr(N), ,`,') -')dnl -> -struct Mapper; - -forloop(`n', 1, N, `specialization(n)') diff --git a/libcult/cult/cli/options-parser.cxx b/libcult/cult/cli/options-parser.cxx deleted file mode 100644 index 4a2b6b3..0000000 --- a/libcult/cult/cli/options-parser.cxx +++ /dev/null @@ -1,40 +0,0 @@ -// file : cult/cli/options-parser.cxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include - -namespace Cult -{ - namespace CLI - { - Trace::Stream OptionsParserBase::tout ("Cult::CLI::OptionsParser", 7); - - - // OptionParserBooleanBase - // - Boolean OptionParserBooleanBase:: - parse (Char const*, Scanner&) - { - return true; - } - - // OptionParserStringBase - // - String OptionParserStringBase:: - parse (Char const* o, Scanner& s) - { - Char const* v (s.next ()); - - if (v == Scanner::eos) - { - //@@ "expected string literal after --option"? - // - throw OptionFormat (o); - } - - return v; - } - } -} diff --git a/libcult/cult/cli/options-parser.hxx b/libcult/cult/cli/options-parser.hxx deleted file mode 100644 index 4068fa6..0000000 --- a/libcult/cult/cli/options-parser.hxx +++ /dev/null @@ -1,570 +0,0 @@ -// file : cult/cli/options-parser.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_OPTIONS_PARSER_HXX -#define CULT_CLI_OPTIONS_PARSER_HXX - -#include - -#include -#include - -#include - -#include -#include -#include - -#include - -//@! which types should be NonCopyable - -namespace Cult -{ - namespace CLI - { - struct UnknownMode - { - enum Value - { - skip, - stop, - fail - }; - }; - - template - struct OptionParserBase - { - T - parse (Char const* o, Scanner& s); - }; - - template - struct OptionParser: OptionParserBase - { - OptionParser (Spec const&) - { - } - }; - - template - class OptionParser > > - { - public: - OptionParser (OptionSpec > const&) - : impl_ (OptionSpec ()) - { - } - - T - parse (Char const* k, Scanner& s) - { - return impl_.parse (k, s); - } - - private: - OptionParser > impl_; - }; - - struct OptionParserBooleanBase - { - Boolean - parse (Char const*, Scanner& s); - }; - - template - struct OptionParser >: OptionParserBooleanBase - { - OptionParser (OptionSpec const&) - { - } - }; - - struct OptionParserStringBase - { - String - parse (Char const*, Scanner& s); - }; - - template - struct OptionParser >: OptionParserStringBase - { - OptionParser (OptionSpec const&) - { - } - }; - - // - // - // - - class OptionsParserBase - { - protected: - struct GlueBase - { - // I am using Void* here to (significantly) reduce the length - // on the object file symbols. - // - virtual Void - operator() (Char const*, Scanner&, Void* options) = 0; - }; - - static Trace::Stream tout; - }; - - template - class OptionsParser : OptionsParserBase - { - typedef - Containers::Map > - Map; - - template - struct Glue; - - template - struct Glue > : GlueBase - { - Glue (OptionSpec const& spec) - : parser_ (spec) - { - } - - virtual Void - operator() (Char const* o, Scanner& scan, Void* options) - { - typedef typename Spec::Options Options; - - Options& ops (*reinterpret_cast (options)); - - ops.template value () = parser_.parse (o, scan); - } - - private: - OptionParser > parser_; - }; - - //@@ It's bad that I also have to specialize Glue. Need to redesign - // this. - // - template - struct Glue > > : GlueBase - { - Glue (OptionSpec > const& spec) - : parser_ (spec) - { - } - - virtual Void - operator() (Char const* o, Scanner& scan, Void* options) - { - typedef typename Spec::Options Options; - - Options& ops (*reinterpret_cast (options)); - - ops.template value ().push_back (parser_.parse (o, scan)); - } - - private: - OptionParser > > parser_; - }; - - - // Option-specific specializations of some functions. - // - template - struct S_ - { - // This is a "specialization" for when type is Bits::Null. - // - static Void - add_parser (Spec const&, Map&) - { - } - - static Void - set_default (typename Spec::Options&, Spec const&) - { - } - }; - - template - struct S_ > - { - static Void - add_parser (Spec const& spec, Map& map) - { - if (k[0] != '\0') - { - OptionSpec const& os (spec.template option ()); - map[os.name ()] = new Glue > (os); - } - } - - static Void - set_default (typename Spec::Options& o, Spec const& s) - { - o.template value () = s.template option ().default_value (); - } - }; - - public: - - OptionsParser (Spec const& spec) - : spec_ (spec) - { - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - S_::add_parser (spec_, map_); - } - - - typename Spec::Options - parse (Scanner& scan, - UnknownMode::Value option_mode = UnknownMode::fail, - UnknownMode::Value argument_mode = UnknownMode::stop) - { - typename Spec::Options ops; - - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - S_::set_default (ops, spec_); - - for (Char const* s (scan.peek ()); s != Scanner::eos; s = scan.peek ()) - { - tout << "looking at \"" << s << "\""; - - //@@ Std:: - // - if (strcmp (s, "--") == 0) - { - // We don't want to remove '--' if our option mode is skip. - // - if (option_mode == UnknownMode::skip) - scan.skip (); - else - scan.next (); - - break; - } - - typename Map::ConstIterator it (map_.find (s)); - - if (it != map_.end ()) - { - tout << "found parser for \"" << s << "\""; - - s = scan.next (); - (*(it->second)) (s, scan, &ops); - } - else if (s[0] == '-') - { - // Unknown option. - // - switch (option_mode) - { - case UnknownMode::skip: - { - scan.skip (); - continue; - } - case UnknownMode::stop: - { - break; - } - case UnknownMode::fail: - { - throw UnexpectedOption (s); - } - } - - break; // stop case - } - else - { - // Something else. - // - switch (argument_mode) - { - case UnknownMode::skip: - { - scan.skip (); - continue; - } - case UnknownMode::stop: - { - break; - } - case UnknownMode::fail: - { - throw UnexpectedArgument (s); - } - } - - break; // stop case - } - } - - return ops; - } - - private: - Map map_; - Spec spec_; - }; - - // - // - // - - template - typename Spec::Options - parse (Spec const& s, - Arguments& args, - UnknownMode::Value option_mode = UnknownMode::fail, - UnknownMode::Value argument_mode = UnknownMode::stop) - { - Scanner scan (args, Scanner::Action::erase); - OptionsParser parser (s); - - return parser.parse (scan, option_mode, argument_mode); - } - - template - Options - parse (Arguments& args, - UnknownMode::Value option_mode = UnknownMode::fail, - UnknownMode::Value argument_mode = UnknownMode::stop) - { - OptionsSpec spec; - return parse (spec, args, option_mode, argument_mode); - } - - template - typename Spec::Options - parse (Spec const& s, - Int& argc, - Char** argv, - UnknownMode::Value option_mode = UnknownMode::fail, - UnknownMode::Value argument_mode = UnknownMode::stop) - { - BasicArguments args (argc, argv); - return parse (s, args, option_mode, argument_mode); - } - - template - Options - parse (Int& argc, - Char** argv, - UnknownMode::Value option_mode = UnknownMode::fail, - UnknownMode::Value argument_mode = UnknownMode::stop) - { - OptionsSpec spec; - - return parse (spec, argc, argv, option_mode, argument_mode); - } - } -} - -#include -#include - -#endif // CULT_CLI_OPTIONS_PARSER_HXX diff --git a/libcult/cult/cli/options-parser.ixx b/libcult/cult/cli/options-parser.ixx deleted file mode 100644 index 80427f2..0000000 --- a/libcult/cult/cli/options-parser.ixx +++ /dev/null @@ -1,12 +0,0 @@ -// file : cult/cli/options-parser.ixx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - } -} - diff --git a/libcult/cult/cli/options-parser.txx b/libcult/cult/cli/options-parser.txx deleted file mode 100644 index bd8172a..0000000 --- a/libcult/cult/cli/options-parser.txx +++ /dev/null @@ -1,34 +0,0 @@ -// file : cult/cli/options-parser.txx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - // OptionParserBase - // - template - T OptionParserBase:: - parse (Char const* o, Scanner& s) - { - Char const* v (s.next ()); - - //@@ "expected something after --option"? - // - if (v == Scanner::eos) - throw OptionFormat (o); - - T r; - std::istringstream is (v); - is >> r; - - if (is.fail () || !is.eof ()) - throw OptionFormat (o); - - return r; - } - } -} - diff --git a/libcult/cult/cli/options-spec.cxx b/libcult/cult/cli/options-spec.cxx deleted file mode 100644 index 9f1e43b..0000000 --- a/libcult/cult/cli/options-spec.cxx +++ /dev/null @@ -1,14 +0,0 @@ -// file : cult/cli/options-spec.cxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include - -namespace Cult -{ - namespace CLI - { - } -} - diff --git a/libcult/cult/cli/options-spec.hxx b/libcult/cult/cli/options-spec.hxx deleted file mode 100644 index aff4541..0000000 --- a/libcult/cult/cli/options-spec.hxx +++ /dev/null @@ -1,723 +0,0 @@ -// file : cult/cli/options-spec.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_OPTIONS_SPEC_HXX -#define CULT_CLI_OPTIONS_SPEC_HXX - -#include - -#include - -namespace Cult -{ - namespace CLI - { - template - class OptionSpec - { - public: - static Char const* const key; - typedef T Type; - - public: - ~OptionSpec () - { - } - - OptionSpec () - : default_value_ (), - name_ ("--") - { - name_ += k; - } - - T const& - default_value () const - { - return default_value_; - } - - Void - default_value (T const& value) - { - default_value_ = value; - } - - //@@ bad name - // - Char const* - name () const - { - return name_.c_str (); - } - - private: - T default_value_; - String name_; - }; - - template - struct OptionSpecType - { - typedef OptionSpec Type; - }; - - template <> - struct OptionSpecType - { - typedef Bits::Null Type; - }; - - - template - Char const* const OptionSpec::key = k; - - template - class OptionsSpec; - - template - - class OptionsSpec > - { - public: - typedef CLI::Options Options; - - typedef typename OptionSpecType::Type o01; - typedef typename OptionSpecType::Type o02; - typedef typename OptionSpecType::Type o03; - typedef typename OptionSpecType::Type o04; - typedef typename OptionSpecType::Type o05; - typedef typename OptionSpecType::Type o06; - typedef typename OptionSpecType::Type o07; - typedef typename OptionSpecType::Type o08; - typedef typename OptionSpecType::Type o09; - typedef typename OptionSpecType::Type o10; - typedef typename OptionSpecType::Type o11; - typedef typename OptionSpecType::Type o12; - typedef typename OptionSpecType::Type o13; - typedef typename OptionSpecType::Type o14; - typedef typename OptionSpecType::Type o15; - typedef typename OptionSpecType::Type o16; - typedef typename OptionSpecType::Type o17; - typedef typename OptionSpecType::Type o18; - typedef typename OptionSpecType::Type o19; - typedef typename OptionSpecType::Type o20; - typedef typename OptionSpecType::Type o21; - typedef typename OptionSpecType::Type o22; - typedef typename OptionSpecType::Type o23; - typedef typename OptionSpecType::Type o24; - typedef typename OptionSpecType::Type o25; - typedef typename OptionSpecType::Type o26; - typedef typename OptionSpecType::Type o27; - typedef typename OptionSpecType::Type o28; - typedef typename OptionSpecType::Type o29; - typedef typename OptionSpecType::Type o30; - typedef typename OptionSpecType::Type o31; - typedef typename OptionSpecType::Type o32; - typedef typename OptionSpecType::Type o33; - typedef typename OptionSpecType::Type o34; - typedef typename OptionSpecType::Type o35; - typedef typename OptionSpecType::Type o36; - typedef typename OptionSpecType::Type o37; - typedef typename OptionSpecType::Type o38; - typedef typename OptionSpecType::Type o39; - typedef typename OptionSpecType::Type o40; - typedef typename OptionSpecType::Type o41; - typedef typename OptionSpecType::Type o42; - typedef typename OptionSpecType::Type o43; - typedef typename OptionSpecType::Type o44; - typedef typename OptionSpecType::Type o45; - typedef typename OptionSpecType::Type o46; - typedef typename OptionSpecType::Type o47; - typedef typename OptionSpecType::Type o48; - typedef typename OptionSpecType::Type o49; - typedef typename OptionSpecType::Type o50; - typedef typename OptionSpecType::Type o51; - typedef typename OptionSpecType::Type o52; - typedef typename OptionSpecType::Type o53; - typedef typename OptionSpecType::Type o54; - typedef typename OptionSpecType::Type o55; - typedef typename OptionSpecType::Type o56; - typedef typename OptionSpecType::Type o57; - typedef typename OptionSpecType::Type o58; - typedef typename OptionSpecType::Type o59; - typedef typename OptionSpecType::Type o60; - typedef typename OptionSpecType::Type o61; - typedef typename OptionSpecType::Type o62; - typedef typename OptionSpecType::Type o63; - typedef typename OptionSpecType::Type o64; - typedef typename OptionSpecType::Type o65; - typedef typename OptionSpecType::Type o66; - typedef typename OptionSpecType::Type o67; - typedef typename OptionSpecType::Type o68; - typedef typename OptionSpecType::Type o69; - typedef typename OptionSpecType::Type o70; - typedef typename OptionSpecType::Type o71; - typedef typename OptionSpecType::Type o72; - typedef typename OptionSpecType::Type o73; - typedef typename OptionSpecType::Type o74; - typedef typename OptionSpecType::Type o75; - typedef typename OptionSpecType::Type o76; - typedef typename OptionSpecType::Type o77; - typedef typename OptionSpecType::Type o78; - typedef typename OptionSpecType::Type o79; - typedef typename OptionSpecType::Type o80; - typedef typename OptionSpecType::Type o81; - typedef typename OptionSpecType::Type o82; - typedef typename OptionSpecType::Type o83; - typedef typename OptionSpecType::Type o84; - typedef typename OptionSpecType::Type o85; - typedef typename OptionSpecType::Type o86; - typedef typename OptionSpecType::Type o87; - typedef typename OptionSpecType::Type o88; - typedef typename OptionSpecType::Type o89; - typedef typename OptionSpecType::Type o90; - typedef typename OptionSpecType::Type o91; - typedef typename OptionSpecType::Type o92; - typedef typename OptionSpecType::Type o93; - typedef typename OptionSpecType::Type o94; - typedef typename OptionSpecType::Type o95; - typedef typename OptionSpecType::Type o96; - typedef typename OptionSpecType::Type o97; - typedef typename OptionSpecType::Type o98; - typedef typename OptionSpecType::Type o99; - typedef typename OptionSpecType::Type o100; - - - private: - typedef Bits::Mapper Mapper; - - public: - template - typename Mapper::template Selector::Type& - option () - { - typedef - typename Mapper::template Selector::Type - Type; - - return *reinterpret_cast (option (k)); - } - - template - typename Mapper::template Selector::Type const& - option () const - { - typedef - typename Mapper::template Selector::Type - Type; - - return *reinterpret_cast (option (k)); - } - - private: - Void* - option (Char const*) const; - - private: - o01 o01_; - o02 o02_; - o03 o03_; - o04 o04_; - o05 o05_; - o06 o06_; - o07 o07_; - o08 o08_; - o09 o09_; - o10 o10_; - o11 o11_; - o12 o12_; - o13 o13_; - o14 o14_; - o15 o15_; - o16 o16_; - o17 o17_; - o18 o18_; - o19 o19_; - o20 o20_; - o21 o21_; - o22 o22_; - o23 o23_; - o24 o24_; - o25 o25_; - o26 o26_; - o27 o27_; - o28 o28_; - o29 o29_; - o30 o30_; - o31 o31_; - o32 o32_; - o33 o33_; - o34 o34_; - o35 o35_; - o36 o36_; - o37 o37_; - o38 o38_; - o39 o39_; - o40 o40_; - o41 o41_; - o42 o42_; - o43 o43_; - o44 o44_; - o45 o45_; - o46 o46_; - o47 o47_; - o48 o48_; - o49 o49_; - o50 o50_; - o51 o51_; - o52 o52_; - o53 o53_; - o54 o54_; - o55 o55_; - o56 o56_; - o57 o57_; - o58 o58_; - o59 o59_; - o60 o60_; - o61 o61_; - o62 o62_; - o63 o63_; - o64 o64_; - o65 o65_; - o66 o66_; - o67 o67_; - o68 o68_; - o69 o69_; - o70 o70_; - o71 o71_; - o72 o72_; - o73 o73_; - o74 o74_; - o75 o75_; - o76 o76_; - o77 o77_; - o78 o78_; - o79 o79_; - o80 o80_; - o81 o81_; - o82 o82_; - o83 o83_; - o84 o84_; - o85 o85_; - o86 o86_; - o87 o87_; - o88 o88_; - o89 o89_; - o90 o90_; - o91 o91_; - o92 o92_; - o93 o93_; - o94 o94_; - o95 o95_; - o96 o96_; - o97 o97_; - o98 o98_; - o99 o99_; - o100 o100_; - }; - } -} - -#include -#include - -#endif // CULT_CLI_OPTIONS_SPEC_HXX diff --git a/libcult/cult/cli/options-spec.ixx b/libcult/cult/cli/options-spec.ixx deleted file mode 100644 index 1c47da1..0000000 --- a/libcult/cult/cli/options-spec.ixx +++ /dev/null @@ -1,12 +0,0 @@ -// file : cult/cli/options-spec.ixx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - } -} - diff --git a/libcult/cult/cli/options-spec.txx b/libcult/cult/cli/options-spec.txx deleted file mode 100644 index f5d59a0..0000000 --- a/libcult/cult/cli/options-spec.txx +++ /dev/null @@ -1,320 +0,0 @@ -// file : cult/cli/options-spec.txx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - template - Void* - OptionsSpec >:: - option (Char const* k) const - { - Void* r (0); - - if (k == k01) r = (Void*) (&o01_); else - if (k == k02) r = (Void*) (&o02_); else - if (k == k03) r = (Void*) (&o03_); else - if (k == k04) r = (Void*) (&o04_); else - if (k == k05) r = (Void*) (&o05_); else - if (k == k06) r = (Void*) (&o06_); else - if (k == k07) r = (Void*) (&o07_); else - if (k == k08) r = (Void*) (&o08_); else - if (k == k09) r = (Void*) (&o09_); else - if (k == k10) r = (Void*) (&o10_); else - if (k == k11) r = (Void*) (&o11_); else - if (k == k12) r = (Void*) (&o12_); else - if (k == k13) r = (Void*) (&o13_); else - if (k == k14) r = (Void*) (&o14_); else - if (k == k15) r = (Void*) (&o15_); else - if (k == k16) r = (Void*) (&o16_); else - if (k == k17) r = (Void*) (&o17_); else - if (k == k18) r = (Void*) (&o18_); else - if (k == k19) r = (Void*) (&o19_); else - if (k == k20) r = (Void*) (&o20_); else - if (k == k21) r = (Void*) (&o21_); else - if (k == k22) r = (Void*) (&o22_); else - if (k == k23) r = (Void*) (&o23_); else - if (k == k24) r = (Void*) (&o24_); else - if (k == k25) r = (Void*) (&o25_); else - if (k == k26) r = (Void*) (&o26_); else - if (k == k27) r = (Void*) (&o27_); else - if (k == k28) r = (Void*) (&o28_); else - if (k == k29) r = (Void*) (&o29_); else - if (k == k30) r = (Void*) (&o30_); else - if (k == k31) r = (Void*) (&o31_); else - if (k == k32) r = (Void*) (&o32_); else - if (k == k33) r = (Void*) (&o33_); else - if (k == k34) r = (Void*) (&o34_); else - if (k == k35) r = (Void*) (&o35_); else - if (k == k36) r = (Void*) (&o36_); else - if (k == k37) r = (Void*) (&o37_); else - if (k == k38) r = (Void*) (&o38_); else - if (k == k39) r = (Void*) (&o39_); else - if (k == k40) r = (Void*) (&o40_); else - if (k == k41) r = (Void*) (&o41_); else - if (k == k42) r = (Void*) (&o42_); else - if (k == k43) r = (Void*) (&o43_); else - if (k == k44) r = (Void*) (&o44_); else - if (k == k45) r = (Void*) (&o45_); else - if (k == k46) r = (Void*) (&o46_); else - if (k == k47) r = (Void*) (&o47_); else - if (k == k48) r = (Void*) (&o48_); else - if (k == k49) r = (Void*) (&o49_); else - if (k == k50) r = (Void*) (&o50_); else - if (k == k51) r = (Void*) (&o51_); else - if (k == k52) r = (Void*) (&o52_); else - if (k == k53) r = (Void*) (&o53_); else - if (k == k54) r = (Void*) (&o54_); else - if (k == k55) r = (Void*) (&o55_); else - if (k == k56) r = (Void*) (&o56_); else - if (k == k57) r = (Void*) (&o57_); else - if (k == k58) r = (Void*) (&o58_); else - if (k == k59) r = (Void*) (&o59_); else - if (k == k60) r = (Void*) (&o60_); else - if (k == k61) r = (Void*) (&o61_); else - if (k == k62) r = (Void*) (&o62_); else - if (k == k63) r = (Void*) (&o63_); else - if (k == k64) r = (Void*) (&o64_); else - if (k == k65) r = (Void*) (&o65_); else - if (k == k66) r = (Void*) (&o66_); else - if (k == k67) r = (Void*) (&o67_); else - if (k == k68) r = (Void*) (&o68_); else - if (k == k69) r = (Void*) (&o69_); else - if (k == k70) r = (Void*) (&o70_); else - if (k == k71) r = (Void*) (&o71_); else - if (k == k72) r = (Void*) (&o72_); else - if (k == k73) r = (Void*) (&o73_); else - if (k == k74) r = (Void*) (&o74_); else - if (k == k75) r = (Void*) (&o75_); else - if (k == k76) r = (Void*) (&o76_); else - if (k == k77) r = (Void*) (&o77_); else - if (k == k78) r = (Void*) (&o78_); else - if (k == k79) r = (Void*) (&o79_); else - if (k == k80) r = (Void*) (&o80_); else - if (k == k81) r = (Void*) (&o81_); else - if (k == k82) r = (Void*) (&o82_); else - if (k == k83) r = (Void*) (&o83_); else - if (k == k84) r = (Void*) (&o84_); else - if (k == k85) r = (Void*) (&o85_); else - if (k == k86) r = (Void*) (&o86_); else - if (k == k87) r = (Void*) (&o87_); else - if (k == k88) r = (Void*) (&o88_); else - if (k == k89) r = (Void*) (&o89_); else - if (k == k90) r = (Void*) (&o90_); else - if (k == k91) r = (Void*) (&o91_); else - if (k == k92) r = (Void*) (&o92_); else - if (k == k93) r = (Void*) (&o93_); else - if (k == k94) r = (Void*) (&o94_); else - if (k == k95) r = (Void*) (&o95_); else - if (k == k96) r = (Void*) (&o96_); else - if (k == k97) r = (Void*) (&o97_); else - if (k == k98) r = (Void*) (&o98_); else - if (k == k99) r = (Void*) (&o99_); else - if (k == k100) r = (Void*) (&o100_); else - assert (false); - - return r; - } - } -} diff --git a/libcult/cult/cli/options.cxx b/libcult/cult/cli/options.cxx deleted file mode 100644 index 6b6e996..0000000 --- a/libcult/cult/cli/options.cxx +++ /dev/null @@ -1,17 +0,0 @@ -// file : cult/cli/options.cxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include - -namespace Cult -{ - namespace CLI - { - namespace Bits - { - extern Char const null[] = ""; - } - } -} diff --git a/libcult/cult/cli/options.hxx b/libcult/cult/cli/options.hxx deleted file mode 100644 index 2a780e1..0000000 --- a/libcult/cult/cli/options.hxx +++ /dev/null @@ -1,502 +0,0 @@ -// file : cult/cli/options.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_OPTIONS_HXX -#define CULT_CLI_OPTIONS_HXX - -#include - -#include - -namespace Cult -{ - namespace CLI - { - namespace Bits - { - template - struct if_; - - template - struct if_ - { - typedef X Type; - }; - - template - struct if_ - { - typedef Y Type; - }; - - template - struct same - { - static Boolean const r = false; - }; - - template - struct same - { - static Boolean const r = true; - }; - - template - struct Tag - { - }; - - //@@ should end up in Cult::Meta - // - struct Null {}; - extern Char const null[]; - -#include - - } - - template - class Options - { - typedef Bits::Mapper Mapper; - - public: - Options () - : i01_ (), - i02_ (), - i03_ (), - i04_ (), - i05_ (), - i06_ (), - i07_ (), - i08_ (), - i09_ (), - i10_ (), - i11_ (), - i12_ (), - i13_ (), - i14_ (), - i15_ (), - i16_ (), - i17_ (), - i18_ (), - i19_ (), - i20_ (), - i21_ (), - i22_ (), - i23_ (), - i24_ (), - i25_ (), - i26_ (), - i27_ (), - i28_ (), - i29_ (), - i30_ (), - i31_ (), - i32_ (), - i33_ (), - i34_ (), - i35_ (), - i36_ (), - i37_ (), - i38_ (), - i39_ (), - i40_ (), - i41_ (), - i42_ (), - i43_ (), - i44_ (), - i45_ (), - i46_ (), - i47_ (), - i48_ (), - i49_ (), - i50_ (), - i51_ (), - i52_ (), - i53_ (), - i54_ (), - i55_ (), - i56_ (), - i57_ (), - i58_ (), - i59_ (), - i60_ (), - i61_ (), - i62_ (), - i63_ (), - i64_ (), - i65_ (), - i66_ (), - i67_ (), - i68_ (), - i69_ (), - i70_ (), - i71_ (), - i72_ (), - i73_ (), - i74_ (), - i75_ (), - i76_ (), - i77_ (), - i78_ (), - i79_ (), - i80_ (), - i81_ (), - i82_ (), - i83_ (), - i84_ (), - i85_ (), - i86_ (), - i87_ (), - i88_ (), - i89_ (), - i90_ (), - i91_ (), - i92_ (), - i93_ (), - i94_ (), - i95_ (), - i96_ (), - i97_ (), - i98_ (), - i99_ (), - i100_ () - { - } - - template - typename Mapper::template Selector::Type& - value () - { - typedef - typename Mapper::template Selector::Type - Type; - - return *reinterpret_cast (value (k)); - } - - template - typename Mapper::template Selector::Type const& - value () const - { - typedef - typename Mapper::template Selector::Type - Type; - - return *reinterpret_cast (value (k)); - } - - private: - Void* - value (Char const*) const; - - private: - T01 i01_; - T02 i02_; - T03 i03_; - T04 i04_; - T05 i05_; - T06 i06_; - T07 i07_; - T08 i08_; - T09 i09_; - T10 i10_; - T11 i11_; - T12 i12_; - T13 i13_; - T14 i14_; - T15 i15_; - T16 i16_; - T17 i17_; - T18 i18_; - T19 i19_; - T20 i20_; - T21 i21_; - T22 i22_; - T23 i23_; - T24 i24_; - T25 i25_; - T26 i26_; - T27 i27_; - T28 i28_; - T29 i29_; - T30 i30_; - T31 i31_; - T32 i32_; - T33 i33_; - T34 i34_; - T35 i35_; - T36 i36_; - T37 i37_; - T38 i38_; - T39 i39_; - T40 i40_; - T41 i41_; - T42 i42_; - T43 i43_; - T44 i44_; - T45 i45_; - T46 i46_; - T47 i47_; - T48 i48_; - T49 i49_; - T50 i50_; - T51 i51_; - T52 i52_; - T53 i53_; - T54 i54_; - T55 i55_; - T56 i56_; - T57 i57_; - T58 i58_; - T59 i59_; - T60 i60_; - T61 i61_; - T62 i62_; - T63 i63_; - T64 i64_; - T65 i65_; - T66 i66_; - T67 i67_; - T68 i68_; - T69 i69_; - T70 i70_; - T71 i71_; - T72 i72_; - T73 i73_; - T74 i74_; - T75 i75_; - T76 i76_; - T77 i77_; - T78 i78_; - T79 i79_; - T80 i80_; - T81 i81_; - T82 i82_; - T83 i83_; - T84 i84_; - T85 i85_; - T86 i86_; - T87 i87_; - T88 i88_; - T89 i89_; - T90 i90_; - T91 i91_; - T92 i92_; - T93 i93_; - T94 i94_; - T95 i95_; - T96 i96_; - T97 i97_; - T98 i98_; - T99 i99_; - T100 i100_; - }; - } -} - -#include -#include - -#endif // CULT_CLI_OPTIONS_HXX diff --git a/libcult/cult/cli/options.ixx b/libcult/cult/cli/options.ixx deleted file mode 100644 index c25b833..0000000 --- a/libcult/cult/cli/options.ixx +++ /dev/null @@ -1,12 +0,0 @@ -// file : cult/cli/options.ixx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - } -} - diff --git a/libcult/cult/cli/options.txx b/libcult/cult/cli/options.txx deleted file mode 100644 index b26666d..0000000 --- a/libcult/cult/cli/options.txx +++ /dev/null @@ -1,320 +0,0 @@ -// file : cult/cli/options.txx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - template - Void* - Options:: - value (Char const* k) const - { - Void* r (0); - - if (k == k01) r = (Void*) (&i01_); else - if (k == k02) r = (Void*) (&i02_); else - if (k == k03) r = (Void*) (&i03_); else - if (k == k04) r = (Void*) (&i04_); else - if (k == k05) r = (Void*) (&i05_); else - if (k == k06) r = (Void*) (&i06_); else - if (k == k07) r = (Void*) (&i07_); else - if (k == k08) r = (Void*) (&i08_); else - if (k == k09) r = (Void*) (&i09_); else - if (k == k10) r = (Void*) (&i10_); else - if (k == k11) r = (Void*) (&i11_); else - if (k == k12) r = (Void*) (&i12_); else - if (k == k13) r = (Void*) (&i13_); else - if (k == k14) r = (Void*) (&i14_); else - if (k == k15) r = (Void*) (&i15_); else - if (k == k16) r = (Void*) (&i16_); else - if (k == k17) r = (Void*) (&i17_); else - if (k == k18) r = (Void*) (&i18_); else - if (k == k19) r = (Void*) (&i19_); else - if (k == k20) r = (Void*) (&i20_); else - if (k == k21) r = (Void*) (&i21_); else - if (k == k22) r = (Void*) (&i22_); else - if (k == k23) r = (Void*) (&i23_); else - if (k == k24) r = (Void*) (&i24_); else - if (k == k25) r = (Void*) (&i25_); else - if (k == k26) r = (Void*) (&i26_); else - if (k == k27) r = (Void*) (&i27_); else - if (k == k28) r = (Void*) (&i28_); else - if (k == k29) r = (Void*) (&i29_); else - if (k == k30) r = (Void*) (&i30_); else - if (k == k31) r = (Void*) (&i31_); else - if (k == k32) r = (Void*) (&i32_); else - if (k == k33) r = (Void*) (&i33_); else - if (k == k34) r = (Void*) (&i34_); else - if (k == k35) r = (Void*) (&i35_); else - if (k == k36) r = (Void*) (&i36_); else - if (k == k37) r = (Void*) (&i37_); else - if (k == k38) r = (Void*) (&i38_); else - if (k == k39) r = (Void*) (&i39_); else - if (k == k40) r = (Void*) (&i40_); else - if (k == k41) r = (Void*) (&i41_); else - if (k == k42) r = (Void*) (&i42_); else - if (k == k43) r = (Void*) (&i43_); else - if (k == k44) r = (Void*) (&i44_); else - if (k == k45) r = (Void*) (&i45_); else - if (k == k46) r = (Void*) (&i46_); else - if (k == k47) r = (Void*) (&i47_); else - if (k == k48) r = (Void*) (&i48_); else - if (k == k49) r = (Void*) (&i49_); else - if (k == k50) r = (Void*) (&i50_); else - if (k == k51) r = (Void*) (&i51_); else - if (k == k52) r = (Void*) (&i52_); else - if (k == k53) r = (Void*) (&i53_); else - if (k == k54) r = (Void*) (&i54_); else - if (k == k55) r = (Void*) (&i55_); else - if (k == k56) r = (Void*) (&i56_); else - if (k == k57) r = (Void*) (&i57_); else - if (k == k58) r = (Void*) (&i58_); else - if (k == k59) r = (Void*) (&i59_); else - if (k == k60) r = (Void*) (&i60_); else - if (k == k61) r = (Void*) (&i61_); else - if (k == k62) r = (Void*) (&i62_); else - if (k == k63) r = (Void*) (&i63_); else - if (k == k64) r = (Void*) (&i64_); else - if (k == k65) r = (Void*) (&i65_); else - if (k == k66) r = (Void*) (&i66_); else - if (k == k67) r = (Void*) (&i67_); else - if (k == k68) r = (Void*) (&i68_); else - if (k == k69) r = (Void*) (&i69_); else - if (k == k70) r = (Void*) (&i70_); else - if (k == k71) r = (Void*) (&i71_); else - if (k == k72) r = (Void*) (&i72_); else - if (k == k73) r = (Void*) (&i73_); else - if (k == k74) r = (Void*) (&i74_); else - if (k == k75) r = (Void*) (&i75_); else - if (k == k76) r = (Void*) (&i76_); else - if (k == k77) r = (Void*) (&i77_); else - if (k == k78) r = (Void*) (&i78_); else - if (k == k79) r = (Void*) (&i79_); else - if (k == k80) r = (Void*) (&i80_); else - if (k == k81) r = (Void*) (&i81_); else - if (k == k82) r = (Void*) (&i82_); else - if (k == k83) r = (Void*) (&i83_); else - if (k == k84) r = (Void*) (&i84_); else - if (k == k85) r = (Void*) (&i85_); else - if (k == k86) r = (Void*) (&i86_); else - if (k == k87) r = (Void*) (&i87_); else - if (k == k88) r = (Void*) (&i88_); else - if (k == k89) r = (Void*) (&i89_); else - if (k == k90) r = (Void*) (&i90_); else - if (k == k91) r = (Void*) (&i91_); else - if (k == k92) r = (Void*) (&i92_); else - if (k == k93) r = (Void*) (&i93_); else - if (k == k94) r = (Void*) (&i94_); else - if (k == k95) r = (Void*) (&i95_); else - if (k == k96) r = (Void*) (&i96_); else - if (k == k97) r = (Void*) (&i97_); else - if (k == k98) r = (Void*) (&i98_); else - if (k == k99) r = (Void*) (&i99_); else - if (k == k100) r = (Void*) (&i100_); else - assert (false); - - return r; - } - } -} diff --git a/libcult/cult/cli/scanner.cxx b/libcult/cult/cli/scanner.cxx deleted file mode 100644 index af51bfa..0000000 --- a/libcult/cult/cli/scanner.cxx +++ /dev/null @@ -1,17 +0,0 @@ -// file : cult/cli/scanner.cxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#include - -namespace Cult -{ - namespace CLI - { - Scanner::Action const Scanner::Action::keep (Scanner::Action::keep_); - Scanner::Action const Scanner::Action::erase (Scanner::Action::erase_); - - Char const* const Scanner::eos = 0; - } -} diff --git a/libcult/cult/cli/scanner.hxx b/libcult/cult/cli/scanner.hxx deleted file mode 100644 index 13fa804..0000000 --- a/libcult/cult/cli/scanner.hxx +++ /dev/null @@ -1,132 +0,0 @@ -// file : cult/cli/scanner.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -#ifndef CULT_CLI_SCANNER_HXX -#define CULT_CLI_SCANNER_HXX - -#include - -#include -#include - -namespace Cult -{ - namespace CLI - { - class Scanner: public NonCopyable - { - public: - class Action - { - public: - static Action const keep, erase; - - friend Boolean - operator== (Action const& a, Action const& b) - { - return a.v_ == b.v_; - } - - friend Boolean - operator!= (Action const& a, Action const& b) - { - return a.v_ != b.v_; - } - - private: - enum Value { keep_, erase_ } v_; - - Action (Value v) - : v_ (v) - { - } - }; - - public: - Scanner (Arguments& args, Action a = Action::keep, Index start = 1) - : cargs_ (args), - args_ (a == Action::erase ? &args : 0), - next_ (start) - { - } - - Scanner (Arguments const& args, Index start = 1) - : cargs_ (args), args_ (0), next_ (start) - { - } - - public: - static Char const* const eos; - - class PastEOS: public virtual Exception {}; - - Char const* - next () - { - if (next_ > cargs_.size ()) - { - throw PastEOS (); - } - else if (next_ == cargs_.size ()) - { - ++next_; - return eos; - } - else - { - Char const* r (cargs_[next_]); - - if (args_ != 0) - { - hold_ = r; - args_->erase (next_); - return hold_.c_str (); - } - else - { - ++next_; - return r; - } - } - } - - Char const* - peek () - { - if (next_ > cargs_.size ()) - { - throw PastEOS (); - } - else if (next_ == cargs_.size ()) - { - return eos; - } - else - { - return cargs_[next_]; - } - } - - Void - skip () - { - if (next_ > cargs_.size ()) - throw PastEOS (); - else - ++next_; - } - - private: - Arguments const& cargs_; - Arguments* args_; - Index next_; - String hold_; - }; - } -} - -#include - -#endif // CULT_CLI_SCANNER_HXX diff --git a/libcult/cult/cli/scanner.ixx b/libcult/cult/cli/scanner.ixx deleted file mode 100644 index 5e84451..0000000 --- a/libcult/cult/cli/scanner.ixx +++ /dev/null @@ -1,12 +0,0 @@ -// file : cult/cli/scanner.ixx -// author : Boris Kolpackov -// copyright : Copyright (c) 2005-2010 Boris Kolpackov -// license : GNU GPL v2 + exceptions; see accompanying LICENSE file - -namespace Cult -{ - namespace CLI - { - } -} - -- cgit v1.2.3