+/* Triggered when the computer goes to sleep */
+- (void)computerWillSleep: (NSNotification *)notification
+{
+ /* Pause */
+ if ( p_intf->p_sys->i_play_status == PLAYING_S )
+ {
+ vlc_value_t val;
+ val.i_int = config_GetInt( p_intf, "key-play-pause" );
+ var_Set( p_intf->p_libvlc, "key-pressed", val );
+ }
+}
+
+/* Helper method for the remote control interface in order to trigger forward/backward and volume
+ increase/decrease as long as the user holds the left/right, plus/minus button */
+- (void) executeHoldActionForRemoteButton: (NSNumber*) buttonIdentifierNumber
+{
+ if (b_remote_button_hold)
+ {
+ switch([buttonIdentifierNumber intValue])
+ {
+ case kRemoteButtonRight_Hold:
+ [o_controls forward: self];
+ break;
+ case kRemoteButtonLeft_Hold:
+ [o_controls backward: self];
+ break;
+ case kRemoteButtonVolume_Plus_Hold:
+ [o_controls volumeUp: self];
+ break;
+ case kRemoteButtonVolume_Minus_Hold:
+ [o_controls volumeDown: self];
+ break;
+ }
+ if (b_remote_button_hold)
+ {
+ /* trigger event */
+ [self performSelector:@selector(executeHoldActionForRemoteButton:)
+ withObject:buttonIdentifierNumber
+ afterDelay:0.25];
+ }
+ }
+}
+