1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-25 06:04:04 +03:00

r16603: Klockwork #2028. Fix null deref on error path.

Jeremy.
(This used to be commit 067feef34388e93ded8db7fd3b4a6a4b752a3059)
This commit is contained in:
Jeremy Allison 2006-06-28 02:22:28 +00:00 committed by Gerald (Jerry) Carter
parent 107698dd0e
commit 5fb4cc9dff

View File

@ -225,7 +225,9 @@ static int key_printers_fetch_keys( const char *key, REGSUBKEY_CTR *subkeys )
/* get information for a specific printer */ /* get information for a specific printer */
reg_split_path( printers_key, &printername, &printerdatakey ); if (!reg_split_path( printers_key, &printername, &printerdatakey )) {
return -1;
}
/* validate the printer name */ /* validate the printer name */
@ -314,7 +316,9 @@ static BOOL key_printers_store_keys( const char *key, REGSUBKEY_CTR *subkeys )
return add_printers_by_registry( subkeys ); return add_printers_by_registry( subkeys );
} }
reg_split_path( printers_key, &printername, &printerdatakey ); if (!reg_split_path( printers_key, &printername, &printerdatakey )) {
return False;
}
/* lookup the printer */ /* lookup the printer */
@ -482,7 +486,10 @@ static int key_printers_fetch_values( const char *key, REGVAL_CTR *values )
/* lookup the printer object */ /* lookup the printer object */
reg_split_path( printers_key, &printername, &printerdatakey ); if (!reg_split_path( printers_key, &printername, &printerdatakey )) {
return -1;
}
if ( !W_ERROR_IS_OK( get_a_printer(NULL, &printer, 2, printername) ) ) if ( !W_ERROR_IS_OK( get_a_printer(NULL, &printer, 2, printername) ) )
goto done; goto done;
@ -672,7 +679,9 @@ static BOOL key_printers_store_values( const char *key, REGVAL_CTR *values )
return regdb_store_values( KEY_WINNT_PRINTERS, values ); return regdb_store_values( KEY_WINNT_PRINTERS, values );
} }
reg_split_path( printers_key, &printername, &keyname ); if (!reg_split_path( printers_key, &printername, &keyname )) {
return False;
}
if ( !W_ERROR_IS_OK(get_a_printer(NULL, &printer, 2, printername) ) ) if ( !W_ERROR_IS_OK(get_a_printer(NULL, &printer, 2, printername) ) )
return False; return False;
@ -754,7 +763,9 @@ static int key_driver_fetch_keys( const char *key, REGSUBKEY_CTR *subkeys )
pstrcpy( key2, keystr ); pstrcpy( key2, keystr );
keystr = key2; keystr = key2;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
/* sanity check */ /* sanity check */
@ -777,7 +788,9 @@ static int key_driver_fetch_keys( const char *key, REGSUBKEY_CTR *subkeys )
/* more of the key path to process */ /* more of the key path to process */
keystr = subkeypath; keystr = subkeypath;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
/* ...\Print\Environements\...\Drivers\ */ /* ...\Print\Environements\...\Drivers\ */
@ -809,7 +822,9 @@ static int key_driver_fetch_keys( const char *key, REGSUBKEY_CTR *subkeys )
if ( strequal(base, "Print Processors") ) { if ( strequal(base, "Print Processors") ) {
keystr = subkeypath; keystr = subkeypath;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
/* no subkeys below this point */ /* no subkeys below this point */
@ -824,7 +839,10 @@ static int key_driver_fetch_keys( const char *key, REGSUBKEY_CTR *subkeys )
/* only dealing with drivers from here on out */ /* only dealing with drivers from here on out */
keystr = subkeypath; keystr = subkeypath;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
version = atoi(&base[strlen(base)-1]); version = atoi(&base[strlen(base)-1]);
switch (env_index) { switch (env_index) {
@ -947,7 +965,9 @@ static int driver_arch_fetch_values( char *key, REGVAL_CTR *values )
NT_PRINTER_DRIVER_INFO_LEVEL driver_ctr; NT_PRINTER_DRIVER_INFO_LEVEL driver_ctr;
WERROR w_result; WERROR w_result;
reg_split_path( key, &base, &subkeypath ); if (!reg_split_path( key, &base, &subkeypath )) {
return -1;
}
/* no values in 'Environments\Drivers\Windows NT x86' */ /* no values in 'Environments\Drivers\Windows NT x86' */
@ -964,7 +984,9 @@ static int driver_arch_fetch_values( char *key, REGVAL_CTR *values )
fstrcpy( arch_environment, base ); fstrcpy( arch_environment, base );
keystr = subkeypath; keystr = subkeypath;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
if ( strequal(base, "Print Processors") ) if ( strequal(base, "Print Processors") )
return 0; return 0;
@ -981,7 +1003,9 @@ static int driver_arch_fetch_values( char *key, REGVAL_CTR *values )
The subkey name has to be Version-XX */ The subkey name has to be Version-XX */
keystr = subkeypath; keystr = subkeypath;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
if ( !subkeypath ) if ( !subkeypath )
return 0; return 0;
@ -991,7 +1015,9 @@ static int driver_arch_fetch_values( char *key, REGVAL_CTR *values )
/* BEGIN PRINTER DRIVER NAME BLOCK */ /* BEGIN PRINTER DRIVER NAME BLOCK */
keystr = subkeypath; keystr = subkeypath;
reg_split_path( keystr, &base, &subkeypath ); if (!reg_split_path( keystr, &base, &subkeypath )) {
return -1;
}
/* don't go any deeper for now */ /* don't go any deeper for now */