#include <vlc_osd.h>
#include <vlc_keys.h>
+/*****************************************************************************
+ * VLCAutoGeneratedMenuContent interface
+ *****************************************************************************
+ * This holds our data for autogenerated menus
+ *****************************************************************************/
+@interface VLCAutoGeneratedMenuContent : NSObject
+{
+ char *psz_name;
+ vlc_object_t * _vlc_object;
+ vlc_value_t value;
+ int i_type;
+}
+
+- (id)initWithVariableName: (const char *)name
+ ofObject: (vlc_object_t *)object
+ andValue: (vlc_value_t)value
+ ofType: (int)type;
+- (const char *)name;
+- (vlc_value_t)value;
+- (vlc_object_t *)vlcObject;
+- (int)type;
+
+@end
+
+#pragma mark -
/*****************************************************************************
* VLCControls implementation
*****************************************************************************/
- (IBAction)play:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- playlist_t * p_playlist = pl_Yield( p_intf );
+ playlist_t * p_playlist = pl_Hold( p_intf );
+ bool empty;
- vlc_object_lock( p_playlist );
- if( playlist_IsEmpty( p_playlist ) )
- {
- vlc_object_unlock( p_playlist );
- vlc_object_release( p_playlist );
+ PL_LOCK;
+ empty = playlist_IsEmpty( p_playlist );
+ PL_UNLOCK;
+
+ pl_Release( p_intf );
+
+ if( empty )
[o_main intfOpenFileGeneric: (id)sender];
- }
- else
- {
- vlc_object_unlock( p_playlist );
- vlc_object_release( p_playlist );
- }
- val.i_int = config_GetInt( p_intf, "key-play-pause" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_PLAY_PAUSE );
}
-/* Small helper method */
-
--(id) getVoutView
+- (id)voutView
{
- id o_window;
- id o_vout_view = nil;
- id o_embedded_vout_list = [[VLCMain sharedInstance] getEmbeddedList];
- NSEnumerator *o_enumerator = [[NSApp orderedWindows] objectEnumerator];
- while( !o_vout_view && ( o_window = [o_enumerator nextObject] ) )
+ id window;
+ id voutView = nil;
+ id embeddedViewList = [[VLCMain sharedInstance] getEmbeddedList];
+ NSEnumerator *enumerator = [[NSApp orderedWindows] objectEnumerator];
+ while( !voutView && ( window = [enumerator nextObject] ) )
{
/* We have an embedded vout */
- if( [o_embedded_vout_list windowContainsEmbedded: o_window] )
+ if( [embeddedViewList windowContainsEmbedded: window] )
{
- o_vout_view = [o_embedded_vout_list getViewForWindow: o_window];
+ voutView = [embeddedViewList getViewForWindow: window];
}
/* We have a detached vout */
- else if( [[o_window className] isEqualToString: @"VLCVoutWindow"] )
+ else if( [[window className] isEqualToString: @"VLCVoutWindow"] )
{
- msg_Dbg( VLCIntf, "detached vout controls.m call getVoutView" );
- o_vout_view = [o_window getVoutView];
+ voutView = [window voutView];
}
}
- return o_vout_view;
+ return [[voutView retain] autorelease];
}
-
- (IBAction)stop:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-stop" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_STOP );
+ /* Close the window directly, because we do know that there
+ * won't be anymore video. It's currently waiting a bit. */
+ [[[self voutView] window] orderOut:self];
}
- (IBAction)faster:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-faster" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_FASTER );
}
- (IBAction)slower:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-slower" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_SLOWER );
}
- (IBAction)prev:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-prev" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_PREV );
}
- (IBAction)next:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-next" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_NEXT );
}
- (IBAction)random:(id)sender
{
vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- playlist_t * p_playlist = pl_Yield( p_intf );
+ playlist_t * p_playlist = pl_Hold( p_intf );
var_Get( p_playlist, "random", &val );
val.b_bool = !val.b_bool;
- (void)shuffle
{
vlc_value_t val;
- playlist_t *p_playlist = pl_Yield( VLCIntf );
+ playlist_t *p_playlist = pl_Hold( VLCIntf );
var_Get( p_playlist, "random", &val );
[o_btn_shuffle setState: val.b_bool];
vlc_object_release( p_playlist );
{
vlc_value_t looping,repeating;
intf_thread_t * p_intf = VLCIntf;
- playlist_t * p_playlist = pl_Yield( p_intf );
+ playlist_t * p_playlist = pl_Hold( p_intf );
var_Get( p_playlist, "repeat", &repeating );
var_Get( p_playlist, "loop", &looping );
{
vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- playlist_t * p_playlist = pl_Yield( p_intf );
+ playlist_t * p_playlist = pl_Hold( p_intf );
var_Get( p_playlist, "repeat", &val );
if (!val.b_bool)
{
vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- playlist_t * p_playlist = pl_Yield( p_intf );
+ playlist_t * p_playlist = pl_Hold( p_intf );
var_Get( p_playlist, "loop", &val );
if (!val.b_bool)
- (IBAction)forward:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-jump+short" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_JUMP_FORWARD_SHORT );
}
- (IBAction)backward:(id)sender
{
vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-jump-short" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_JUMP_BACKWARD_SHORT );
}
- (IBAction)volumeUp:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-vol-up" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_VOL_UP );
/* Manage volume status */
[o_main manageVolumeSlider];
}
- (IBAction)volumeDown:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-vol-down" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_VOL_DOWN );
/* Manage volume status */
[o_main manageVolumeSlider];
}
- (IBAction)mute:(id)sender
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-vol-mute" );
- var_Set( p_intf->p_libvlc, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_VOL_MUTE );
/* Manage volume status */
[o_main manageVolumeSlider];
}
FIND_ANYWHERE );
if( p_vout != NULL )
{
- vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- val.i_int = config_GetInt( p_intf, "key-position" );
- var_Set( p_intf, "key-pressed", val );
+ var_SetInteger( p_intf->p_libvlc, "key-action", ACTIONID_POSITION );
vlc_object_release( (vlc_object_t *)p_vout );
}
}
}
- (BOOL) isFullscreen {
- id o_vout_view = [self getVoutView];
+ id o_vout_view = [self voutView];
if( o_vout_view )
{
return [o_vout_view isFullscreen];
FIND_ANYWHERE );
if( p_vout != NULL )
{
- id o_vout_view = [self getVoutView];
+ id o_vout_view = [self voutView];
if( o_vout_view )
{
if( [o_title isEqualToString: _NS("Half Size") ] )
}
else
{
+ /* Fullscreen state for next time will be saved here too */
[o_vout_view toggleFullscreen];
}
}
}
else
{
- playlist_t * p_playlist = pl_Yield( VLCIntf );
+ playlist_t * p_playlist = pl_Hold( VLCIntf );
if( [o_title isEqualToString: _NS("Fullscreen")] ||
[sender isKindOfClass:[NSButton class]] )
var_Set( p_playlist, "fullscreen", (vlc_value_t)!val.b_bool );
}
- vlc_object_release( p_playlist );
+ pl_Release( VLCIntf );
+ }
+
+}
+
+- (IBAction)telxTransparent:(id)sender
+{
+ intf_thread_t * p_intf = VLCIntf;
+ vlc_object_t *p_vbi;
+ p_vbi = (vlc_object_t *) vlc_object_find_name( p_intf,
+ "zvbi", FIND_ANYWHERE );
+ if( p_vbi )
+ {
+ var_SetBool( p_vbi, "vbi-opaque", [sender state] );
+ [sender setState: ![sender state]];
+ vlc_object_release( p_vbi );
}
+}
+- (IBAction)telxNavLink:(id)sender;
+{
+ intf_thread_t * p_intf = VLCIntf;
+ vlc_object_t *p_vbi;
+ int i_page = 0;
+
+ if( [[sender title] isEqualToString: _NS("Index")] )
+ i_page = 'i' << 16;
+ else if( [[sender title] isEqualToString: _NS("Red")] )
+ i_page = 'r' << 16;
+ else if( [[sender title] isEqualToString: _NS("Green")] )
+ i_page = 'g' << 16;
+ else if( [[sender title] isEqualToString: _NS("Yellow")] )
+ i_page = 'y' << 16;
+ else if( [[sender title] isEqualToString: _NS("Blue")] )
+ i_page = 'b' << 16;
+ if( i_page == 0 ) return;
+
+ p_vbi = (vlc_object_t *) vlc_object_find_name( p_intf,
+ "zvbi", FIND_ANYWHERE );
+ if( p_vbi )
+ {
+ var_SetInteger( p_vbi, "vbi-page", i_page );
+ vlc_object_release( p_vbi );
+ }
}
- (void)scrollWheel:(NSEvent *)theEvent
/* Escape */
if( key == (unichar) 0x1b )
{
- id o_vout_view = [self getVoutView];
+ id o_vout_view = [self voutView];
if( o_vout_view && [o_vout_view isFullscreen] )
{
[o_vout_view toggleFullscreen];
return;
}
- VLCMenuExt *o_data;
+ VLCAutoGeneratedMenuContent *o_data;
switch( i_type & VLC_VAR_TYPE )
{
case VLC_VAR_VOID:
- o_data = [[VLCMenuExt alloc] initWithVar: psz_variable Object: p_object->i_object_id
- Value: val ofType: i_type];
+ o_data = [[VLCAutoGeneratedMenuContent alloc] initWithVariableName: psz_variable ofObject: p_object
+ andValue: val ofType: i_type];
[o_mi setRepresentedObject: [NSValue valueWithPointer:[o_data retain]]];
break;
case VLC_VAR_BOOL:
- o_data = [[VLCMenuExt alloc] initWithVar: psz_variable Object: p_object->i_object_id
- Value: val ofType: i_type];
+ o_data = [[VLCAutoGeneratedMenuContent alloc] initWithVariableName: psz_variable ofObject: p_object
+ andValue: val ofType: i_type];
[o_mi setRepresentedObject: [NSValue valueWithPointer:[o_data retain]]];
if( !( i_type & VLC_VAR_ISCOMMAND ) )
[o_mi setState: val.b_bool ? TRUE : FALSE ];
vlc_value_t another_val;
NSMenuItem * o_lmi;
NSString *o_title = @"";
- VLCMenuExt *o_data;
+ VLCAutoGeneratedMenuContent *o_data;
switch( i_type & VLC_VAR_TYPE )
{
text_list.p_list->p_values[i].psz_string : val_list.p_list->p_values[i].psz_string ];
o_lmi = [o_menu addItemWithTitle: o_title action: pf_callback keyEquivalent: @""];
- o_data = [[VLCMenuExt alloc] initWithVar: strdup(psz_variable) Object: p_object->i_object_id
- Value: another_val ofType: i_type];
+ o_data = [[VLCAutoGeneratedMenuContent alloc] initWithVariableName: strdup(psz_variable) ofObject: p_object
+ andValue: another_val ofType: i_type];
[o_lmi setRepresentedObject: [NSValue valueWithPointer:[o_data retain]]];
[o_lmi setTarget: self];
val_list.p_list->p_values[i].i_int];
o_lmi = [[o_menu addItemWithTitle: o_title action: pf_callback keyEquivalent: @""] retain ];
- o_data = [[VLCMenuExt alloc] initWithVar: strdup(psz_variable) Object: p_object->i_object_id
- Value: val_list.p_list->p_values[i] ofType: i_type];
+ o_data = [[VLCAutoGeneratedMenuContent alloc] initWithVariableName: strdup(psz_variable) ofObject: p_object
+ andValue: val_list.p_list->p_values[i] ofType: i_type];
[o_lmi setRepresentedObject: [NSValue valueWithPointer:[ o_data retain]]];
[o_lmi setTarget: self];
- (IBAction)toggleVar:(id)sender
{
NSMenuItem *o_mi = (NSMenuItem *)sender;
- VLCMenuExt *o_data = [[o_mi representedObject] pointerValue];
+ VLCAutoGeneratedMenuContent *o_data = [[o_mi representedObject] pointerValue];
[NSThread detachNewThreadSelector: @selector(toggleVarThread:)
toTarget: self withObject: o_data];
return;
}
-- (int)toggleVarThread: (id)_o_data
+- (int)toggleVarThread: (id)data
{
vlc_object_t *p_object;
NSAutoreleasePool * o_pool = [[NSAutoreleasePool alloc] init];
- VLCMenuExt *o_data = (VLCMenuExt *)_o_data;
+
+ assert([data isKindOfClass:[VLCAutoGeneratedMenuContent class]]);
+ VLCAutoGeneratedMenuContent *menuContent = (VLCAutoGeneratedMenuContent *)data;
vlc_thread_set_priority( VLCIntf , VLC_THREAD_PRIORITY_LOW );
- p_object = (vlc_object_t *)vlc_object_get( [o_data objectID] );
+ p_object = [menuContent vlcObject];
if( p_object != NULL )
{
- var_Set( p_object, strdup([o_data name]), [o_data value] );
+ var_Set( p_object, [menuContent name], [menuContent value] );
vlc_object_release( p_object );
[o_pool release];
return true;
}
else if( sender == o_specificTime_ok_btn )
{
- input_thread_t * p_input = (input_thread_t *)vlc_object_find( VLCIntf, \
- VLC_OBJECT_INPUT, FIND_ANYWHERE );
+ input_thread_t * p_input = pl_CurrentInput( VLCIntf );
if( p_input )
{
unsigned int timeInSec = 0;
input_Control( p_input, INPUT_SET_TIME, (int64_t)(timeInSec * 1000000));
vlc_object_release( p_input );
}
-
+
[NSApp endSheet: o_specificTime_win];
[o_specificTime_win close];
}
else
{
- input_thread_t * p_input = (input_thread_t *)vlc_object_find( VLCIntf, \
- VLC_OBJECT_INPUT, FIND_ANYWHERE );
+ input_thread_t * p_input = pl_CurrentInput( VLCIntf );
if( p_input )
{
/* we can obviously only do that if an input is available */
BOOL bEnabled = TRUE;
vlc_value_t val;
intf_thread_t * p_intf = VLCIntf;
- playlist_t * p_playlist = pl_Yield( p_intf );
-
- vlc_object_lock( p_playlist );
-
-#define p_input p_playlist->p_input
+ playlist_t * p_playlist = pl_Hold( p_intf );
+ input_thread_t * p_input = playlist_CurrentInput( p_playlist );
if( [[o_mi title] isEqualToString: _NS("Faster")] ||
[[o_mi title] isEqualToString: _NS("Slower")] )
[[o_mi title] isEqualToString: _NS("Next")] )
{
/** \todo fix i_size use */
+ PL_LOCK;
bEnabled = p_playlist->items.i_size > 1;
+ PL_UNLOCK;
}
else if( [[o_mi title] isEqualToString: _NS("Random")] )
{
{
if( p_input != NULL )
{
- var_Get( p_input, "seekable", &val);
+ var_Get( p_input, "can-seek", &val);
bEnabled = val.b_bool;
}
else bEnabled = FALSE;
break;
}
}
+
vlc_object_release( (vlc_object_t *)p_vout );
}
- else if( [[o_mi title] isEqualToString: _NS("Fullscreen")] )
+ if( [[o_mi title] isEqualToString: _NS("Fullscreen")] )
{
var_Get( p_playlist, "fullscreen", &val );
[o_mi setState: val.b_bool];
[o_main setupMenus]; /* Make sure video menu is up to date */
}
- vlc_object_unlock( p_playlist );
+ /* Special case for telx menu */
+ if( [[o_mi title] isEqualToString: _NS("Normal Size")] );
+ {
+ NSMenuItem *item = [[o_mi menu] itemWithTitle:_NS("Teletext")];
+ bool b_telx = false;
+ if( p_input )
+ {
+ const int i_teletext_es = var_GetInteger( p_input, "teletext-es" );
+ const int i_spu_es = var_GetInteger( p_input, "spu-es" );
+
+ if( i_teletext_es >= 0 && i_teletext_es == i_spu_es )
+ b_telx = true;
+ }
+ [[item submenu] setAutoenablesItems:NO];
+ for( int k=0; k < [[item submenu] numberOfItems]; k++ )
+ {
+ [[[item submenu] itemAtIndex:k] setEnabled: b_telx];
+ }
+ }
+
+ if( p_input ) vlc_object_release( p_input );
vlc_object_release( p_playlist );
return( bEnabled );
@end
/*****************************************************************************
- * VLCMenuExt implementation
+ * VLCAutoGeneratedMenuContent implementation
*****************************************************************************
* Object connected to a playlistitem which remembers the data belonging to
* the variable of the autogenerated menu
*****************************************************************************/
-@implementation VLCMenuExt
+@implementation VLCAutoGeneratedMenuContent
-- (id)initWithVar: (const char *)_psz_name Object: (int)i_id
- Value: (vlc_value_t)val ofType: (int)_i_type
+-(id) initWithVariableName:(const char *)name ofObject:(vlc_object_t *)object
+ andValue:(vlc_value_t)val ofType:(int)type
{
self = [super init];
if( self != nil )
{
- psz_name = strdup( _psz_name );
- i_object_id = i_id;
+ psz_name = strdup( name );
+ _vlc_object = vlc_object_hold( object );
value = val;
- i_type = _i_type;
+ i_type = type;
}
return( self );
- (void)dealloc
{
+ vlc_object_release( _vlc_object );
free( psz_name );
[super dealloc];
}
-- (char *)name
+- (const char *)name
{
return psz_name;
}
-- (int)objectID
+- (vlc_value_t)value
{
- return i_object_id;
+ return value;
}
-- (vlc_value_t)value
+- (vlc_object_t *)vlcObject
{
- return value;
+ return vlc_object_hold( _vlc_object );
}
+
- (int)type
{
return i_type;