1998-11-05 19:51:34 +03:00
/*
2002-01-30 09:08:46 +03:00
* Unix SMB / CIFS implementation .
* SMB parameters and setup
1998-11-05 19:51:34 +03:00
* Copyright ( C ) Andrew Tridgell 1992 - 1998 Modified by Jeremy Allison 1995.
*
* 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 the Free
* Software Foundation ; either version 2 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 along with
* this program ; if not , write to the Free Software Foundation , Inc . , 675
* Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
2003-09-08 18:00:51 +04:00
# ifndef MAP_FAILED
# define MAP_FAILED ((void *)-1)
# endif
1998-11-05 19:51:34 +03:00
static int gotalarm ;
/***************************************************************
Signal function to tell us we timed out .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static void gotalarm_sig ( void )
{
2004-09-01 05:33:55 +04:00
gotalarm = 1 ;
1998-11-05 19:51:34 +03:00
}
/***************************************************************
Lock or unlock a fd for a known lock type . Abandon after waitsecs
seconds .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL do_file_lock ( int fd , int waitsecs , int type )
{
2004-09-01 05:33:55 +04:00
SMB_STRUCT_FLOCK lock ;
int ret ;
void ( * oldsig_handler ) ( int ) ;
gotalarm = 0 ;
oldsig_handler = CatchSignal ( SIGALRM , SIGNAL_CAST gotalarm_sig ) ;
lock . l_type = type ;
lock . l_whence = SEEK_SET ;
lock . l_start = 0 ;
lock . l_len = 1 ;
lock . l_pid = 0 ;
alarm ( waitsecs ) ;
/* Note we must *NOT* use sys_fcntl here ! JRA */
ret = fcntl ( fd , SMB_F_SETLKW , & lock ) ;
alarm ( 0 ) ;
CatchSignal ( SIGALRM , SIGNAL_CAST oldsig_handler ) ;
if ( gotalarm ) {
DEBUG ( 0 , ( " do_file_lock: failed to %s file. \n " ,
type = = F_UNLCK ? " unlock " : " lock " ) ) ;
return False ;
}
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
return ( ret = = 0 ) ;
}
1998-11-05 19:51:34 +03:00
/***************************************************************
Lock an fd . Abandon after waitsecs seconds .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL file_lock ( int fd , int type , int secs , int * plock_depth )
{
2004-09-01 05:33:55 +04:00
if ( fd < 0 )
return False ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
( * plock_depth ) + + ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( ( * plock_depth ) = = 0 ) {
if ( ! do_file_lock ( fd , secs , type ) ) {
DEBUG ( 10 , ( " file_lock: locking file failed, error = %s. \n " , strerror ( errno ) ) ) ;
return False ;
}
}
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
return True ;
1998-11-05 19:51:34 +03:00
}
/***************************************************************
Unlock an fd . Abandon after waitsecs seconds .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL file_unlock ( int fd , int * plock_depth )
{
2004-09-01 05:33:55 +04:00
BOOL ret = True ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( * plock_depth = = 1 ) {
ret = do_file_lock ( fd , 5 , F_UNLCK ) ;
}
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
( * plock_depth ) - - ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( ! ret ) {
DEBUG ( 10 , ( " file_unlock: unlocking file failed, error = %s. \n " , strerror ( errno ) ) ) ;
}
return ret ;
1998-11-05 19:51:34 +03:00
}
/***************************************************************
2004-09-01 05:33:55 +04:00
Locks a file for enumeration / modification .
1998-11-05 19:51:34 +03:00
update to be set = True if modification is required .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
1999-12-13 16:27:58 +03:00
void * startfilepwent ( char * pfile , char * s_readbuf , int bufsize ,
1998-11-05 19:51:34 +03:00
int * file_lock_depth , BOOL update )
{
2004-09-01 05:33:55 +04:00
FILE * fp = NULL ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( ! * pfile ) {
DEBUG ( 0 , ( " startfilepwent: No file set \n " ) ) ;
return ( NULL ) ;
}
DEBUG ( 10 , ( " startfilepwent: opening file %s \n " , pfile ) ) ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
fp = sys_fopen ( pfile , update ? " r+b " : " rb " ) ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( fp = = NULL ) {
DEBUG ( 0 , ( " startfilepwent: unable to open file %s \n " , pfile ) ) ;
return NULL ;
}
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
/* Set a buffer to do more efficient reads */
setvbuf ( fp , s_readbuf , _IOFBF , bufsize ) ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( ! file_lock ( fileno ( fp ) , ( update ? F_WRLCK : F_RDLCK ) , 5 , file_lock_depth ) ) {
DEBUG ( 0 , ( " startfilepwent: unable to lock file %s \n " , pfile ) ) ;
fclose ( fp ) ;
return NULL ;
}
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
/* Make sure it is only rw by the owner */
chmod ( pfile , 0600 ) ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
/* We have a lock on the file. */
return ( void * ) fp ;
1998-11-05 19:51:34 +03:00
}
/***************************************************************
End enumeration of the file .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
1999-12-13 16:27:58 +03:00
void endfilepwent ( void * vp , int * file_lock_depth )
1998-11-05 19:51:34 +03:00
{
2004-09-01 05:33:55 +04:00
FILE * fp = ( FILE * ) vp ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
file_unlock ( fileno ( fp ) , file_lock_depth ) ;
fclose ( fp ) ;
DEBUG ( 7 , ( " endfilepwent: closed file. \n " ) ) ;
1998-11-05 19:51:34 +03:00
}
/*************************************************************************
Return the current position in the file list as an SMB_BIG_UINT .
This must be treated as an opaque token .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
1998-11-05 19:51:34 +03:00
SMB_BIG_UINT getfilepwpos ( void * vp )
{
2004-09-01 05:33:55 +04:00
return ( SMB_BIG_UINT ) sys_ftell ( ( FILE * ) vp ) ;
1998-11-05 19:51:34 +03:00
}
/*************************************************************************
Set the current position in the file list from an SMB_BIG_UINT .
This must be treated as an opaque token .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
1998-11-05 19:51:34 +03:00
BOOL setfilepwpos ( void * vp , SMB_BIG_UINT tok )
{
2004-09-01 05:33:55 +04:00
return ! sys_fseek ( ( FILE * ) vp , ( SMB_OFF_T ) tok , SEEK_SET ) ;
1998-11-05 19:51:34 +03:00
}
/*************************************************************************
2004-09-01 05:33:55 +04:00
Gets a line out of a file .
1999-12-13 16:27:58 +03:00
line is of format " xxxx:xxxxxx:xxxxx: " .
1998-11-05 19:51:34 +03:00
lines with " # " at the front are ignored .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
1998-11-05 19:51:34 +03:00
int getfileline ( void * vp , char * linebuf , int linebuf_size )
{
/* Static buffers we will return. */
FILE * fp = ( FILE * ) vp ;
unsigned char c ;
1999-12-13 16:27:58 +03:00
unsigned char * p ;
2004-09-01 05:33:55 +04:00
size_t linebuf_len ;
1998-11-05 19:51:34 +03:00
2004-09-01 05:33:55 +04:00
if ( fp = = NULL ) {
1998-11-05 19:51:34 +03:00
DEBUG ( 0 , ( " getfileline: Bad file pointer. \n " ) ) ;
return - 1 ;
}
/*
* Scan the file , a line at a time .
*/
2004-09-01 05:33:55 +04:00
while ( ! feof ( fp ) ) {
1998-11-05 19:51:34 +03:00
linebuf [ 0 ] = ' \0 ' ;
fgets ( linebuf , linebuf_size , fp ) ;
2004-09-01 05:33:55 +04:00
if ( ferror ( fp ) ) {
1998-11-05 19:51:34 +03:00
return - 1 ;
}
/*
* Check if the string is terminated with a newline - if not
* then we must keep reading and discard until we get one .
*/
linebuf_len = strlen ( linebuf ) ;
2004-09-01 05:33:55 +04:00
if ( linebuf_len = = 0 ) {
2000-08-18 10:27:24 +04:00
linebuf [ 0 ] = ' \0 ' ;
return 0 ;
}
2004-09-01 05:33:55 +04:00
if ( linebuf [ linebuf_len - 1 ] ! = ' \n ' ) {
2000-08-18 10:27:24 +04:00
c = ' \0 ' ;
2004-09-01 05:33:55 +04:00
while ( ! ferror ( fp ) & & ! feof ( fp ) ) {
2000-08-18 10:27:24 +04:00
c = fgetc ( fp ) ;
2004-09-01 05:33:55 +04:00
if ( c = = ' \n ' ) {
2000-08-18 10:27:24 +04:00
break ;
1998-11-05 19:51:34 +03:00
}
}
2004-09-01 05:33:55 +04:00
} else {
2000-08-18 10:27:24 +04:00
linebuf [ linebuf_len - 1 ] = ' \0 ' ;
1998-11-05 19:51:34 +03:00
}
# ifdef DEBUG_PASSWORD
DEBUG ( 100 , ( " getfileline: got line |%s| \n " , linebuf ) ) ;
# endif
2004-09-01 05:33:55 +04:00
if ( ( linebuf [ 0 ] = = 0 ) & & feof ( fp ) ) {
1998-11-05 19:51:34 +03:00
DEBUG ( 4 , ( " getfileline: end of file reached \n " ) ) ;
return 0 ;
}
2004-09-01 05:33:55 +04:00
if ( linebuf [ 0 ] = = ' # ' | | linebuf [ 0 ] = = ' \0 ' ) {
1998-11-05 19:51:34 +03:00
DEBUG ( 6 , ( " getfileline: skipping comment or blank line \n " ) ) ;
continue ;
}
2001-07-04 11:36:09 +04:00
p = ( unsigned char * ) strchr_m ( linebuf , ' : ' ) ;
2004-09-01 05:33:55 +04:00
if ( p = = NULL ) {
1999-12-13 16:27:58 +03:00
DEBUG ( 0 , ( " getfileline: malformed line entry (no :) \n " ) ) ;
continue ;
}
1998-11-05 19:51:34 +03:00
return linebuf_len ;
}
return - 1 ;
}
/****************************************************************************
2004-09-01 05:33:55 +04:00
Read a line from a file with possible \ continuation chars .
Blanks at the start or end of a line are stripped .
The string will be allocated if s2 is NULL .
1998-11-05 19:51:34 +03:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-09-10 16:46:42 +04:00
char * fgets_slash ( char * s2 , int maxlen , XFILE * f )
1998-11-05 19:51:34 +03:00
{
2004-09-01 05:33:55 +04:00
char * s = s2 ;
int len = 0 ;
int c ;
BOOL start_of_line = True ;
if ( x_feof ( f ) ) {
return ( NULL ) ;
}
if ( maxlen < 2 ) {
return ( NULL ) ;
}
if ( ! s2 ) {
maxlen = MIN ( maxlen , 8 ) ;
2004-12-07 21:25:53 +03:00
s = ( char * ) SMB_MALLOC ( maxlen ) ;
2004-09-01 05:33:55 +04:00
}
if ( ! s ) {
return ( NULL ) ;
}
* s = 0 ;
while ( len < maxlen - 1 ) {
c = x_getc ( f ) ;
switch ( c ) {
case ' \r ' :
break ;
case ' \n ' :
while ( len > 0 & & s [ len - 1 ] = = ' ' ) {
s [ - - len ] = 0 ;
}
if ( len > 0 & & s [ len - 1 ] = = ' \\ ' ) {
s [ - - len ] = 0 ;
start_of_line = True ;
break ;
}
return ( s ) ;
case EOF :
if ( len < = 0 & & ! s2 ) {
SAFE_FREE ( s ) ;
}
return ( len > 0 ? s : NULL ) ;
case ' ' :
if ( start_of_line ) {
break ;
}
default :
start_of_line = False ;
s [ len + + ] = c ;
s [ len ] = 0 ;
}
if ( ! s2 & & len > maxlen - 3 ) {
char * t ;
2001-08-12 21:30:01 +04:00
2004-09-01 05:33:55 +04:00
maxlen * = 2 ;
2004-12-07 21:25:53 +03:00
t = ( char * ) SMB_REALLOC ( s , maxlen ) ;
2004-09-01 05:33:55 +04:00
if ( ! t ) {
DEBUG ( 0 , ( " fgets_slash: failed to expand buffer! \n " ) ) ;
SAFE_FREE ( s ) ;
return ( NULL ) ;
} else {
s = t ;
}
}
}
return ( s ) ;
1998-11-05 19:51:34 +03:00
}
2000-04-16 10:19:11 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Load from a pipe into memory .
2000-04-16 10:19:11 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2000-04-16 15:00:21 +04:00
char * file_pload ( char * syscmd , size_t * size )
2000-04-16 10:19:11 +04:00
{
2000-04-16 15:00:21 +04:00
int fd , n ;
2001-08-12 21:30:01 +04:00
char * p , * tp ;
2000-04-16 15:00:21 +04:00
pstring buf ;
size_t total ;
fd = sys_popen ( syscmd ) ;
2004-09-01 05:33:55 +04:00
if ( fd = = - 1 ) {
return NULL ;
}
2000-04-16 15:00:21 +04:00
p = NULL ;
total = 0 ;
while ( ( n = read ( fd , buf , sizeof ( buf ) ) ) > 0 ) {
2004-12-07 21:25:53 +03:00
tp = SMB_REALLOC ( p , total + n + 1 ) ;
2001-08-12 21:30:01 +04:00
if ( ! tp ) {
2003-02-24 06:09:08 +03:00
DEBUG ( 0 , ( " file_pload: failed to expand buffer! \n " ) ) ;
2000-04-16 15:00:21 +04:00
close ( fd ) ;
2001-09-17 06:19:44 +04:00
SAFE_FREE ( p ) ;
2000-04-16 15:00:21 +04:00
return NULL ;
2004-09-01 05:33:55 +04:00
} else {
p = tp ;
}
2000-04-16 15:00:21 +04:00
memcpy ( p + total , buf , n ) ;
total + = n ;
}
2000-04-30 19:13:15 +04:00
if ( p ) p [ total ] = 0 ;
2000-04-16 15:00:21 +04:00
2003-02-24 06:09:08 +03:00
/* FIXME: Perhaps ought to check that the command completed
* successfully ( returned 0 ) ; if not the data may be
* truncated . */
2000-04-16 15:00:21 +04:00
sys_pclose ( fd ) ;
2004-09-01 05:33:55 +04:00
if ( size ) {
* size = total ;
}
2000-04-16 15:00:21 +04:00
return p ;
}
/****************************************************************************
2004-09-01 05:33:55 +04:00
Load a file into memory from a fd .
2001-04-13 04:37:00 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
char * fd_load ( int fd , size_t * size )
2000-04-16 15:00:21 +04:00
{
2000-04-16 10:19:11 +04:00
SMB_STRUCT_STAT sbuf ;
2000-04-16 15:00:21 +04:00
char * p ;
2000-04-18 06:17:46 +04:00
2004-09-01 05:33:55 +04:00
if ( sys_fstat ( fd , & sbuf ) ! = 0 ) {
return NULL ;
}
2000-04-16 10:19:11 +04:00
2004-12-07 21:25:53 +03:00
p = ( char * ) SMB_MALLOC ( sbuf . st_size + 1 ) ;
2004-09-01 05:33:55 +04:00
if ( ! p ) {
return NULL ;
}
2000-04-16 10:19:11 +04:00
2000-04-16 15:00:21 +04:00
if ( read ( fd , p , sbuf . st_size ) ! = sbuf . st_size ) {
2001-09-17 06:19:44 +04:00
SAFE_FREE ( p ) ;
2000-04-16 10:19:11 +04:00
return NULL ;
}
2000-04-16 15:00:21 +04:00
p [ sbuf . st_size ] = 0 ;
2000-04-16 10:19:11 +04:00
2004-09-01 05:33:55 +04:00
if ( size ) {
* size = sbuf . st_size ;
}
2000-04-16 15:00:21 +04:00
return p ;
}
2001-04-13 04:37:00 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Load a file into memory .
2001-04-13 04:37:00 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-09-29 15:51:40 +04:00
char * file_load ( const char * fname , size_t * size )
2001-04-13 04:37:00 +04:00
{
int fd ;
char * p ;
2004-09-01 05:33:55 +04:00
if ( ! fname | | ! * fname ) {
return NULL ;
}
2001-04-13 04:37:00 +04:00
fd = open ( fname , O_RDONLY ) ;
2004-09-01 05:33:55 +04:00
if ( fd = = - 1 ) {
return NULL ;
}
2001-04-13 04:37:00 +04:00
p = fd_load ( fd , size ) ;
close ( fd ) ;
return p ;
}
2001-10-03 16:18:20 +04:00
/*******************************************************************
2004-09-01 05:33:55 +04:00
mmap ( if possible ) or read a file .
2001-10-03 16:18:20 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-10-03 16:18:20 +04:00
void * map_file ( char * fname , size_t size )
{
size_t s2 = 0 ;
void * p = NULL ;
# ifdef HAVE_MMAP
2004-09-01 05:33:55 +04:00
int fd ;
fd = open ( fname , O_RDONLY , 0 ) ;
if ( fd = = - 1 ) {
DEBUG ( 2 , ( " map_file: Failed to load %s - %s \n " , fname , strerror ( errno ) ) ) ;
return NULL ;
}
p = mmap ( NULL , size , PROT_READ , MAP_SHARED | MAP_FILE , fd , 0 ) ;
close ( fd ) ;
if ( p = = MAP_FAILED ) {
DEBUG ( 1 , ( " map_file: Failed to mmap %s - %s \n " , fname , strerror ( errno ) ) ) ;
return NULL ;
2001-10-03 16:18:20 +04:00
}
# endif
if ( ! p ) {
p = file_load ( fname , & s2 ) ;
2004-09-01 05:33:55 +04:00
if ( ! p ) {
return NULL ;
}
2002-07-15 14:35:28 +04:00
if ( s2 ! = size ) {
2004-09-01 05:33:55 +04:00
DEBUG ( 1 , ( " map_file: incorrect size for %s - got %lu expected %lu \n " ,
2003-07-25 08:24:40 +04:00
fname , ( unsigned long ) s2 , ( unsigned long ) size ) ) ;
2004-09-01 05:33:55 +04:00
SAFE_FREE ( p ) ;
2001-10-03 16:18:20 +04:00
return NULL ;
}
}
return p ;
}
2000-04-16 15:00:21 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Parse a buffer into lines .
2000-04-16 15:00:21 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-07-04 11:15:53 +04:00
static char * * file_lines_parse ( char * p , size_t size , int * numlines )
2000-04-16 15:00:21 +04:00
{
int i ;
char * s , * * ret ;
2004-09-01 05:33:55 +04:00
if ( ! p ) {
return NULL ;
}
2000-04-16 15:00:21 +04:00
2000-04-16 10:19:11 +04:00
for ( s = p , i = 0 ; s < p + size ; s + + ) {
if ( s [ 0 ] = = ' \n ' ) i + + ;
}
2004-12-07 21:25:53 +03:00
ret = SMB_MALLOC_ARRAY ( char * , i + 2 ) ;
2000-04-16 10:19:11 +04:00
if ( ! ret ) {
2001-09-17 06:19:44 +04:00
SAFE_FREE ( p ) ;
2000-04-16 10:19:11 +04:00
return NULL ;
}
2000-04-16 13:40:02 +04:00
memset ( ret , 0 , sizeof ( ret [ 0 ] ) * ( i + 2 ) ) ;
2004-09-01 05:33:55 +04:00
if ( numlines ) {
* numlines = i ;
}
2000-04-16 10:19:11 +04:00
ret [ 0 ] = p ;
for ( s = p , i = 0 ; s < p + size ; s + + ) {
if ( s [ 0 ] = = ' \n ' ) {
s [ 0 ] = 0 ;
i + + ;
ret [ i ] = s + 1 ;
}
2004-09-01 05:33:55 +04:00
if ( s [ 0 ] = = ' \r ' ) {
s [ 0 ] = 0 ;
}
2000-04-16 10:19:11 +04:00
}
return ret ;
}
2000-04-16 15:00:21 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Load a file into memory and return an array of pointers to lines in the file
must be freed with file_lines_free ( ) .
2000-04-16 15:00:21 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-09-29 15:51:40 +04:00
char * * file_lines_load ( const char * fname , int * numlines )
2000-04-16 15:00:21 +04:00
{
char * p ;
size_t size ;
p = file_load ( fname , & size ) ;
2004-09-01 05:33:55 +04:00
if ( ! p ) {
return NULL ;
}
2000-04-16 15:00:21 +04:00
2001-07-04 11:15:53 +04:00
return file_lines_parse ( p , size , numlines ) ;
2000-04-16 15:00:21 +04:00
}
2001-04-13 04:37:00 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Load a fd into memory and return an array of pointers to lines in the file
must be freed with file_lines_free ( ) . If convert is true calls unix_to_dos on
the list .
2001-04-13 04:37:00 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-07-04 11:15:53 +04:00
char * * fd_lines_load ( int fd , int * numlines )
2001-04-13 04:37:00 +04:00
{
char * p ;
size_t size ;
p = fd_load ( fd , & size ) ;
2004-09-01 05:33:55 +04:00
if ( ! p ) {
return NULL ;
}
2001-04-13 04:37:00 +04:00
2001-07-04 11:15:53 +04:00
return file_lines_parse ( p , size , numlines ) ;
2001-04-13 04:37:00 +04:00
}
2000-04-16 15:00:21 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Load a pipe into memory and return an array of pointers to lines in the data
must be freed with file_lines_free ( ) .
2000-04-16 15:00:21 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2001-07-04 11:15:53 +04:00
char * * file_lines_pload ( char * syscmd , int * numlines )
2000-04-16 15:00:21 +04:00
{
char * p ;
size_t size ;
p = file_pload ( syscmd , & size ) ;
2004-09-01 05:33:55 +04:00
if ( ! p ) {
return NULL ;
}
2000-04-16 15:00:21 +04:00
2001-07-04 11:15:53 +04:00
return file_lines_parse ( p , size , numlines ) ;
2000-04-16 15:00:21 +04:00
}
2000-04-16 10:19:11 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Free lines loaded with file_lines_load .
2000-04-16 10:19:11 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2000-04-16 10:19:11 +04:00
void file_lines_free ( char * * lines )
{
2004-09-01 05:33:55 +04:00
if ( ! lines ) {
return ;
}
2001-09-17 06:19:44 +04:00
SAFE_FREE ( lines [ 0 ] ) ;
SAFE_FREE ( lines ) ;
2000-04-16 10:19:11 +04:00
}
2000-04-16 13:40:02 +04:00
2000-04-16 15:17:19 +04:00
/****************************************************************************
2004-09-01 05:33:55 +04:00
Take a list of lines and modify them to produce a list where \ continues
a line .
2000-04-16 15:17:19 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2004-09-01 05:33:55 +04:00
2000-04-16 15:17:19 +04:00
void file_lines_slashcont ( char * * lines )
{
int i , j ;
for ( i = 0 ; lines [ i ] ; ) {
int len = strlen ( lines [ i ] ) ;
if ( lines [ i ] [ len - 1 ] = = ' \\ ' ) {
lines [ i ] [ len - 1 ] = ' ' ;
if ( lines [ i + 1 ] ) {
char * p = & lines [ i ] [ len ] ;
2004-09-01 05:33:55 +04:00
while ( p < lines [ i + 1 ] ) {
* p + + = ' ' ;
}
for ( j = i + 1 ; lines [ j ] ; j + + ) {
lines [ j ] = lines [ j + 1 ] ;
}
2000-04-16 15:17:19 +04:00
}
} else {
i + + ;
}
}
}
2001-10-11 11:42:52 +04:00
2004-09-01 05:33:55 +04:00
/****************************************************************************
Save a lump of data into a file . Mostly used for debugging .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2001-10-11 11:42:52 +04:00
BOOL file_save ( const char * fname , void * packet , size_t length )
{
int fd ;
fd = open ( fname , O_WRONLY | O_CREAT | O_TRUNC , 0644 ) ;
if ( fd = = - 1 ) {
return False ;
}
2003-02-24 06:09:08 +03:00
if ( write ( fd , packet , length ) ! = ( size_t ) length ) {
2001-10-11 11:42:52 +04:00
return False ;
}
close ( fd ) ;
return True ;
}