Commit d66f3c87 authored by Derk-Jan Hartman's avatar Derk-Jan Hartman

macosx gui: Fix resetting of the prefs.

Ok, this isn't making it much nicer, and this code definetly needs a more careful rewrite, but this is patchwork for the 1.0-bugfix release and at least it will do for now.

- reset's the values in any loaded views after reset of the config is called
- does not reset the module selector atm. might follow later on.
parent bbe8ccf8
...@@ -194,6 +194,7 @@ static VLCPrefs *_o_sharedMainInstance = nil; ...@@ -194,6 +194,7 @@ static VLCPrefs *_o_sharedMainInstance = nil;
[o_prefs_window center]; [o_prefs_window center];
[o_prefs_window makeKeyAndOrderFront:self]; [o_prefs_window makeKeyAndOrderFront:self];
[_rootTreeItem resetView];
} }
- (void)initStrings - (void)initStrings
...@@ -233,11 +234,8 @@ static VLCPrefs *_o_sharedMainInstance = nil; ...@@ -233,11 +234,8 @@ static VLCPrefs *_o_sharedMainInstance = nil;
{ {
if( i_return == NSAlertAlternateReturn ) if( i_return == NSAlertAlternateReturn )
{ {
[o_prefs_view setDocumentView: o_empty_view];
config_ResetAll( p_intf ); config_ResetAll( p_intf );
[_rootTreeItem resetView]; [_rootTreeItem resetView];
[[o_tree itemAtRow:[o_tree selectedRow]]
showView:o_prefs_view];
} }
} }
...@@ -649,12 +647,16 @@ static VLCPrefs *_o_sharedMainInstance = nil; ...@@ -649,12 +647,16 @@ static VLCPrefs *_o_sharedMainInstance = nil;
- (void)resetView - (void)resetView
{ {
[_subviews release];
_subviews = nil;
unsigned int i; unsigned int i;
for( i = 0 ; i < [_subviews count] ; i++ )
[[_subviews objectAtIndex:i] resetValues];
for( i = 0 ; i < [_options count] ; i++ )
[[_options objectAtIndex:i] resetView];
for( i = 0 ; i < [_children count] ; i++ ) for( i = 0 ; i < [_children count] ; i++ )
[[_children objectAtIndex:i] resetView]; [[_children objectAtIndex:i] resetView];
} }
- (NSMutableArray *)children - (NSMutableArray *)children
......
...@@ -51,6 +51,7 @@ static NSMenu *o_keys_menu = nil; ...@@ -51,6 +51,7 @@ static NSMenu *o_keys_menu = nil;
- (float)floatValue; - (float)floatValue;
- (char *)stringValue; - (char *)stringValue;
- (void)applyChanges; - (void)applyChanges;
- (void)resetValues;
- (int)labelSize; - (int)labelSize;
- (void) alignWithXPosition:(int)i_xPos; - (void) alignWithXPosition:(int)i_xPos;
......
...@@ -926,6 +926,10 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -926,6 +926,10 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
} }
} }
- (void)resetValues
{
}
- (int)labelSize - (int)labelSize
{ {
return [o_label frame].size.width; return [o_label frame].size.width;
...@@ -1020,6 +1024,19 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1020,6 +1024,19 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
return [[VLCMain sharedInstance] delocalizeString: return [[VLCMain sharedInstance] delocalizeString:
[o_textfield stringValue]]; [o_textfield stringValue]];
} }
- (void)resetValues
{
NSString *o_textfieldString;
char *psz_value = config_GetPsz( VLCIntf, p_item->psz_name );
if( psz_value )
o_textfieldString = [[VLCMain sharedInstance]
localizedString: psz_value];
else
o_textfieldString = [NSString stringWithString: @""];
free( psz_value );
[super resetValues];
}
@end @end
@implementation StringListConfigControl @implementation StringListConfigControl
...@@ -1093,6 +1110,21 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1093,6 +1110,21 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
return strdup( [[VLCMain sharedInstance] return strdup( [[VLCMain sharedInstance]
delocalizeString: [o_combo stringValue]] ); delocalizeString: [o_combo stringValue]] );
} }
- (void)resetValues
{
int i_index;
[o_combo reloadData];
char *psz_value = config_GetPsz( VLCIntf, p_item->psz_name );
for( i_index = 0; i_index < p_item->i_list; i_index++ )
if( psz_value &&
!strcmp( psz_value, p_item->ppsz_list[i_index] ) )
[o_combo selectItemAtIndex: i_index];
free( psz_value );
[super resetValues];
}
@end @end
@implementation StringListConfigControl (NSComboBoxDataSource) @implementation StringListConfigControl (NSComboBoxDataSource)
...@@ -1214,6 +1246,19 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1214,6 +1246,19 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
else else
return NULL; return NULL;
} }
-(void)resetValues
{
NSString *o_textfieldString;
char *psz_value = config_GetPsz( VLCIntf, p_item->psz_name );
if( psz_value )
o_textfieldString = [NSString stringWithFormat: @"%s", psz_value];
else
o_textfieldString = [NSString stringWithString: @""];
free(psz_value);
[super resetValues];
}
@end @end
@implementation ModuleConfigControl @implementation ModuleConfigControl
...@@ -1229,8 +1274,6 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1229,8 +1274,6 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
if( [super initWithFrame: mainFrame item: _p_item] != nil ) if( [super initWithFrame: mainFrame item: _p_item] != nil )
{ {
size_t i_index;
module_t *p_parser, **p_list;
i_view_type = CONFIG_ITEM_MODULE; i_view_type = CONFIG_ITEM_MODULE;
o_popupTooltip = [[VLCMain sharedInstance] wrapString: o_popupTooltip = [[VLCMain sharedInstance] wrapString:
...@@ -1255,54 +1298,7 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1255,54 +1298,7 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
[[o_popup lastItem] setTag: -1]; [[o_popup lastItem] setTag: -1];
[o_popup selectItem: [o_popup lastItem]]; [o_popup selectItem: [o_popup lastItem]];
/* build a list of available modules */ [self resetValues];
p_list = module_list_get( NULL );
for( i_index = 0; p_list[i_index]; i_index++ )
{
p_parser = p_list[i_index];
if( p_item->i_type == CONFIG_ITEM_MODULE )
{
if( module_provides( p_parser, p_item->psz_type ) )
{
NSString *o_description = [[VLCMain sharedInstance]
localizedString: module_GetLongName( p_parser )];
[o_popup addItemWithTitle: o_description];
if( p_item->value.psz &&
!strcmp( p_item->value.psz, module_get_object( p_parser ) ) )
[o_popup selectItem:[o_popup lastItem]];
}
}
else
{
int i;
if( module_is_main( p_parser ) )
continue;
unsigned int confsize;
unsigned int unused;
module_config_t *p_configlist = module_config_get( p_parser, &confsize );
for ( i = 0; i < confsize; i++ )
{
module_config_t *p_config = &p_configlist[i];
/* Hack: required subcategory is stored in i_min */
if( p_config->i_type == CONFIG_SUBCATEGORY &&
p_config->value.i == p_item->min.i )
{
NSString *o_description = [[VLCMain sharedInstance]
localizedString: module_GetLongName( p_parser )];
[o_popup addItemWithTitle: o_description];
if( p_item->value.psz && !strcmp(p_item->value.psz,
module_get_object( p_parser )) )
[o_popup selectItem:[o_popup lastItem]];
}
}
module_config_free( p_configlist );
}
}
module_list_free( p_list );
[self addSubview: o_popup]; [self addSubview: o_popup];
} }
return self; return self;
...@@ -1382,6 +1378,68 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1382,6 +1378,68 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
module_list_free( p_list ); module_list_free( p_list );
return returnval; return returnval;
} }
-(void)resetValues
{
/* build a list of available modules */
size_t i_index;
module_t *p_parser, **p_list;
p_list = module_list_get( NULL );
for( i_index = 0; p_list[i_index]; i_index++ )
{
p_parser = p_list[i_index];
if( p_item->i_type == CONFIG_ITEM_MODULE )
{
if( module_provides( p_parser, p_item->psz_type ) )
{
NSString *o_description = [[VLCMain sharedInstance]
localizedString: module_GetLongName( p_parser )];
[o_popup addItemWithTitle: o_description];
char *psz_value = config_GetPsz( VLCIntf, p_item->psz_name );
if( psz_value &&
!strcmp( psz_value, module_get_object( p_parser ) ) )
[o_popup selectItem:[o_popup lastItem]];
free(psz_value);
}
}
else
{
int i;
if( module_is_main( p_parser ) )
continue;
unsigned int confsize;
unsigned int unused;
module_config_t *p_configlist = module_config_get( p_parser, &confsize );
for ( i = 0; i < confsize; i++ )
{
module_config_t *p_config = &p_configlist[i];
/* Hack: required subcategory is stored in i_min */
if( p_config->i_type == CONFIG_SUBCATEGORY &&
config_GetInt( VLCIntf, p_item->psz_name) == p_item->min.i )
{
NSString *o_description = [[VLCMain sharedInstance]
localizedString: module_GetLongName( p_parser )];
[o_popup addItemWithTitle: o_description];
char *psz_value = config_GetPsz( VLCIntf, p_item->psz_name );
if( psz_value && !strcmp(psz_value,
module_get_object( p_parser )) )
[o_popup selectItem:[o_popup lastItem]];
free( psz_value );
}
}
module_config_free( p_configlist );
}
}
module_list_free( p_list );
[super resetValues];
}
@end @end
@implementation IntegerConfigControl @implementation IntegerConfigControl
...@@ -1472,6 +1530,12 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1472,6 +1530,12 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
return [o_textfield intValue]; return [o_textfield intValue];
} }
-(void)resetValues
{
[o_textfield setIntValue: config_GetInt(VLCIntf, p_item->psz_name)];
[super resetValues];
}
@end @end
@implementation IntegerListConfigControl @implementation IntegerListConfigControl
...@@ -1548,6 +1612,20 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1548,6 +1612,20 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
else else
return [o_combo intValue]; return [o_combo intValue];
} }
-(void)resetValues
{
int i_index;
[o_combo reloadData];
for( i_index = 0; i_index < p_item->i_list; i_index++ )
{
if( config_GetInt( VLCIntf, p_item->psz_name) == p_item->pi_list[i_index] )
{
[o_combo selectItemAtIndex: i_index];
}
}
}
@end @end
@implementation IntegerListConfigControl (NSComboBoxDataSource) @implementation IntegerListConfigControl (NSComboBoxDataSource)
...@@ -1675,6 +1753,14 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1675,6 +1753,14 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
{ {
return [o_slider intValue]; return [o_slider intValue];
} }
- (void)resetValues
{
int value = config_GetInt( VLCIntf, p_item->psz_name );
[o_textfield setIntValue:value];
[o_slider setIntValue:value];
[super resetValues];
}
@end @end
@implementation FloatConfigControl @implementation FloatConfigControl
...@@ -1765,6 +1851,12 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1765,6 +1851,12 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
{ {
return [o_stepper floatValue]; return [o_stepper floatValue];
} }
- (void)resetValues
{
[o_textfield setFloatValue: config_GetFloat( VLCIntf, p_item->psz_name)];
[super resetValues];
}
@end @end
@implementation RangedFloatConfigControl @implementation RangedFloatConfigControl
...@@ -1877,6 +1969,12 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1877,6 +1969,12 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
return [o_slider floatValue]; return [o_slider floatValue];
} }
- (void)resetValues
{
[o_textfield setFloatValue: config_GetFloat(VLCIntf, p_item->psz_name)];
[o_slider setFloatValue: config_GetFloat(VLCIntf, p_item->psz_name)];
[super resetValues];
}
@end @end
@implementation BoolConfigControl @implementation BoolConfigControl
...@@ -1927,6 +2025,11 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -1927,6 +2025,11 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
return [o_checkbox intValue]; return [o_checkbox intValue];
} }
- (void)resetValues
{
[o_checkbox setState: config_GetInt( VLCIntf, p_item->psz_name)];
[super resetValues];
}
@end @end
@implementation KeyConfigControl @implementation KeyConfigControl
...@@ -2006,13 +2109,19 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \ ...@@ -2006,13 +2109,19 @@ o_textfield = [[[NSSecureTextField alloc] initWithFrame: s_rc] retain]; \
{ {
return [o_popup selectedTag]; return [o_popup selectedTag];
} }
- (void)resetValues
{
[o_popup selectItem:[[o_popup menu] itemWithTag:config_GetInt( VLCIntf, p_item->psz_name )]];
[super resetValues];
}
@end @end
@implementation ModuleListConfigControl @implementation ModuleListConfigControl
- (id) initWithItem: (module_config_t *)_p_item - (id) initWithItem: (module_config_t *)_p_item
withView: (NSView *)o_parent_view withView: (NSView *)o_parent_view
{ {
if( _p_item->i_type == CONFIG_ITEM_MODULE_LIST ) if( _p_item->i_type == CONFIG_ITEM_MODULE_LIST )
//TODO.... //TODO....
return nil; return nil;
...@@ -2194,6 +2303,13 @@ if( _p_item->i_type == CONFIG_ITEM_MODULE_LIST ) ...@@ -2194,6 +2303,13 @@ if( _p_item->i_type == CONFIG_ITEM_MODULE_LIST )
return strdup( [[o_textfield stringValue] UTF8String] ); return strdup( [[o_textfield stringValue] UTF8String] );
} }
-(void)resetValues
{
#warning Reset prefs of the module selector is broken atm.
NSLog( @"don't forget about modulelistconfig" );
[super resetValues];
}
@end @end
@implementation ModuleListConfigControl (NSTableDataSource) @implementation ModuleListConfigControl (NSTableDataSource)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment