/*
Unix SMB / CIFS implementation .
SMB parameters and setup
Copyright ( C ) Andrew Tridgell 1992 - 1999
Copyright ( C ) John H Terpstra 1996 - 1999
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1999
Copyright ( C ) Paul Ashton 1998 - 1999
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
( at your option ) any later version .
This program 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 General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# ifndef _SMB_MACROS_H
# define _SMB_MACROS_H
/* Misc bit macros */
# define BOOLSTR(b) ((b) ? "Yes" : "No")
# define BITSETW(ptr,bit) ((SVAL(ptr,0) & (1<<(bit)))!=0)
/* for readability... */
# define IS_DOS_READONLY(test_mode) (((test_mode) & aRONLY) != 0)
# define IS_DOS_DIR(test_mode) (((test_mode) & aDIR) != 0)
# define IS_DOS_ARCHIVE(test_mode) (((test_mode) & aARCH) != 0)
# define IS_DOS_SYSTEM(test_mode) (((test_mode) & aSYSTEM) != 0)
# define IS_DOS_HIDDEN(test_mode) (((test_mode) & aHIDDEN) != 0)
# ifndef SAFE_FREE /* Oh no this is also defined in tdb.h */
/**
* Free memory if the pointer and zero the pointer .
*
* @ note You are explicitly allowed to pass NULL pointers - - they will
* always be ignored .
* */
2005-05-31 13:46:45 +00:00
# define SAFE_FREE(x) do { if ((x) != NULL) {free(x); x=NULL;} } while(0)
# endif
/* assert macros */
2005-04-16 20:48:04 +00:00
# ifdef DEVELOPER
# define SMB_ASSERT(b) ( (b) ? (void)0 : \
2007-06-15 21:58:49 +00:00
( DEBUG ( 0 , ( " PANIC: assert failed at %s(%d): %s \n " , \
__FILE__ , __LINE__ , # b ) ) , smb_panic ( " assert failed: " # b ) ) )
2005-04-16 20:48:04 +00:00
# else
/* redefine the assert macro for non-developer builds */
# define SMB_ASSERT(b) ( (b) ? (void)0 : \
2007-06-15 21:58:49 +00:00
( DEBUG ( 0 , ( " PANIC: assert failed at %s(%d): %s \n " , \
__FILE__ , __LINE__ , # b ) ) ) )
2005-04-16 20:48:04 +00:00
# endif
2006-03-22 23:49:09 +00:00
# define SMB_WARN(condition, message) \
( ( condition ) ? ( void ) 0 : \
DEBUG ( 0 , ( " WARNING: %s: %s \n " , # condition , message ) ) )
# define SMB_ASSERT_ARRAY(a,n) SMB_ASSERT((sizeof(a) / sizeof((a)[0])) >= (n))
/* these are useful macros for checking validity of handles */
# define IS_IPC(conn) ((conn) && (conn)->ipc)
# define IS_PRINT(conn) ((conn) && (conn)->printer)
2005-04-06 16:28:04 +00:00
/* you must add the following extern declaration to files using this macro
2006-12-12 17:38:42 +00:00
* ( do not add it to the macro as that causes nested extern declaration warnings )
2005-04-06 16:28:04 +00:00
* extern struct current_user current_user ;
*/
# define FSP_BELONGS_CONN(fsp,conn) do {\
if ( ! ( ( fsp ) & & ( conn ) & & ( ( conn ) = = ( fsp ) - > conn ) & & ( current_user . vuid = = ( fsp ) - > vuid ) ) ) \
2006-07-11 18:01:26 +00:00
return ERROR_NT ( NT_STATUS_INVALID_HANDLE ) ; \
} while ( 0 )
2006-07-11 18:01:26 +00:00
# define FNUM_OK(fsp,c) ((fsp) && !(fsp)->is_directory && (c)==(fsp)->conn && current_user.vuid==(fsp)->vuid)
2005-04-06 16:28:04 +00:00
/* you must add the following extern declaration to files using this macro
2006-12-12 17:38:42 +00:00
* ( do not add it to the macro as that causes nested extern declaration warnings )
2005-04-06 16:28:04 +00:00
* extern struct current_user current_user ;
*/
# define CHECK_FSP(fsp,conn) do {\
2006-07-11 18:01:26 +00:00
if ( ! ( fsp ) | | ! ( conn ) ) \
return ERROR_NT ( NT_STATUS_INVALID_HANDLE ) ; \
else if ( ( ( conn ) ! = ( fsp ) - > conn ) | | current_user . vuid ! = ( fsp ) - > vuid ) \
return ERROR_NT ( NT_STATUS_INVALID_HANDLE ) ; \
else if ( ( fsp ) - > is_directory ) \
return ERROR_NT ( NT_STATUS_INVALID_DEVICE_REQUEST ) ; \
else if ( ( fsp ) - > fh - > fd = = - 1 ) \
return ERROR_NT ( NT_STATUS_ACCESS_DENIED ) ; \
2005-04-14 23:32:56 +00:00
( fsp ) - > num_smb_operations + + ; \
} while ( 0 )
2005-07-08 04:51:27 +00:00
# define CHECK_READ(fsp,inbuf) (((fsp)->fh->fd != -1) && ((fsp)->can_read || \
( ( SVAL ( ( inbuf ) , smb_flg2 ) & FLAGS2_READ_PERMIT_EXECUTE ) & & \
( fsp - > access_mask & FILE_EXECUTE ) ) ) )
# define CHECK_WRITE(fsp) ((fsp)->can_write && ((fsp)->fh->fd != -1))
# define ERROR_WAS_LOCK_DENIED(status) (NT_STATUS_EQUAL((status), NT_STATUS_LOCK_NOT_GRANTED) || \
NT_STATUS_EQUAL ( ( status ) , NT_STATUS_FILE_LOCK_CONFLICT ) )
/* the service number for the [globals] defaults */
# define GLOBAL_SECTION_SNUM (-1)
/* translates a connection number into a service number */
2006-07-11 18:01:26 +00:00
# define SNUM(conn) ((conn)?(conn)->params->service:GLOBAL_SECTION_SNUM)
/* access various service details */
# define SERVICE(snum) (lp_servicename(snum))
# define PRINTERNAME(snum) (lp_printername(snum))
# define CAN_WRITE(conn) (!conn->read_only)
# define VALID_SNUM(snum) (lp_snum_ok(snum))
# define GUEST_OK(snum) (VALID_SNUM(snum) && lp_guest_ok(snum))
# define GUEST_ONLY(snum) (VALID_SNUM(snum) && lp_guest_only(snum))
# define CAN_SETDIR(snum) (!lp_no_set_dir(snum))
2006-07-11 18:01:26 +00:00
# define CAN_PRINT(conn) ((conn) && lp_print_ok(SNUM(conn)))
# define MAP_HIDDEN(conn) ((conn) && lp_map_hidden(SNUM(conn)))
# define MAP_SYSTEM(conn) ((conn) && lp_map_system(SNUM(conn)))
# define MAP_ARCHIVE(conn) ((conn) && lp_map_archive(SNUM(conn)))
2004-05-07 18:37:47 +00:00
# define IS_HIDDEN_PATH(conn,path) ((conn) && is_in_path((path),(conn)->hide_list,(conn)->case_sensitive))
# define IS_VETO_PATH(conn,path) ((conn) && is_in_path((path),(conn)->veto_list,(conn)->case_sensitive))
# define IS_VETO_OPLOCK_PATH(conn,path) ((conn) && is_in_path((path),(conn)->veto_oplock_list,(conn)->case_sensitive))
/*
* Used by the stat cache code to check if a returned
* stat structure is valid .
*/
# define VALID_STAT(st) ((st).st_nlink != 0)
# define VALID_STAT_OF_DIR(st) (VALID_STAT(st) && S_ISDIR((st).st_mode))
2005-06-02 23:18:52 +00:00
# define SET_STAT_INVALID(st) ((st).st_nlink = 0)
# ifndef MIN
# define MIN(a,b) ((a)<(b)?(a):(b))
# endif
# ifndef MAX
# define MAX(a,b) ((a)>(b)?(a):(b))
# endif
# ifndef ABS
# define ABS(a) ((a)>0?(a):(-(a)))
# endif
/* Macros to get at offsets within smb_lkrng and smb_unlkrng
structures . We cannot define these as actual structures
due to possible differences in structure packing
on different machines / compilers . */
# define SMB_LPID_OFFSET(indx) (10 * (indx))
# define SMB_LKOFF_OFFSET(indx) ( 2 + (10 * (indx)))
# define SMB_LKLEN_OFFSET(indx) ( 6 + (10 * (indx)))
# define SMB_LARGE_LPID_OFFSET(indx) (20 * (indx))
# define SMB_LARGE_LKOFF_OFFSET_HIGH(indx) (4 + (20 * (indx)))
# define SMB_LARGE_LKOFF_OFFSET_LOW(indx) (8 + (20 * (indx)))
# define SMB_LARGE_LKLEN_OFFSET_HIGH(indx) (12 + (20 * (indx)))
# define SMB_LARGE_LKLEN_OFFSET_LOW(indx) (16 + (20 * (indx)))
2008-01-04 12:56:23 -08:00
# define ERROR_DOS(class,code) error_packet(outbuf,class,code,NT_STATUS_OK,__LINE__,__FILE__)
# define ERROR_NT(status) error_packet(outbuf,0,0,status,__LINE__,__FILE__)
# define ERROR_FORCE_NT(status) error_packet(outbuf,-1,-1,status,__LINE__,__FILE__)
# define ERROR_BOTH(status,class,code) error_packet(outbuf,class,code,status,__LINE__,__FILE__)
2007-07-23 09:36:09 +00:00
# define reply_nterror(req,status) reply_nt_error(req,status,__LINE__,__FILE__)
2007-08-10 10:28:09 +00:00
# define reply_force_nterror(req,status) reply_force_nt_error(req,status,__LINE__,__FILE__)
2007-07-23 09:36:09 +00:00
# define reply_doserror(req,eclass,ecode) reply_dos_error(req,eclass,ecode,__LINE__,__FILE__)
# define reply_botherror(req,status,eclass,ecode) reply_both_error(req,eclass,ecode,status,__LINE__,__FILE__)
2007-07-30 10:23:26 +00:00
# define reply_unixerror(req,defclass,deferror) reply_unix_error(req,defclass,deferror,NT_STATUS_OK,__LINE__,__FILE__)
2007-07-23 09:36:09 +00:00
2005-04-01 23:11:28 +00:00
/* these are the datagram types */
# define DGRAM_DIRECT_UNIQUE 0x10
2005-03-03 03:43:57 +00:00
# define SMB_ROUNDUP(x,r) ( ((x)%(r)) ? ( (((x)+(r)) / (r))*(r) ) : (x))
/* Extra macros added by Ying Chen at IBM - speed increase by inlining. */
# define smb_buf(buf) (((char *)(buf)) + smb_size + CVAL(buf,smb_wct)*2)
# define smb_buflen(buf) (SVAL(buf,smb_vwv0 + (int)CVAL(buf, smb_wct)*2))
/* the remaining number of bytes in smb buffer 'buf' from pointer 'p'. */
# define smb_bufrem(buf, p) (smb_buflen(buf)-PTR_DIFF(p, smb_buf(buf)))
/* Note that chain_size must be available as an extern int to this macro. */
# define smb_offset(p,buf) (PTR_DIFF(p,buf+4) + chain_size)
# define smb_len(buf) (PVAL(buf,3)|(PVAL(buf,2)<<8)|((PVAL(buf,1)&1)<<16))
2007-12-26 17:12:36 -08:00
# define _smb_setlen(buf,len) do { buf[0] = 0; buf[1] = ((len)&0x10000)>>16; \
buf [ 2 ] = ( ( len ) & 0xFF00 ) > > 8 ; buf [ 3 ] = ( len ) & 0xFF ; } while ( 0 )
2007-05-16 00:07:38 +00:00
# define smb_len_large(buf) (PVAL(buf,3)|(PVAL(buf,2)<<8)|(PVAL(buf,1)<<16))
2007-11-02 12:21:34 -07:00
# define _smb_setlen_large(buf,len) do { buf[0] = 0; buf[1] = ((len)&0xFF0000)>>16; \
buf [ 2 ] = ( ( len ) & 0xFF00 ) > > 8 ; buf [ 3 ] = ( len ) & 0xFF ; } while ( 0 )
2007-05-16 00:07:38 +00:00
2008-01-04 12:56:23 -08:00
# define ENCRYPTION_REQUIRED(conn) ((conn) ? ((conn)->encrypt_level == Required) : false)
# define IS_CONN_ENCRYPTED(conn) ((conn) ? (conn)->encrypted_tid : false)
/*******************************************************************
find the difference in milliseconds between two struct timeval
values
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define TvalDiff(tvalold,tvalnew) \
( ( ( tvalnew ) - > tv_sec - ( tvalold ) - > tv_sec ) * 1000 + \
( ( int ) ( tvalnew ) - > tv_usec - ( int ) ( tvalold ) - > tv_usec ) / 1000 )
/****************************************************************************
2007-10-24 14:16:54 -07:00
true if two IPv4 addresses are equal
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-24 14:16:54 -07:00
# define ip_equal_v4(ip1,ip2) ((ip1).s_addr == (ip2).s_addr)
/*****************************************************************
splits out the last subkey of a key
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define reg_get_subkey(full_keyname, key_name, subkey_name) \
split_at_last_component ( full_keyname , key_name , ' \\ ' , subkey_name )
/****************************************************************************
Return True if the offset is at zero .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-05-01 09:30:18 +00:00
# define dptr_zero(buf) (IVAL(buf,1) == 0)
/*******************************************************************
copy an IP address from one buffer to another
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define putip(dest,src) memcpy(dest,src,4)
/*******************************************************************
Return True if a server has CIFS UNIX capabilities .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define SERVER_HAS_UNIX_CIFS(c) ((c)->capabilities & CAP_UNIX)
/****************************************************************************
Make a filename into unix format .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define IS_DIRECTORY_SEP(c) ((c) == '\\' || (c) == ' / ')
# define unix_format(fname) string_replace(fname,'\\',' / ')
# define unix_format_w(fname) string_replace_w(fname, UCS2_CHAR('\\'), UCS2_CHAR(' / '))
/****************************************************************************
Make a file into DOS format .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define dos_format(fname) string_replace(fname,' / ','\\')
/*****************************************************************************
2005-09-02 09:10:42 +00:00
Check to see if we are a DC for this domain
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define IS_DC (lp_server_role()==ROLE_DOMAIN_PDC || lp_server_role()==ROLE_DOMAIN_BDC)
2004-12-07 18:25:53 +00:00
/*****************************************************************************
Safe allocation macros .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# define SMB_MALLOC_ARRAY(type,count) (type *)malloc_array(sizeof(type),(count))
2007-02-24 12:40:43 +00:00
# define SMB_MEMALIGN_ARRAY(type,align,count) (type *)memalign_array(sizeof(type),align,(count))
r13915: Fixed a very interesting class of realloc() bugs found by Coverity.
realloc can return NULL in one of two cases - (1) the realloc failed,
(2) realloc succeeded but the new size requested was zero, in which
case this is identical to a free() call.
The error paths dealing with these two cases should be different,
but mostly weren't. Secondly the standard idiom for dealing with
realloc when you know the new size is non-zero is the following :
tmp = realloc(p, size);
if (!tmp) {
SAFE_FREE(p);
return error;
} else {
p = tmp;
}
However, there were *many* *many* places in Samba where we were
using the old (broken) idiom of :
p = realloc(p, size)
if (!p) {
return error;
}
which will leak the memory pointed to by p on realloc fail.
This commit (hopefully) fixes all these cases by moving to
a standard idiom of :
p = SMB_REALLOC(p, size)
if (!p) {
return error;
}
Where if the realloc returns null due to the realloc failing
or size == 0 we *guarentee* that the storage pointed to by p
has been freed. This allows me to remove a lot of code that
was dealing with the standard (more verbose) method that required
a tmp pointer. This is almost always what you want. When a
realloc fails you never usually want the old memory, you
want to free it and get into your error processing asap.
For the 11 remaining cases where we really do need to keep the
old pointer I have invented the new macro SMB_REALLOC_KEEP_OLD_ON_ERROR,
which can be used as follows :
tmp = SMB_REALLOC_KEEP_OLD_ON_ERROR(p, size);
if (!tmp) {
SAFE_FREE(p);
return error;
} else {
p = tmp;
}
SMB_REALLOC_KEEP_OLD_ON_ERROR guarentees never to free the
pointer p, even on size == 0 or realloc fail. All this is
done by a hidden extra argument to Realloc(), BOOL free_old_on_error
which is set appropriately by the SMB_REALLOC and SMB_REALLOC_KEEP_OLD_ON_ERROR
macros (and their array counterparts).
It remains to be seen what this will do to our Coverity bug count :-).
Jeremy.
2006-03-07 06:31:04 +00:00
# define SMB_REALLOC(p,s) Realloc((p),(s),True) /* Always frees p on error or s == 0 */
# define SMB_REALLOC_KEEP_OLD_ON_ERROR(p,s) Realloc((p),(s),False) /* Never frees p on error or s == 0 */
# define SMB_REALLOC_ARRAY(p,type,count) (type *)realloc_array((p),sizeof(type),(count),True) /* Always frees p on error or s == 0 */
2006-03-07 18:52:48 +00:00
# define SMB_REALLOC_ARRAY_KEEP_OLD_ON_ERROR(p,type,count) (type *)realloc_array((p),sizeof(type),(count),False) /* Never frees p on error or s == 0 */
2004-12-07 18:25:53 +00:00
# define SMB_CALLOC_ARRAY(type,count) (type *)calloc_array(sizeof(type),(count))
# define SMB_XMALLOC_P(type) (type *)smb_xmalloc_array(sizeof(type),1)
# define SMB_XMALLOC_ARRAY(type,count) (type *)smb_xmalloc_array(sizeof(type),(count))
2005-05-03 07:33:49 +00:00
/* The new talloc is paranoid malloc checker safe. */
2004-12-07 18:25:53 +00:00
2007-08-29 01:23:31 +00:00
#if 0
2007-08-30 14:55:32 +00:00
Disable these now we have checked all code paths and ensured
2007-08-29 01:23:31 +00:00
NULL returns on zero request . JRA .
2007-04-29 00:09:22 +00:00
# define TALLOC(ctx, size) talloc_zeronull(ctx, size, __location__)
# define TALLOC_P(ctx, type) (type *)talloc_zeronull(ctx, sizeof(type), #type)
# define TALLOC_ARRAY(ctx, type, count) (type *)_talloc_array_zeronull(ctx, sizeof(type), count, #type)
# define TALLOC_MEMDUP(ctx, ptr, size) _talloc_memdup_zeronull(ctx, ptr, size, __location__)
# define TALLOC_ZERO(ctx, size) _talloc_zero_zeronull(ctx, size, __location__)
# define TALLOC_ZERO_P(ctx, type) (type *)_talloc_zero_zeronull(ctx, sizeof(type), #type)
# define TALLOC_ZERO_ARRAY(ctx, type, count) (type *)_talloc_zero_array_zeronull(ctx, sizeof(type), count, #type)
2007-08-29 01:23:31 +00:00
# define TALLOC_SIZE(ctx, size) talloc_zeronull(ctx, size, __location__)
# define TALLOC_ZERO_SIZE(ctx, size) _talloc_zero_zeronull(ctx, size, __location__)
# else
# define TALLOC(ctx, size) talloc_named_const(ctx, size, __location__)
# define TALLOC_P(ctx, type) (type *)talloc_named_const(ctx, sizeof(type), #type)
# define TALLOC_ARRAY(ctx, type, count) (type *)_talloc_array(ctx, sizeof(type), count, #type)
# define TALLOC_MEMDUP(ctx, ptr, size) _talloc_memdup(ctx, ptr, size, __location__)
# define TALLOC_ZERO(ctx, size) _talloc_zero(ctx, size, __location__)
# define TALLOC_ZERO_P(ctx, type) (type *)_talloc_zero(ctx, sizeof(type), #type)
# define TALLOC_ZERO_ARRAY(ctx, type, count) (type *)_talloc_zero_array(ctx, sizeof(type), count, #type)
2007-08-29 01:48:46 +00:00
# define TALLOC_SIZE(ctx, size) talloc_named_const(ctx, size, __location__)
2007-08-29 01:23:31 +00:00
# define TALLOC_ZERO_SIZE(ctx, size) _talloc_zero(ctx, size, __location__)
# endif
2005-05-03 07:33:49 +00:00
# define TALLOC_REALLOC(ctx, ptr, count) _talloc_realloc(ctx, ptr, count, __location__)
# define TALLOC_REALLOC_ARRAY(ctx, ptr, type, count) (type *)_talloc_realloc_array(ctx, ptr, sizeof(type), count, #type)
# define talloc_destroy(ctx) talloc_free(ctx)
2005-08-29 14:55:40 +00:00
# define TALLOC_FREE(ctx) do { if ((ctx) != NULL) {talloc_free(ctx); ctx=NULL;} } while(0)
2005-05-03 07:33:49 +00:00
2008-02-28 15:49:57 +01:00
/* only define PARANOID_MALLOC_CHECKER with --enable-developer */
2005-05-31 13:46:45 +00:00
2008-02-28 15:49:57 +01:00
# if defined(DEVELOPER)
2005-05-04 16:19:23 +00:00
# define PARANOID_MALLOC_CHECKER 1
# endif
2004-12-07 18:25:53 +00:00
2005-05-03 07:33:49 +00:00
# if defined(PARANOID_MALLOC_CHECKER)
2004-12-07 18:25:53 +00:00
# define PRS_ALLOC_MEM(ps, type, count) (type *)prs_alloc_mem_((ps),sizeof(type),(count))
2005-03-23 23:26:33 +00:00
2004-12-07 18:25:53 +00:00
/* Get medieval on our ass about malloc.... */
/* Restrictions on malloc/realloc/calloc. */
# ifdef malloc
# undef malloc
# endif
# define malloc(s) __ERROR_DONT_USE_MALLOC_DIRECTLY
# ifdef realloc
# undef realloc
# endif
# define realloc(p,s) __ERROR_DONT_USE_REALLOC_DIRECTLY
# ifdef calloc
# undef calloc
# endif
# define calloc(n,s) __ERROR_DONT_USE_CALLOC_DIRECTLY
# ifdef strndup
# undef strndup
# endif
# define strndup(s,n) __ERROR_DONT_USE_STRNDUP_DIRECTLY
# ifdef strdup
# undef strdup
# endif
# define strdup(s) __ERROR_DONT_USE_STRDUP_DIRECTLY
# define SMB_MALLOC(s) malloc_(s)
# define SMB_MALLOC_P(type) (type *)malloc_(sizeof(type))
# define SMB_STRDUP(s) smb_xstrdup(s)
# define SMB_STRNDUP(s,n) smb_xstrndup(s,n)
# else
# define PRS_ALLOC_MEM(ps, type, count) (type *)prs_alloc_mem((ps),sizeof(type),(count))
/* Regular malloc code. */
# define SMB_MALLOC(s) malloc(s)
# define SMB_MALLOC_P(type) (type *)malloc(sizeof(type))
# define SMB_STRDUP(s) strdup(s)
# define SMB_STRNDUP(s,n) strndup(s,n)
# endif
2005-04-10 15:26:37 +00:00
# define ADD_TO_ARRAY(mem_ctx, type, elem, array, num) \
do { \
* ( array ) = ( ( mem_ctx ) ! = NULL ) ? \
TALLOC_REALLOC_ARRAY ( mem_ctx , ( * ( array ) ) , type , ( * ( num ) ) + 1 ) : \
SMB_REALLOC_ARRAY ( ( * ( array ) ) , type , ( * ( num ) ) + 1 ) ; \
SMB_ASSERT ( ( * ( array ) ) ! = NULL ) ; \
( * ( array ) ) [ * ( num ) ] = ( elem ) ; \
( * ( num ) ) + = 1 ; \
} while ( 0 )
2005-04-15 13:41:49 +00:00
# define ADD_TO_LARGE_ARRAY(mem_ctx, type, elem, array, num, size) \
2006-07-11 18:01:26 +00:00
add_to_large_array ( ( mem_ctx ) , sizeof ( type ) , & ( elem ) , ( void * ) ( array ) , ( num ) , ( size ) ) ;
2005-04-15 13:41:49 +00:00
2007-10-10 15:34:30 -05:00
# ifndef ISDOT
# define ISDOT(p) (*(p) == '.' && *((p) + 1) == '\0')
# endif /* ISDOT */
# ifndef ISDOTDOT
# define ISDOTDOT(p) (*(p) == '.' && *((p) + 1) == '.' && *((p) + 2) == '\0')
# endif /* ISDOTDOT */
2008-01-09 17:32:26 -08:00
# ifndef toupper_ascii_fast
/* Warning - this must only be called with 0 <= c < 128. IT WILL
* GIVE GARBAGE if c > 128 or c < 0. JRA .
*/
extern char toupper_ascii_fast_table [ ] ;
# define toupper_ascii_fast(c) toupper_ascii_fast_table[(unsigned int)(c)];
# endif
# endif /* _SMB_MACROS_H */