summaryrefslogtreecommitdiff
path: root/src/pluto/defs.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/pluto/defs.h')
-rw-r--r--src/pluto/defs.h97
1 files changed, 23 insertions, 74 deletions
diff --git a/src/pluto/defs.h b/src/pluto/defs.h
index 574ce4a1a..8491f4ae8 100644
--- a/src/pluto/defs.h
+++ b/src/pluto/defs.h
@@ -11,128 +11,77 @@
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* for more details.
- *
- * RCSID $Id: defs.h 3252 2007-10-06 21:24:50Z andreas $
*/
#ifndef _DEFS_H
#define _DEFS_H
+#include <string.h>
#include <sys/types.h>
+#include <chunk.h>
+
#ifdef KLIPS
-# define USED_BY_KLIPS /* ignore */
+# define USED_BY_KLIPS /* ignore */
#else
-# define USED_BY_KLIPS UNUSED
+# define USED_BY_KLIPS UNUSED
#endif
#ifdef DEBUG
-# define USED_BY_DEBUG /* ignore */
+# define USED_BY_DEBUG /* ignore */
#else
-# define USED_BY_DEBUG UNUSED
+# define USED_BY_DEBUG UNUSED
#endif
-/* Length of temporary buffers */
-
-#define BUF_LEN 512
-
/* type of serial number of a state object
* Needed in connections.h and state.h; here to simplify dependencies.
*/
typedef unsigned long so_serial_t;
-#define SOS_NOBODY 0 /* null serial number */
-#define SOS_FIRST 1 /* first normal serial number */
+#define SOS_NOBODY 0 /* null serial number */
+#define SOS_FIRST 1 /* first normal serial number */
/* memory allocation */
-extern void *alloc_bytes(size_t size, const char *name);
-#define alloc_thing(thing, name) (alloc_bytes(sizeof(thing), (name)))
+#define clone_thing(orig) clalloc((void *)&(orig), sizeof(orig))
-extern void *clone_bytes(const void *orig, size_t size, const char *name);
-#define clone_thing(orig, name) clone_bytes((const void *)&(orig), sizeof(orig), (name))
-#define clone_str(str, name) \
- ((str) == NULL? NULL : clone_bytes((str), strlen((str))+1, (name)))
+#define clone_str(str) \
+ ((str) == NULL? NULL : strdup(str))
+
+#define replace(p, q) \
+ { free(p); (p) = (q); }
-#ifdef LEAK_DETECTIVE
- extern void pfree(void *ptr);
- extern void report_leaks(void);
-#else
-# define pfree(ptr) free(ptr) /* ordinary stdc free */
-#endif
-#define pfreeany(p) { if ((p) != NULL) pfree(p); }
-#define replace(p, q) { pfreeany(p); (p) = (q); }
-
-
-/* chunk is a simple pointer-and-size abstraction */
-
-struct chunk {
- u_char *ptr;
- size_t len;
- };
-typedef struct chunk chunk_t;
-
-#define setchunk(ch, addr, size) { (ch).ptr = (addr); (ch).len = (size); }
-#define strchunk(str) { str, sizeof(str) }
-/* NOTE: freeanychunk, unlike pfreeany, NULLs .ptr */
-#define freeanychunk(ch) { pfreeany((ch).ptr); (ch).ptr = NULL; }
-#define clonetochunk(ch, addr, size, name) \
- { (ch).ptr = clone_bytes((addr), (ch).len = (size), name); }
-#define clonereplacechunk(ch, addr, size, name) \
- { pfreeany((ch).ptr); clonetochunk(ch, addr, size, name); }
#define chunkcpy(dst, chunk) \
- { memcpy(dst, chunk.ptr, chunk.len); dst += chunk.len;}
-#define same_chunk(a, b) \
- ( (a).len == (b).len && memcmp((a).ptr, (b).ptr, (b).len) == 0 )
+ { memcpy(dst, chunk.ptr, chunk.len); dst += chunk.len;}
extern char* temporary_cyclic_buffer(void);
-extern const char* concatenate_paths(const char *a, const char *b);
-
-extern const chunk_t empty_chunk;
-
-/* compare two chunks */
-extern int cmp_chunk(chunk_t a, chunk_t b);
+extern char* concatenate_paths(char *a, char *b);
/* move a chunk to a memory position and free it after insertion */
extern void mv_chunk(u_char **pos, chunk_t content);
-/* write the binary contents of a chunk_t to a file */
-extern bool write_chunk(const char *filename, const char *label, chunk_t ch
- ,mode_t mask, bool force);
-
-/* display a date either in local or UTC time */
-extern char* timetoa(const time_t *time, bool utc);
-
/* warns a predefined interval before expiry */
extern const char* check_expiry(time_t expiration_date,
- int warning_interval, bool strict);
+ int warning_interval, bool strict);
-#define MAX_PROMPT_PASS_TRIALS 5
-#define PROMPT_PASS_LEN 64
+#define MAX_PROMPT_PASS_TRIALS 5
+#define PROMPT_PASS_LEN 64
/* struct used to prompt for a secret passphrase
* from a console with file descriptor fd
*/
typedef struct {
- char secret[PROMPT_PASS_LEN+1];
- bool prompt;
- int fd;
+ char secret[PROMPT_PASS_LEN+1];
+ bool prompt;
+ int fd;
} prompt_pass_t;
-/* no time defined in time_t */
-#define UNDEFINED_TIME 0
-
-/* size of timetoa string buffer */
-#define TIMETOA_BUF 30
-
/* filter eliminating the directory entries '.' and '..' */
typedef struct dirent dirent_t;
extern int file_select(const dirent_t *entry);
/* cleanly exit Pluto */
-
extern void exit_pluto(int /*status*/) NEVER_RETURNS;
-
/* zero all bytes */
#define zero(x) memset((x), '\0', sizeof(*(x)))