Remove old testsuite
[dyninst.git] / testsuite / src / ParameterDict.C
1 /*
2  * Copyright (c) 1996-2004 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * This license is for research uses.  For such uses, there is no
12  * charge. We define "research use" to mean you may freely use it
13  * inside your organization for whatever purposes you see fit. But you
14  * may not re-distribute Paradyn or parts of Paradyn, in any form
15  * source or binary (including derivatives), electronic or otherwise,
16  * to any other organization or entity without our permission.
17  * 
18  * (for other uses, please contact us at paradyn@cs.wisc.edu)
19  * 
20  * All warranties, including without limitation, any warranty of
21  * merchantability or fitness for a particular purpose, are hereby
22  * excluded.
23  * 
24  * By your use of Paradyn, you understand and agree that we (or any
25  * other person or entity with proprietary rights in Paradyn) are
26  * under no obligation to provide either maintenance services,
27  * update services, notices of latent defects, or correction of
28  * defects for Paradyn.
29  * 
30  * Even if advised of the possibility of such damages, under no
31  * circumstances shall we (or any other person or entity with
32  * proprietary rights in the software licensed hereunder) be liable
33  * to you or any third party for direct, indirect, or consequential
34  * damages of any character regardless of type of action, including,
35  * without limitation, loss of profits, loss of use, loss of good
36  * will, or computer failure or malfunction.  You agree to indemnify
37  * us (and any other person or entity with proprietary rights in the
38  * software licensed hereunder) for any and all liability it may
39  * incur to third parties resulting from your use of Paradyn.
40  */
41
42 // $Id: ParameterDict.C,v 1.3 2008/10/20 20:35:43 legendre Exp $
43 #include "ParameterDict.h"
44 #include <stdio.h>
45 #include <string.h>
46 #include <stdlib.h>
47
48 // Parameter -
49 Parameter::Parameter()
50 {
51    data1 = 0;
52 }
53 Parameter::~Parameter()
54 {
55 }
56
57 // Error functions, in proper operation these will be overidden in a subclass
58 void Parameter::setString(const char *str)
59 {
60    fprintf(stderr, "Warning: Setting a string for a non-string Parameter, ignored\n");
61 }
62
63 char *Parameter::getString()
64 {
65    fprintf(stderr, "Warning: Getting a string for an non-string Parameter, ignored\n");
66    return NULL;
67 }
68
69 int Parameter::getInt()
70 {
71    fprintf(stderr, "Warning: Getting an int for a non-int Parameter, ignored\n");
72    return -1;
73 }
74
75 void Parameter::setInt(int num)
76 {
77    fprintf(stderr, "Warning: Setting an int for a non-int Parameter, ignored\n");
78 }
79
80 void *Parameter::getPtr()
81 {
82    fprintf(stderr, "Warning: Getting a ptr for a non-ptr Parameter, ignored\n");
83    return NULL;
84 }
85
86 void Parameter::setPtr(void *ptr)
87 {
88    fprintf(stderr, "Warning: Setting an ptr for a non-ptr Parameter, ignored\n");
89 }
90 // End Error Functions
91
92 // String Functions
93 ParamString::ParamString()
94 {
95    data = NULL;
96 }
97
98 ParamString::ParamString(const char *str)
99 {
100    if ( str != NULL )
101    {
102       data = strdup(str);
103    }
104    else
105    {
106       data = NULL;
107    }
108
109 }
110
111 ParamString::~ParamString()
112 {
113    if (data != NULL )
114    {
115       free(data);
116    }
117 }
118
119 void ParamString::setString(const char *str)
120 {
121    // Free old string
122    if ( data != NULL )
123    {
124       free(data);
125    }
126
127    if ( str != NULL )
128    {
129       data = strdup(str);
130    }
131    else
132    {
133       data = NULL;
134    }
135 }
136
137 char* ParamString::getString()
138 {
139    return data;
140 }
141
142 // End String Functions
143 // Integer functions
144 ParamInt::ParamInt(int num)
145 {
146    data = num;
147 }
148
149 int ParamInt::getInt()
150 {
151    return data;
152 }
153
154 void ParamInt::setInt(int num)
155 {
156    data = num;
157 }
158
159 // End Integer functions
160
161 // Pointer functions
162 ParamPtr::ParamPtr()
163 {
164    data = NULL;
165 }
166
167 ParamPtr::ParamPtr(void *ptr)
168 {
169    data = ptr;
170 }
171
172 void *ParamPtr::getPtr()
173 {
174    return data;
175 }
176
177 void ParamPtr::setPtr(void *ptr)
178 {
179    data = ptr;
180 }