getCyclesPerSecond() support
[dyninst.git] / common / docs / libutil.1
1 .\"
2 .\"
3 .TH LIBUTIL 1L PARADYN "\\n(mo/\\n(dy/19\\n(yr"
4 .SH NAME
5 libutil \- Support Library
6 .SH DESCRIPTION
7 .PP
8 This library provides utility functions.  It provides a list class, a hash table class, and functions to support client-server communications using XDR/pvm/threads.
9 .SH "LIST CLASS SYNOPSIS"
10 .B template <class Type> class List {
11 .br
12 .B      public:
13 .br
14 .B      List();
15 .br
16 .B      int  empty();
17 .br
18 .B      friend ostream &operator<<(ostream&, List<Type>&);
19 .br
20 .B      void print();
21 .br
22 .B      void add(Type data, void *key);
23 .br
24 .B      void add(Type data);
25 .br
26 .B      Boolean addUnique(Type data);
27 .br
28 .B      Boolean addUnique(Type data, void *key);
29 .br
30 .B      Type find(void *key);
31 .br
32 .B      Boolean remove(void *key);
33 .br
34 .B      int count();
35 .br
36 .B      Type operator *();
37 .br
38 .B      void operator +=(List<Type> mergee);
39 .br
40 .B      Type operator ++();
41 .br
42 .B      void map (void (*map_function)(const Type item));
43 .br
44 .B      void setCurrent();
45 .br
46 .B      const Type getCurrent();
47 .br
48 .B      const Type next();
49 .br
50 .B      void advanceCurrent();
51 .br
52 .B      protected:
53 .br
54 .B      ListItem<Type>  *head;
55 .br
56 .B      ListItem<Type>  *current;
57 .br
58 };
59 .br
60 .SH "HASH TABLE CLASS SYNOPSIS"
61 .PP
62 .B template <class Type> class HTable {
63 .br
64 .B    public:
65 .br
66 .B      friend ostream &operator<<(ostream&, HTable<Type>&);
67 .br
68 .B      void print();
69 .br
70 .B      HTable(Type data);
71 .br
72 .B      void add(Type data, void *key);
73 .br
74 .B      HTable(); 
75 .br
76 .B      Boolean addUnique(Type data, void *key);
77 .br
78 .B      Type find(void *key);
79 .br
80 .B      Boolean remove(void *key);
81 .br
82 .B      Type operator =(HTable<Type> arg);
83 .br
84 .B      Type operator *();
85 .br
86 .B      Type operator ++();
87 .br
88 .B      int count();
89 .br
90 .B      private:
91 .br
92 .B      List<Type> **table;
93 .br
94 .B      List<Type> currList;
95 .br
96 .B      int currHid;
97 .br
98 .B      int tableSize;
99 .br
100 };
101 .br
102 .SH "LIBRARY SYNOPSIS"
103 .TP 8
104 .B int RPCprocessCreate (pid, host, User, command,
105 .B       args)
106 .br
107 .B int *pid;
108 .br
109 .B char *host;  
110 .br
111 .B char *User;           
112 .br
113 .B char *command; 
114 .br
115 .B char **args;   
116 .TP 8
117 .B int RPC_readReady (fd)
118 .br
119 .B int fd;
120 .TP 8
121 .B int RPC_setup_socket (socket_fd, family, type)
122 .br
123 .B int *socket_fd;
124 .br
125 .B int family;
126 .br
127 .B int type;
128 .TP 8
129 .B char **RPC_make_arg_list (program, family, type,
130 .B                           port, flag)
131 .br
132 .B char *program;
133 .br
134 .B int family;
135 .br
136 .B int type;
137 .br
138 .B int port;
139 .br
140 .B int flag;
141 .TP 8
142 .B int RPC_undo_arg_list (argc, arg_list, machine,
143 .B                         family, type, socket, flag)
144 .br
145 .B int argc;
146 .br
147 .B char **arg_list;
148 .br
149 .B char **machine;
150 .br
151 .B int *family;
152 .br
153 .B int *type;
154 .br
155 .B int *socket;
156 .br
157 .B int *flag;
158 .TP 8
159 .B int RPC_getConnect (fd)
160 .br
161 .B int fd;
162
163 .SH "LIST CLASS DESCRIPTION"
164 .PP
165 .SH "HASH TABLE DESCRIPTION"
166 .PP
167 .SH "LIBRARY DESCRIPTION"
168 .PP
169 .B int RPCprocessCreate (pid, host, User, command,
170 .B       args)
171 .br
172 .B int *pid;
173 .br
174 .B char *host;  
175 .br
176 .B char *User;           
177 .br
178 .B char *command; 
179 .br
180 .B char **args;   
181 .br
182 stdout will be closed for the exec'd program.  The pid is returned in pid.
183 Host is the name of the host to start the program on.  Command is the name
184 of the command to exec.  If args is non-null, it will be used as an argument 
185 for the exec.  Thus, command should be the first entry in args.  If args is
186 null, command is passed as the argument list.
187 .TP 8
188 .B int RPC_readReady (fd)
189 .br
190 .B int fd;
191 .TP 8
192 .B int RPC_setup_socket (socket_fd, family, type)
193 .br
194 .B int *socket_fd;
195 .br
196 .B int family;
197 .br
198 .B int type;
199 .TP 8
200 .B char **RPC_make_arg_list (program, family, type,
201 .B                           port, flag)
202 .br
203 .B char *program;
204 .br
205 .B int family;
206 .br
207 .B int type;
208 .br
209 .B int port;
210 .br
211 .B int flag;
212 .TP 8
213 .B int RPC_undo_arg_list (argc, arg_list, machine,
214 .B                         family, type, socket, flag)
215 .br
216 .B int argc;
217 .br
218 .B char **arg_list;
219 .br
220 .B char **machine;
221 .br
222 .B int *family;
223 .br
224 .B int *type;
225 .br
226 .B int *socket;
227 .br
228 .B int *flag;
229 .TP 8
230 .B int RPC_getConnect (fd)
231 .br
232 .B int fd;
233
234 .SH "SEE ALSO"
235 Paradyn(1).
236 .SH COPYRIGHT
237 Copyright 1994, The Paradyn Software Team.
238 .SH AUTHOR
239 Mark Callaghan     (markc@cs.wisc.edu)
240
241
242