summaryrefslogtreecommitdiffstats
path: root/src/tclap/ArgTraits.h
blob: 297f166794984eccc0da869962d40df4fdae7a07 (plain)
1
2
3
4
5
6
7
8
9
10
11
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
/******************************************************************************
 *
 *  file:  ArgTraits.h
 *
 *  Copyright (c) 2007, Daniel Aarno, Michael E. Smoot .
 *  All rights reverved.
 *
 *  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_ARGTRAITS_H
#define TCLAP_ARGTRAITS_H

// This is an internal tclap file, you should probably not have to
// include this directly

namespace TCLAP
{
	// We use two empty structs to get compile type specialization
	// function to work

	/**
	 * A value like argument value type is a value that can be set using
	 * operator>>. This is the default value type.
	 */
	struct ValueLike
	{
		typedef ValueLike ValueCategory;
	};

	/**
	 * A string like argument value type is a value that can be set using
	 * operator=(string). Usefull if the value type contains spaces which
	 * will be broken up into individual tokens by operator>>.
	 */
	struct StringLike
	{
	};

	/**
	 * A class can inherit from this object to make it have string like
	 * traits. This is a compile time thing and does not add any overhead
	 * to the inherenting class.
	 */
	struct StringLikeTrait
	{
		typedef StringLike ValueCategory;
	};

	/**
	 * A class can inherit from this object to make it have value like
	 * traits. This is a compile time thing and does not add any overhead
	 * to the inherenting class.
	 */
	struct ValueLikeTrait
	{
		typedef ValueLike ValueCategory;
	};

	/**
	 * Arg traits are used to get compile type specialization when parsing
	 * argument values. Using an ArgTraits you can specify the way that
	 * values gets assigned to any particular type during parsing. The two
	 * supported types are string like and value like.
	 */
	template<typename T>
	struct ArgTraits
	{
		typedef typename T::ValueCategory ValueCategory;
	};
}

#endif