2011-04-08 06:02:40 +04:00
/*
Unix SMB / CIFS implementation .
Samba utility functions
Copyright ( C ) Andrew Tridgell 1992 - 2001
Copyright ( C ) Simo Sorce 2001 - 2002
Copyright ( C ) Martin Pool 2003
Copyright ( C ) James Peach 2005
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 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
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
2022-06-25 12:07:44 +03:00
# include "replace.h"
# include "system/locale.h"
# include "lib/util/samba_util.h"
2011-04-08 06:02:40 +04:00
/**
2014-03-19 23:56:42 +04:00
Do a case - insensitive , whitespace - ignoring ASCII string compare .
2011-04-08 06:02:40 +04:00
* */
_PUBLIC_ int strwicmp ( const char * psz1 , const char * psz2 )
{
/* if BOTH strings are NULL, return TRUE, if ONE is NULL return */
/* appropriate value. */
if ( psz1 = = psz2 )
return ( 0 ) ;
else if ( psz1 = = NULL )
return ( - 1 ) ;
else if ( psz2 = = NULL )
return ( 1 ) ;
/* sync the strings on first non-whitespace */
while ( 1 ) {
while ( isspace ( ( int ) * psz1 ) )
psz1 + + ;
while ( isspace ( ( int ) * psz2 ) )
psz2 + + ;
2014-03-19 23:56:42 +04:00
/*
* This does not do a genuine multi - byte comparison ,
* instead it just uses the fast - path for ASCII in
* these common routines
*/
2011-07-20 00:19:29 +04:00
if ( toupper_m ( ( unsigned char ) * psz1 ) ! = toupper_m ( ( unsigned char ) * psz2 )
2011-04-08 06:02:40 +04:00
| | * psz1 = = ' \0 '
| | * psz2 = = ' \0 ' )
break ;
psz1 + + ;
psz2 + + ;
}
return ( * psz1 - * psz2 ) ;
}
2011-04-08 06:55:28 +04:00
2011-04-08 07:04:26 +04:00
/**
String replace .
NOTE : oldc and newc must be 7 bit characters
* */
void string_replace ( char * s , char oldc , char newc )
{
2020-09-28 13:31:13 +03:00
while ( * s ! = ' \0 ' ) {
2011-04-08 07:04:26 +04:00
size_t c_size ;
2020-09-28 13:31:13 +03:00
next_codepoint ( s , & c_size ) ;
2011-04-08 07:04:26 +04:00
if ( c_size = = 1 ) {
2020-09-28 13:31:13 +03:00
if ( * s = = oldc ) {
* s = newc ;
2011-04-08 07:04:26 +04:00
}
}
2020-09-28 13:31:13 +03:00
s + = c_size ;
2011-04-08 07:04:26 +04:00
}
}
2011-04-14 09:48:00 +04:00
/**
Paranoid strcpy into a buffer of given length ( includes terminating
zero . Strips out all but ' a - Z0 - 9 ' and the character in other_safe_chars
and replaces with ' _ ' . Deliberately does * NOT * check for multibyte
characters . Treats src as an array of bytes , not as a multibyte
string . Any byte > 0x7f is automatically converted to ' _ ' .
other_safe_chars must also contain an ascii string ( bytes < 0x7f ) .
* */
char * alpha_strcpy ( char * dest ,
const char * src ,
const char * other_safe_chars ,
size_t maxlength )
{
size_t len , i ;
if ( ! dest ) {
smb_panic ( " ERROR: NULL dest in alpha_strcpy " ) ;
}
if ( ! src ) {
* dest = 0 ;
return dest ;
}
len = strlen ( src ) ;
if ( len > = maxlength )
len = maxlength - 1 ;
if ( ! other_safe_chars )
other_safe_chars = " " ;
for ( i = 0 ; i < len ; i + + ) {
int val = ( src [ i ] & 0xff ) ;
if ( val > 0x7f ) {
dest [ i ] = ' _ ' ;
continue ;
}
if ( isupper ( val ) | | islower ( val ) | |
isdigit ( val ) | | strchr ( other_safe_chars , val ) )
dest [ i ] = src [ i ] ;
else
dest [ i ] = ' _ ' ;
}
dest [ i ] = ' \0 ' ;
return dest ;
}
2020-01-17 21:15:22 +03:00
char * talloc_alpha_strcpy ( TALLOC_CTX * mem_ctx ,
const char * src ,
const char * other_safe_chars )
{
char * dest = NULL ;
size_t slen ;
if ( src = = NULL ) {
return NULL ;
}
slen = strlen ( src ) ;
dest = talloc_zero_size ( mem_ctx , slen + 1 ) ;
if ( dest = = NULL ) {
return NULL ;
}
alpha_strcpy ( dest , src , other_safe_chars , slen + 1 ) ;
return dest ;
}