Line data Source code
1 : /* 2 : Unix SMB/CIFS implementation. 3 : Samba utility functions 4 : 5 : Copyright (C) Andrew Tridgell 1992-2001 6 : Copyright (C) Simo Sorce 2001-2002 7 : Copyright (C) Martin Pool 2003 8 : Copyright (C) James Peach 2005 9 : 10 : This program is free software; you can redistribute it and/or modify 11 : it under the terms of the GNU General Public License as published by 12 : the Free Software Foundation; either version 3 of the License, or 13 : (at your option) any later version. 14 : 15 : This program is distributed in the hope that it will be useful, 16 : but WITHOUT ANY WARRANTY; without even the implied warranty of 17 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 : GNU General Public License for more details. 19 : 20 : You should have received a copy of the GNU General Public License 21 : along with this program. If not, see <http://www.gnu.org/licenses/>. 22 : */ 23 : 24 : #include "replace.h" 25 : #include "system/locale.h" 26 : #include "lib/util/samba_util.h" 27 : 28 : /** 29 : Do a case-insensitive, whitespace-ignoring ASCII string compare. 30 : **/ 31 8333040603 : _PUBLIC_ int strwicmp(const char *psz1, const char *psz2) 32 : { 33 : /* if BOTH strings are NULL, return TRUE, if ONE is NULL return */ 34 : /* appropriate value. */ 35 8333040603 : if (psz1 == psz2) 36 3136 : return (0); 37 8332875421 : else if (psz1 == NULL) 38 0 : return (-1); 39 8332875421 : else if (psz2 == NULL) 40 0 : return (1); 41 : 42 : /* sync the strings on first non-whitespace */ 43 11584985 : while (1) { 44 9776102713 : while (isspace((int)*psz1)) 45 81133350 : psz1++; 46 9773200051 : while (isspace((int)*psz2)) 47 78230688 : psz2++; 48 : 49 : /* 50 : * This does not do a genuine multi-byte comparison, 51 : * instead it just uses the fast-path for ASCII in 52 : * these common routines 53 : */ 54 9694969363 : if (toupper_m((unsigned char)*psz1) != toupper_m((unsigned char)*psz2) 55 1390759352 : || *psz1 == '\0' 56 1362093942 : || *psz2 == '\0') 57 : break; 58 1362093942 : psz1++; 59 1362093942 : psz2++; 60 : } 61 8332875421 : return (*psz1 - *psz2); 62 : } 63 : 64 : /** 65 : String replace. 66 : NOTE: oldc and newc must be 7 bit characters 67 : **/ 68 660974 : void string_replace( char *s, char oldc, char newc ) 69 : { 70 14582466 : while (*s != '\0') { 71 111834 : size_t c_size; 72 13921492 : next_codepoint(s, &c_size); 73 : 74 13921492 : if (c_size == 1) { 75 13921492 : if (*s == oldc) { 76 1215938 : *s = newc; 77 : } 78 : } 79 13921492 : s += c_size; 80 : } 81 660974 : } 82 : 83 : 84 : /** 85 : Paranoid strcpy into a buffer of given length (includes terminating 86 : zero. Strips out all but 'a-Z0-9' and the character in other_safe_chars 87 : and replaces with '_'. Deliberately does *NOT* check for multibyte 88 : characters. Treats src as an array of bytes, not as a multibyte 89 : string. Any byte >0x7f is automatically converted to '_'. 90 : other_safe_chars must also contain an ascii string (bytes<0x7f). 91 : **/ 92 : 93 113406 : char *alpha_strcpy(char *dest, 94 : const char *src, 95 : const char *other_safe_chars, 96 : size_t maxlength) 97 : { 98 1799 : size_t len, i; 99 : 100 113406 : if (!dest) { 101 0 : smb_panic("ERROR: NULL dest in alpha_strcpy"); 102 : } 103 : 104 113406 : if (!src) { 105 0 : *dest = 0; 106 0 : return dest; 107 : } 108 : 109 113406 : len = strlen(src); 110 113406 : if (len >= maxlength) 111 0 : len = maxlength - 1; 112 : 113 113406 : if (!other_safe_chars) 114 12 : other_safe_chars = ""; 115 : 116 1018325 : for(i = 0; i < len; i++) { 117 904919 : int val = (src[i] & 0xff); 118 904919 : if (val > 0x7f) { 119 0 : dest[i] = '_'; 120 0 : continue; 121 : } 122 904919 : if (isupper(val) || islower(val) || 123 356332 : isdigit(val) || strchr(other_safe_chars, val)) 124 902971 : dest[i] = src[i]; 125 : else 126 1948 : dest[i] = '_'; 127 : } 128 : 129 113406 : dest[i] = '\0'; 130 : 131 113406 : return dest; 132 : } 133 : 134 59601 : char *talloc_alpha_strcpy(TALLOC_CTX *mem_ctx, 135 : const char *src, 136 : const char *other_safe_chars) 137 : { 138 59601 : char *dest = NULL; 139 937 : size_t slen; 140 : 141 59601 : if (src == NULL) { 142 0 : return NULL; 143 : } 144 : 145 59601 : slen = strlen(src); 146 : 147 59601 : dest = talloc_zero_size(mem_ctx, slen + 1); 148 59601 : if (dest == NULL) { 149 0 : return NULL; 150 : } 151 : 152 59601 : alpha_strcpy(dest, src, other_safe_chars, slen + 1); 153 59601 : return dest; 154 : }