| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- // -*- Mode: c++; c-basic-offset: 4; tab-width: 4; -*-
- /******************************************************************************
- *
- * file: XorHandler.h
- *
- * Copyright (c) 2003, Michael E. Smoot .
- * Copyright (c) 2004, Michael E. Smoot, Daniel Aarno.
- * All rights reserved.
- *
- * See the file COPYING in the top directory of this distribution for
- * more information.
- *
- * THE SOFTWARE IS PROVIDED _AS IS_, WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
- * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
- * DEALINGS IN THE SOFTWARE.
- *
- *****************************************************************************/
- #ifndef TCLAP_XORHANDLER_H
- #define TCLAP_XORHANDLER_H
- #include <tclap/Arg.h>
- #include <string>
- #include <vector>
- #include <algorithm>
- #include <iostream>
- namespace TCLAP {
- /**
- * This class handles lists of Arg's that are to be XOR'd on the command
- * line. This is used by CmdLine and you shouldn't ever use it.
- */
- class XorHandler
- {
- protected:
- /**
- * The list of of lists of Arg's to be or'd together.
- */
- std::vector< std::vector<Arg*> > _orList;
- public:
- /**
- * Constructor. Does nothing.
- */
- XorHandler( ) : _orList(std::vector< std::vector<Arg*> >()) {}
- /**
- * Add a list of Arg*'s that will be xor'd together.
- * \param ors - list of Arg* that will be xor'd.
- */
- void add( const std::vector<Arg*>& ors );
- /**
- * Checks whether the specified Arg is in one of the xor lists and
- * if it does match one, returns the size of the xor list that the
- * Arg matched. If the Arg matches, then it also sets the rest of
- * the Arg's in the list. You shouldn't use this.
- * \param a - The Arg to be checked.
- */
- int check( const Arg* a );
- /**
- * Returns the XOR specific short usage.
- */
- std::string shortUsage();
- /**
- * Prints the XOR specific long usage.
- * \param os - Stream to print to.
- */
- void printLongUsage(std::ostream& os);
- /**
- * Simply checks whether the Arg is contained in one of the arg
- * lists.
- * \param a - The Arg to be checked.
- */
- bool contains( const Arg* a );
- const std::vector< std::vector<Arg*> >& getXorList() const;
- };
- //////////////////////////////////////////////////////////////////////
- //BEGIN XOR.cpp
- //////////////////////////////////////////////////////////////////////
- inline void XorHandler::add( const std::vector<Arg*>& ors )
- {
- _orList.push_back( ors );
- }
- inline int XorHandler::check( const Arg* a )
- {
- // iterate over each XOR list
- for ( int i = 0; static_cast<unsigned int>(i) < _orList.size(); i++ )
- {
- // if the XOR list contains the arg..
- ArgVectorIterator ait = std::find( _orList[i].begin(),
- _orList[i].end(), a );
- if ( ait != _orList[i].end() )
- {
- // first check to see if a mutually exclusive switch
- // has not already been set
- for ( ArgVectorIterator it = _orList[i].begin();
- it != _orList[i].end();
- it++ )
- if ( a != (*it) && (*it)->isSet() )
- throw(CmdLineParseException(
- "Mutually exclusive argument already set!",
- (*it)->toString()));
- // go through and set each arg that is not a
- for ( ArgVectorIterator it = _orList[i].begin();
- it != _orList[i].end();
- it++ )
- if ( a != (*it) )
- (*it)->xorSet();
- // return the number of required args that have now been set
- if ( (*ait)->allowMore() )
- return 0;
- else
- return static_cast<int>(_orList[i].size());
- }
- }
- if ( a->isRequired() )
- return 1;
- else
- return 0;
- }
- inline bool XorHandler::contains( const Arg* a )
- {
- for ( int i = 0; static_cast<unsigned int>(i) < _orList.size(); i++ )
- for ( ArgVectorIterator it = _orList[i].begin();
- it != _orList[i].end();
- it++ )
- if ( a == (*it) )
- return true;
- return false;
- }
- inline const std::vector< std::vector<Arg*> >& XorHandler::getXorList() const
- {
- return _orList;
- }
- //////////////////////////////////////////////////////////////////////
- //END XOR.cpp
- //////////////////////////////////////////////////////////////////////
- } //namespace TCLAP
- #endif
|