util.h 8.9 KB
Newer Older
1

2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 * utils.h: common, generic utility functions
 *
 * Copyright (C) 2006, 2007 Binary Karma
 * Copyright (C) 2006 Shuveb Hussain
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
 *
 * File created Jul 18, 2007 - Shuveb Hussain <shuveb@binarykarma.com>
 */

25 26 27
#ifndef __VIR_UTIL_H__
#define __VIR_UTIL_H__

28
#include "verify.h"
29
#include "internal.h"
30
#include <unistd.h>
31
#include <sys/select.h>
32
#include <sys/types.h>
33

D
Daniel P. Berrange 已提交
34 35
int saferead(int fd, void *buf, size_t count);
ssize_t safewrite(int fd, const void *buf, size_t count);
36
int safezero(int fd, int flags, off_t offset, off_t len);
D
Daniel P. Berrange 已提交
37

38 39 40 41
enum {
    VIR_EXEC_NONE   = 0,
    VIR_EXEC_NONBLOCK = (1 << 0),
    VIR_EXEC_DAEMON = (1 << 1),
42
    VIR_EXEC_CLEAR_CAPS = (1 << 2),
43 44
};

45 46
int virSetNonBlock(int fd) ATTRIBUTE_RETURN_CHECK;
int virSetCloseExec(int fd) ATTRIBUTE_RETURN_CHECK;
47

48 49 50 51
/* This will execute in the context of the first child
 * after fork() but before execve() */
typedef int (*virExecHook)(void *data);

52 53 54 55 56 57 58 59
int virExecDaemonize(virConnectPtr conn,
                     const char *const*argv,
                     const char *const*envp,
                     const fd_set *keepfd,
                     pid_t *retpid,
                     int infd, int *outfd, int *errfd,
                     int flags,
                     virExecHook hook,
60
                     void *data,
61
                     char *pidfile) ATTRIBUTE_RETURN_CHECK;
62 63 64 65 66 67 68 69 70 71
int virExecWithHook(virConnectPtr conn,
                    const char *const*argv,
                    const char *const*envp,
                    const fd_set *keepfd,
                    int *retpid,
                    int infd,
                    int *outfd,
                    int *errfd,
                    int flags,
                    virExecHook hook,
72
                    void *data,
73
                    char *pidfile) ATTRIBUTE_RETURN_CHECK;
74 75 76
int virExec(virConnectPtr conn,
            const char *const*argv,
            const char *const*envp,
77
            const fd_set *keepfd,
78
            pid_t *retpid,
79 80 81
            int infd,
            int *outfd,
            int *errfd,
82 83
            int flags) ATTRIBUTE_RETURN_CHECK;
int virRun(virConnectPtr conn, const char *const*argv, int *status) ATTRIBUTE_RETURN_CHECK;
84

85
int virFileReadLimFD(int fd, int maxlen, char **buf) ATTRIBUTE_RETURN_CHECK;
86

87
int virFileReadAll(const char *path, int maxlen, char **buf) ATTRIBUTE_RETURN_CHECK;
88

89
int virFileWriteStr(const char *path, const char *str) ATTRIBUTE_RETURN_CHECK;
M
Mark McLoughlin 已提交
90

91 92 93 94 95 96 97
int virFileMatchesNameSuffix(const char *file,
                             const char *name,
                             const char *suffix);

int virFileHasSuffix(const char *str,
                     const char *suffix);

98
int virFileStripSuffix(char *str,
99
                       const char *suffix) ATTRIBUTE_RETURN_CHECK;
100

101 102
int virFileLinkPointsTo(const char *checkLink,
                        const char *checkDest);
103

D
Daniel P. Berrange 已提交
104
int virFileResolveLink(const char *linkpath,
105
                       char **resultpath) ATTRIBUTE_RETURN_CHECK;
D
Daniel P. Berrange 已提交
106

107 108
char *virFindFileInPath(const char *file);

109 110
int virFileExists(const char *path);

111
int virFileMakePath(const char *path) ATTRIBUTE_RETURN_CHECK;
112 113 114 115 116

int virFileBuildPath(const char *dir,
                     const char *name,
                     const char *ext,
                     char *buf,
117
                     unsigned int buflen) ATTRIBUTE_RETURN_CHECK;
118

A
Amy Griffis 已提交
119
int virFileAbsPath(const char *path,
120
                   char **abspath) ATTRIBUTE_RETURN_CHECK;
A
Amy Griffis 已提交
121

122 123 124
int virFileOpenTty(int *ttymaster,
                   char **ttyName,
                   int rawmode);
125 126 127 128
int virFileOpenTtyAt(const char *ptmx,
                     int *ttymaster,
                     char **ttyName,
                     int rawmode);
129

130 131
char* virFilePid(const char *dir,
                 const char *name);
132
int virFileWritePidPath(const char *path,
133
                        pid_t pid) ATTRIBUTE_RETURN_CHECK;
134 135
int virFileWritePid(const char *dir,
                    const char *name,
136
                    pid_t pid) ATTRIBUTE_RETURN_CHECK;
137 138
int virFileReadPid(const char *dir,
                   const char *name,
139
                   pid_t *pid) ATTRIBUTE_RETURN_CHECK;
