1
/* $Id: types.h 4359 2013-02-21 11:18:36Z bennylp $ */
3
* Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com)
4
* Copyright (C) 2003-2008 Benny Prijono <benny@prijono.org>
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20
#ifndef __PJ_TYPES_H__
21
#define __PJ_TYPES_H__
26
* @brief Declaration of basic types and utility.
29
* @defgroup PJ_BASIC Basic Data Types and Library Functionality.
33
#include <pj/config.h>
37
/* ************************************************************************* */
39
/** Signed 32bit integer. */
40
typedef int pj_int32_t;
42
/** Unsigned 32bit integer. */
43
typedef unsigned int pj_uint32_t;
45
/** Signed 16bit integer. */
46
typedef short pj_int16_t;
48
/** Unsigned 16bit integer. */
49
typedef unsigned short pj_uint16_t;
51
/** Signed 8bit integer. */
52
typedef signed char pj_int8_t;
54
/** Unsigned 8bit integer. */
55
typedef unsigned char pj_uint8_t;
57
/** Large unsigned integer. */
58
typedef size_t pj_size_t;
60
/** Large signed integer. */
61
typedef long pj_ssize_t;
64
typedef int pj_status_t;
67
typedef int pj_bool_t;
69
/** Native char type, which will be equal to wchar_t for Unicode
70
* and char for ANSI. */
71
#if defined(PJ_NATIVE_STRING_IS_UNICODE) && PJ_NATIVE_STRING_IS_UNICODE!=0
72
typedef wchar_t pj_char_t;
74
typedef char pj_char_t;
77
/** This macro creates Unicode or ANSI literal string depending whether
78
* native platform string is Unicode or ANSI. */
79
#if defined(PJ_NATIVE_STRING_IS_UNICODE) && PJ_NATIVE_STRING_IS_UNICODE!=0
80
# define PJ_T(literal_str) L##literal_str
82
# define PJ_T(literal_str) literal_str
98
#if defined(PJ_HAS_INT64) && PJ_HAS_INT64!=0
99
typedef pj_int64_t pj_off_t;
101
typedef pj_ssize_t pj_off_t;
104
/* ************************************************************************* */
106
* Data structure types.
109
* This type is used as replacement to legacy C string, and used throughout
110
* the library. By convention, the string is NOT null terminated.
114
/** Buffer pointer, which is by convention NOT null terminated. */
117
/** The length of the string. */
122
* This structure represents high resolution (64bit) time value. The time
123
* values represent time in cycles, which is retrieved by calling
124
* #pj_get_timestamp().
126
typedef union pj_timestamp
130
#if defined(PJ_IS_LITTLE_ENDIAN) && PJ_IS_LITTLE_ENDIAN!=0
131
pj_uint32_t lo; /**< Low 32-bit value of the 64-bit value. */
132
pj_uint32_t hi; /**< high 32-bit value of the 64-bit value. */
134
pj_uint32_t hi; /**< high 32-bit value of the 64-bit value. */
135
pj_uint32_t lo; /**< Low 32-bit value of the 64-bit value. */
137
} u32; /**< The 64-bit value as two 32-bit values. */
140
pj_uint64_t u64; /**< The whole 64-bit value, where available. */
147
* The opaque data type for linked list, which is used as arguments throughout
148
* the linked list operations.
150
typedef void pj_list_type;
155
typedef struct pj_list pj_list;
158
* Opaque data type for hash tables.
160
typedef struct pj_hash_table_t pj_hash_table_t;
163
* Opaque data type for hash entry (only used internally by hash table).
165
typedef struct pj_hash_entry pj_hash_entry;
168
* Data type for hash search iterator.
169
* This structure should be opaque, however applications need to declare
170
* concrete variable of this type, that's why the declaration is visible here.
172
typedef struct pj_hash_iterator_t
174
pj_uint32_t index; /**< Internal index. */
175
pj_hash_entry *entry; /**< Internal entry. */
176
} pj_hash_iterator_t;
180
* Forward declaration for memory pool factory.
182
typedef struct pj_pool_factory pj_pool_factory;
185
* Opaque data type for memory pool.
187
typedef struct pj_pool_t pj_pool_t;
190
* Forward declaration for caching pool, a pool factory implementation.
192
typedef struct pj_caching_pool pj_caching_pool;
195
* This type is used as replacement to legacy C string, and used throughout
198
typedef struct pj_str_t pj_str_t;
201
* Opaque data type for I/O Queue structure.
203
typedef struct pj_ioqueue_t pj_ioqueue_t;
206
* Opaque data type for key that identifies a handle registered to the
207
* I/O queue framework.
209
typedef struct pj_ioqueue_key_t pj_ioqueue_key_t;
212
* Opaque data to identify timer heap.
214
typedef struct pj_timer_heap_t pj_timer_heap_t;
217
* Opaque data type for atomic operations.
219
typedef struct pj_atomic_t pj_atomic_t;
222
* Value type of an atomic variable.
224
typedef PJ_ATOMIC_VALUE_TYPE pj_atomic_value_t;
226
/* ************************************************************************* */
228
/** Thread handle. */
229
typedef struct pj_thread_t pj_thread_t;
232
typedef struct pj_lock_t pj_lock_t;
235
typedef struct pj_grp_lock_t pj_grp_lock_t;
238
typedef struct pj_mutex_t pj_mutex_t;
240
/** Semaphore handle. */
241
typedef struct pj_sem_t pj_sem_t;
244
typedef struct pj_event_t pj_event_t;
246
/** Unidirectional stream pipe object. */
247
typedef struct pj_pipe_t pj_pipe_t;
249
/** Operating system handle. */
250
typedef void *pj_oshandle_t;
252
/** Socket handle. */
253
typedef long pj_sock_t;
255
/** Generic socket address. */
256
typedef void pj_sockaddr_t;
258
/** Forward declaration. */
259
typedef struct pj_sockaddr_in pj_sockaddr_in;
262
typedef unsigned int pj_color_t;
265
typedef int pj_exception_id_t;
267
/* ************************************************************************* */
269
/** Utility macro to compute the number of elements in static array. */
270
#define PJ_ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0]))
272
/** Maximum value for signed 32-bit integer. */
273
#define PJ_MAXINT32 0x7FFFFFFFL
276
* Length of object names.
278
#define PJ_MAX_OBJ_NAME 32
280
/* ************************************************************************* */
285
* Initialize the PJ Library.
286
* This function must be called before using the library. The purpose of this
287
* function is to initialize static library data, such as character table used
288
* in random string generation, and to initialize operating system dependent
289
* functionality (such as WSAStartup() in Windows).
291
* Apart from calling pj_init(), application typically should also initialize
292
* the random seed by calling pj_srand().
294
* @return PJ_SUCCESS on success.
296
PJ_DECL(pj_status_t) pj_init(void);
302
PJ_DECL(void) pj_shutdown(void);
305
* Type of callback to register to pj_atexit().
307
typedef void (*pj_exit_callback)(void);
310
* Register cleanup function to be called by PJLIB when pj_shutdown() is
313
* @param func The function to be registered.
315
* @return PJ_SUCCESS on success.
317
PJ_DECL(pj_status_t) pj_atexit(pj_exit_callback func);
322
* Swap the byte order of an 16bit data.
324
* @param val16 The 16bit data.
326
* @return An 16bit data with swapped byte order.
328
PJ_INLINE(pj_int16_t) pj_swap16(pj_int16_t val16)
330
pj_uint8_t *p = (pj_uint8_t*)&val16;
338
* Swap the byte order of an 32bit data.
340
* @param val32 The 32bit data.
342
* @return An 32bit data with swapped byte order.
344
PJ_INLINE(pj_int32_t) pj_swap32(pj_int32_t val32)
346
pj_uint8_t *p = (pj_uint8_t*)&val32;
361
* @addtogroup PJ_TIME Time Data Type and Manipulation.
367
* Representation of time value in this library.
368
* This type can be used to represent either an interval or a specific time
371
typedef struct pj_time_val
373
/** The seconds part of the time. */
376
/** The miliseconds fraction of the time. */
382
* Normalize the value in time value.
383
* @param t Time value to be normalized.
385
PJ_DECL(void) pj_time_val_normalize(pj_time_val *t);
388
* Get the total time value in miliseconds. This is the same as
389
* multiplying the second part with 1000 and then add the miliseconds
390
* part to the result.
392
* @param t The time value.
393
* @return Total time in miliseconds.
396
#define PJ_TIME_VAL_MSEC(t) ((t).sec * 1000 + (t).msec)
399
* This macro will check if \a t1 is equal to \a t2.
401
* @param t1 The first time value to compare.
402
* @param t2 The second time value to compare.
403
* @return Non-zero if both time values are equal.
406
#define PJ_TIME_VAL_EQ(t1, t2) ((t1).sec==(t2).sec && (t1).msec==(t2).msec)
409
* This macro will check if \a t1 is greater than \a t2
411
* @param t1 The first time value to compare.
412
* @param t2 The second time value to compare.
413
* @return Non-zero if t1 is greater than t2.
416
#define PJ_TIME_VAL_GT(t1, t2) ((t1).sec>(t2).sec || \
417
((t1).sec==(t2).sec && (t1).msec>(t2).msec))
420
* This macro will check if \a t1 is greater than or equal to \a t2
422
* @param t1 The first time value to compare.
423
* @param t2 The second time value to compare.
424
* @return Non-zero if t1 is greater than or equal to t2.
427
#define PJ_TIME_VAL_GTE(t1, t2) (PJ_TIME_VAL_GT(t1,t2) || \
428
PJ_TIME_VAL_EQ(t1,t2))
431
* This macro will check if \a t1 is less than \a t2
433
* @param t1 The first time value to compare.
434
* @param t2 The second time value to compare.
435
* @return Non-zero if t1 is less than t2.
438
#define PJ_TIME_VAL_LT(t1, t2) (!(PJ_TIME_VAL_GTE(t1,t2)))
441
* This macro will check if \a t1 is less than or equal to \a t2.
443
* @param t1 The first time value to compare.
444
* @param t2 The second time value to compare.
445
* @return Non-zero if t1 is less than or equal to t2.
448
#define PJ_TIME_VAL_LTE(t1, t2) (!PJ_TIME_VAL_GT(t1, t2))
451
* Add \a t2 to \a t1 and store the result in \a t1. Effectively
453
* this macro will expand as: (\a t1 += \a t2).
454
* @param t1 The time value to add.
455
* @param t2 The time value to be added to \a t1.
458
#define PJ_TIME_VAL_ADD(t1, t2) do { \
459
(t1).sec += (t2).sec; \
460
(t1).msec += (t2).msec; \
461
pj_time_val_normalize(&(t1)); \
466
* Substract \a t2 from \a t1 and store the result in \a t1. Effectively
467
* this macro will expand as (\a t1 -= \a t2).
469
* @param t1 The time value to subsctract.
470
* @param t2 The time value to be substracted from \a t1.
473
#define PJ_TIME_VAL_SUB(t1, t2) do { \
474
(t1).sec -= (t2).sec; \
475
(t1).msec -= (t2).msec; \
476
pj_time_val_normalize(&(t1)); \
481
* This structure represent the parsed representation of time.
482
* It is acquired by calling #pj_time_decode().
484
typedef struct pj_parsed_time
486
/** This represents day of week where value zero means Sunday */
489
/* This represents day of the year, 0-365, where zero means
494
/** This represents day of month: 1-31 */
497
/** This represents month, with the value is 0 - 11 (zero is January) */
500
/** This represent the actual year (unlike in ANSI libc where
501
* the value must be added by 1900).
505
/** This represents the second part, with the value is 0-59 */
508
/** This represents the minute part, with the value is: 0-59 */
511
/** This represents the hour part, with the value is 0-23 */
514
/** This represents the milisecond part, with the value is 0-999 */
521
* @} // Time Management
524
/* ************************************************************************* */
529
* Color code combination.
532
PJ_TERM_COLOR_R = 2, /**< Red */
533
PJ_TERM_COLOR_G = 4, /**< Green */
534
PJ_TERM_COLOR_B = 1, /**< Blue. */
535
PJ_TERM_COLOR_BRIGHT = 8 /**< Bright mask. */
544
#endif /* __PJ_TYPES_H__ */