169 Commits

Author SHA1 Message Date
mes5k
ad7f3fdab3 minor formatting 2004-09-26 23:54:16 +00:00
mes5k
5b198cd996 updates 2004-09-26 22:50:20 +00:00
mes5k
f8db10c85d minor fix so that we run all tests 2004-09-26 22:17:31 +00:00
macbishop
863906f918 Removed src subdir 2004-09-26 18:51:46 +00:00
macbishop
9cc253042d Removed libtclap.a deps 2004-09-26 18:49:15 +00:00
macbishop
95bcb93947 Removed creation of src/Makefile 2004-09-26 18:46:18 +00:00
macbishop
af05b0a6ec Removed src subdir 2004-09-26 18:34:10 +00:00
macbishop
4fcee3ee11 Implementation now in header files 2004-09-26 18:31:43 +00:00
macbishop
35aa53232d Moving the implementation of tclap to the header files presented me with two
major problems. 1) There where static functions and variables that could cause
link errors if tclap where used in different files (e.g. file1.cc and file2.cc
included tclap then compiling both files would give hard symbols for some
variables which would produce multiple definition when linking) 2) The
dependencies of tclap was a bit strange (CmdLine depends on Args and Args
depends on CmdLine for instance)

The first problem I solved by removing all static variables putting them in
static member functions (which are weak-symbols). So for instance every where
there previously was something like x = _delimiter there now is x = delimiter()
or in case of write acces delimiterRef() = x instead of _delimiter = x (I had
to append the Ref because there where already functions with the same name as
the variables). To solve the problem with static functions I simply inlined
them. This causes the compiler to produce a weak symbol or inline if
appropriate. We can put the functions inside the class declaration later to
make the code look better. This worked fine in all but two cases. In the
ValueArg and MultiArg classes I had to do a "hack" to work around the
specialization template for extractValue<std::string>. The code for this is
very simple but it might look strange an stupid at first but it is only to
resolve the specialisation to a weak symbol. What I did was I put the
implementations of extractValue in a helper class and I could then create a
specialized class instead of function and everything worked out. I think now in
retrospect there might be better solutions to this but I'll think a bit more on
it (maybe some type of inlining on the specialized version would suffice but
I'm not sure).

To handle the dependencies I had to do some rewriting. The first step was to
introduce a new class CmdLineInterface that is a purely abstract base of
CmdLine that specifies the functions needed by Arg and friends. Thus Arg
classes now takes an CmdLineInterface object as input instead (however only
CmdLine can ever be instantiated of-course). With this extra class cleaning up
the dependencies was quite simple, I've attached a dependency graph to the mail
(depgraph.png). I also cleaned up the #includes so now only what actually needs
inclusion is included. A nice side effect of this is that the impl. of CmdLine
is now put back into CmdLine.h (where I guess you wanted it) which (recursivly)
includes everything else needed.

Just to make things clear for myself regarding the class dependencies I made a
class TCLAP::Exception that inherits from std::exception and is a base of
ArgException (Exception does nothing currently). If we don't want the Exception
class it can be removed, however I think it could be a nice logic to have a
base Exception class that every exception inherits from, but we can discuss
that when we decide how to handle exceptions.
2004-09-26 18:27:47 +00:00
macbishop
660f7e155a Now return 0 if all tests fail and 1 if any test fail 2004-09-26 15:07:06 +00:00
macbishop
61ddf68d75 Runs all tests and sumarizes the result 2004-09-26 14:58:06 +00:00
mes5k
289b1a1396 added some comments 2004-09-21 00:09:50 +00:00
mes5k
5f1a3d79e3 formatting only 2004-09-21 00:08:54 +00:00
macbishop
4362a50705 Recommit because something is strange. The changes are that memory allocated in _construct is deallocated when the CmdLine obj is destroyed 2004-09-20 17:05:15 +00:00
macbishop
6c06e31bb2 Memory allocated in _constructor is now deleted when the object is destroyed 2004-09-19 18:32:13 +00:00
mes5k
6cd0c3db78 changed ifndef labels 2004-09-18 16:54:21 +00:00
macbishop
4ae30a9aa5 Had to make ~Arg() public because it won't be possible to delete Arg*s if it is not, and we want that (I think). 2004-09-18 14:53:47 +00:00
mes5k
c88714bcde version 1.0.0 2004-09-16 04:24:37 +00:00
mes5k
67c8ff84e1 cleaned up a bunch of things 2004-09-16 03:54:08 +00:00
mes5k
6cc1ce8463 added tests for CmdLine arg 2004-09-12 02:35:14 +00:00
mes5k
77592b3a83 added new test for CmdLine arg 2004-09-12 02:33:57 +00:00
mes5k
389a4f87b1 got CmdLine arg working 2004-09-12 02:32:37 +00:00
mes5k
26bcd0b50e shouldn't be in cvs 2004-09-10 02:08:33 +00:00
macbishop
46fdfd07c3 Added support for automatic addition to a CmdLine parser 2004-09-09 19:56:12 +00:00
macbishop
35a072e0b6 Support for automatic addition to a CmdLine parser 2004-09-09 19:55:33 +00:00
mes5k
1064a196d1 fixed a warning in MSVC++ 2004-09-09 03:09:32 +00:00
mes5k
c22fcbad64 not needed 2004-09-07 23:08:21 +00:00
mes5k
4aa7c869ff now throws exception on matching names/flags/desc 2004-09-07 22:14:29 +00:00
mes5k
b7a7649bbf fixed to handle new exception on matching names/flags/desc 2004-09-07 22:12:27 +00:00
mes5k
9ee1f41a44 updated Doxyfile for newer doxygen 2004-09-07 20:25:21 +00:00
mes5k
523af24f81 added more args to better test output printing 2004-09-07 18:25:52 +00:00
mes5k
a01538d7ba changed namespace std handling 2004-09-07 18:24:48 +00:00
mes5k
4e311b2219 fixed test output for new formatting 2004-09-07 18:24:18 +00:00
macbishop
b2c9942f51 Compilation was broken due to undef. symbols in compilers with 2 stage
name-lookup (such as gcc >= 3.4). The fix for this is to tell the
compiler what symbols to use withlines like: using MultiArg<T>::_name;

This is now done and everything compiles fine. Since I'm not sure
about the support for things like using MultiArg<T>::_name; on all
compilers it is ifdef:ed away by default. To get 2 stage name-lookup
to work you have to add -DTWO_STAGE_NAME_LOOKUP to your CXXFLAGS
before running configure.
2004-09-04 21:09:37 +00:00
mes5k
b34918c2fe smartened printing even further 2004-08-18 19:34:28 +00:00
mes5k
65fd6009a2 fixed int messiness 2004-08-11 03:35:53 +00:00
mes5k
ee1ca9b844 made path explicit 2004-08-11 03:32:14 +00:00
mes5k
867b526950 changed allowed separator 2004-08-11 03:05:04 +00:00
mes5k
dc0aa2daf3 changed error output and added usage stuff 2004-08-11 02:53:50 +00:00
mes5k
847ea3a4fc updated 2004-08-11 02:52:07 +00:00
mes5k
a4a58320b0 changed to 0.9.9 2004-08-11 02:47:05 +00:00
mes5k
5ae5f57bbb tweaked for usage 2004-08-11 02:46:12 +00:00
mes5k
e1d1339530 added usage stuff 2004-08-11 02:45:27 +00:00
mes5k
f951dccd84 tweaked usage 2004-08-11 02:43:33 +00:00
mes5k
8be8e45e44 updated for allowed 2004-07-06 02:02:17 +00:00
mes5k
93ced7abe3 allow tests 2004-07-04 03:01:48 +00:00
mes5k
8895edd174 doh 2004-07-04 02:56:41 +00:00
mes5k
3629a21123 allow 2004-07-04 02:34:28 +00:00
mes5k
fc56674402 made isReq virtual 2004-07-04 02:31:35 +00:00
mes5k
45ecbd896c added allow 2004-07-04 02:30:52 +00:00