140 141
int virFileDeletePid(const char *dir,
                     const char *name);
142

143 144
char *virArgvToString(const char *const *argv);

D
Daniel P. Berrange 已提交
145
int virStrToLong_i(char const *s,
146 147 148 149 150 151 152 153 154 155 156 157
                     char **end_ptr,
                     int base,
                     int *result);

int virStrToLong_ui(char const *s,
                    char **end_ptr,
                    int base,
                    unsigned int *result);
int virStrToLong_ll(char const *s,
                    char **end_ptr,
                    int base,
                    long long *result);
D
Daniel P. Berrange 已提交
158 159 160 161
int virStrToLong_ull(char const *s,
                     char **end_ptr,
                     int base,
                     unsigned long long *result);
162 163 164
int virStrToDouble(char const *s,
                   char **end_ptr,
                   double *result);
D
Daniel P. Berrange 已提交
165 166

int virMacAddrCompare (const char *mac1, const char *mac2);
167

168 169
void virSkipSpaces(const char **str);
int virParseNumber(const char **str);
170
int virAsprintf(char **strp, const char *fmt, ...)
171
    ATTRIBUTE_FMT_PRINTF(2, 3) ATTRIBUTE_RETURN_CHECK;
C
Chris Lalancette 已提交
172 173 174 175 176
char *virStrncpy(char *dest, const char *src, size_t n, size_t destbytes)
    ATTRIBUTE_RETURN_CHECK;
char *virStrcpy(char *dest, const char *src, size_t destbytes)
    ATTRIBUTE_RETURN_CHECK;
#define virStrcpyStatic(dest, src) virStrcpy((dest), (src), sizeof(dest))
177

178 179 180 181 182
#define VIR_MAC_BUFLEN 6
#define VIR_MAC_PREFIX_BUFLEN 3
#define VIR_MAC_STRING_BUFLEN VIR_MAC_BUFLEN * 3

int virParseMacAddr(const char* str,
183
                    unsigned char *addr) ATTRIBUTE_RETURN_CHECK;
184 185 186 187
void virFormatMacAddr(const unsigned char *addr,
                      char *str);
void virGenerateMacAddr(const unsigned char *prefix,
                        unsigned char *addr);
188

189
int virDiskNameToIndex(const char* str);
190
char *virIndexToDiskName(int idx, const char *prefix);
191 192 193 194 195 196 197 198 199 200

int virEnumFromString(const char *const*types,
                      unsigned int ntypes,
                      const char *type);

const char *virEnumToString(const char *const*types,
                            unsigned int ntypes,
                            int type);

#define VIR_ENUM_IMPL(name, lastVal, ...)                               \
201
    static const char *const name ## TypeList[] = { __VA_ARGS__ };      \
202
    extern int (* name ## Verify (void)) [verify_true (ARRAY_CARDINALITY(name ## TypeList) == lastVal)]; \
203 204 205 206 207 208 209 210 211 212 213 214 215 216 217
    const char *name ## TypeToString(int type) {                        \
        return virEnumToString(name ## TypeList,                        \
                               ARRAY_CARDINALITY(name ## TypeList),     \
                               type);                                   \
    }                                                                   \
    int name ## TypeFromString(const char *type) {                      \
        return virEnumFromString(name ## TypeList,                      \
                                 ARRAY_CARDINALITY(name ## TypeList),   \
                                 type);                                 \
    }

#define VIR_ENUM_DECL(name)                             \
    const char *name ## TypeToString(int type);         \
    int name ## TypeFromString(const char*type);

D
Daniel P. Berrange 已提交
218 219 220 221 222 223 224 225
#ifndef HAVE_GETUID
static inline int getuid (void) { return 0; }
#endif

#ifndef HAVE_GETGID
static inline int getgid (void) { return 0; }
#endif

226
char *virGetHostname(virConnectPtr conn);
227

G
Guido Günther 已提交
228 229
int virKillProcess(pid_t pid, int sig);

230 231 232
#ifdef HAVE_GETPWUID_R
char *virGetUserDirectory(virConnectPtr conn,
                          uid_t uid);
233 234
char *virGetUserName(virConnectPtr conn,
                     uid_t uid);
235 236
int virGetUserID(virConnectPtr conn,
                 const char *name,
237
                 uid_t *uid) ATTRIBUTE_RETURN_CHECK;
238 239
int virGetGroupID(virConnectPtr conn,
                  const char *name,
240
                  gid_t *gid) ATTRIBUTE_RETURN_CHECK;
241 242
#endif

243
int virRandomInitialize(unsigned int seed) ATTRIBUTE_RETURN_CHECK;
244 245
int virRandom(int max);

246 247 248 249
#ifdef HAVE_MNTENT_H
char *virFileFindMountPoint(const char *type);
#endif

D
Daniel P. Berrange 已提交
250 251
void virFileWaitForDevices(virConnectPtr conn);

252 253 254
#define virBuildPath(path, ...) virBuildPathInternal(path, __VA_ARGS__, NULL)
int virBuildPathInternal(char **path, ...) ATTRIBUTE_SENTINEL;

255
#endif /* __VIR_UTIL_H__ */