diff --git a/source/printing/nt_printing.c b/source/printing/nt_printing.c index 47e0af96334..b3a2ca5893b 100644 --- a/source/printing/nt_printing.c +++ b/source/printing/nt_printing.c @@ -2560,6 +2560,38 @@ int add_new_printer_key( NT_PRINTER_DATA *data, const char *name ) return key_index; } +/**************************************************************************** + search for a registry key name in the existing printer data + ***************************************************************************/ + +int delete_printer_key( NT_PRINTER_DATA *data, const char *name ) +{ + int i; + NT_PRINTER_KEY *printer_key; + + for ( i=0; inum_keys; i++ ) { + if ( strequal( data->keys[i].name, name ) ) { + + /* cleanup memory */ + + printer_key = &data->keys[i]; + SAFE_FREE( printer_key->name ); + regval_ctr_destroy( &printer_key->values ); + + /* if not the end of the array, move remaining elements down one slot */ + + data->num_keys--; + if ( data->num_keys && (i < data->num_keys) ) + memmove( &data->keys[i], &data->keys[i+1], sizeof(NT_PRINTER_KEY)*(data->num_keys-i) ); + + break; + } + } + + + return data->num_keys; +} + /**************************************************************************** search for a registry key name in the existing printer data ***************************************************************************/ diff --git a/source/registry/reg_printing.c b/source/registry/reg_printing.c index 09a0dd0c346..60ae68c6665 100644 --- a/source/registry/reg_printing.c +++ b/source/registry/reg_printing.c @@ -290,8 +290,9 @@ static BOOL key_printers_store_keys( const char *key, REGSUBKEY_CTR *subkeys ) char *printers_key; char *printername, *printerdatakey; NT_PRINTER_INFO_LEVEL *printer = NULL; - int i, num_subkeys; + int i, num_subkeys, num_existing_keys; char *subkeyname; + fstring *existing_subkeys = NULL; printers_key = strip_printers_prefix( key ); @@ -309,12 +310,29 @@ static BOOL key_printers_store_keys( const char *key, REGSUBKEY_CTR *subkeys ) printername)); return False; } + + /* get the top level printer keys */ + + num_existing_keys = get_printer_subkeys( &printer->info_2->data, "", &existing_subkeys ); + + for ( i=0; iinfo_2->data, existing_subkeys[i] ); + } + } num_subkeys = regsubkey_ctr_numkeys( subkeys ); for ( i=0; iinfo_2->data, subkeyname) == -1 ) { + DEBUG(5,("key_printers_store_keys: adding key %s\n", + existing_subkeys[i])); if ( add_new_printer_key( &printer->info_2->data, subkeyname ) == -1 ) return False; }