/** * Perform a deep copy of an existing ACL. * * @param p_this object to attach the copy to. * @param p_acl ACL object to be copied. * * @return a new ACL object, or NULL on error. */ vlc_acl_t *__ACL_Duplicate( vlc_object_t *p_this, const vlc_acl_t *p_acl ) { vlc_acl_t *p_dupacl; if( p_acl == NULL ) return NULL; p_dupacl = (vlc_acl_t *)malloc( sizeof( *p_dupacl ) ); if( p_dupacl == NULL ) return NULL; if( p_acl->i_size ) { p_dupacl->p_entries = (vlc_acl_entry_t *) malloc( p_acl->i_size * sizeof( vlc_acl_entry_t ) ); if( p_dupacl->p_entries == NULL ) { free( p_dupacl ); return NULL; } memcpy( p_dupacl->p_entries, p_acl->p_entries, p_acl->i_size * sizeof( vlc_acl_entry_t ) ); } else p_dupacl->p_entries = NULL; vlc_object_yield( p_this ); p_dupacl->p_owner = p_this; p_dupacl->i_size = p_acl->i_size; p_dupacl->b_allow_default = p_acl->b_allow_default; return p_dupacl; }
/** * Register a new session with the announce handler * * \param p_sout a sout instance structure * \param p_session a session descriptor * \param p_method an announce method descriptor * \return VLC_SUCCESS or an error */ int sout_AnnounceRegister( sout_instance_t *p_sout, session_descriptor_t *p_session, announce_method_t *p_method ) { int i_ret; announce_handler_t *p_announce = (announce_handler_t*) vlc_object_find( p_sout, VLC_OBJECT_ANNOUNCE, FIND_ANYWHERE ); if( !p_announce ) { msg_Dbg( p_sout, "No announce handler found, creating one" ); p_announce = announce_HandlerCreate( p_sout ); if( !p_announce ) { msg_Err( p_sout, "Creation failed" ); return VLC_ENOMEM; } vlc_object_yield( p_announce ); msg_Dbg( p_sout, "creation done" ); } i_ret = announce_Register( p_announce, p_session, p_method ); vlc_object_release( p_announce ); return i_ret; }
/** * Register a new session with the announce handler, using a pregenerated SDP * * \param p_sout a sout instance structure * \param psz_sdp the SDP to register * \param psz_uri session URI (needed for SAP address auto detection * \param p_method an announce method descriptor * \return the new session descriptor structure */ session_descriptor_t *sout_AnnounceRegisterSDP( sout_instance_t *p_sout, const char *psz_sdp, const char *psz_uri, announce_method_t *p_method ) { session_descriptor_t *p_session; announce_handler_t *p_announce = (announce_handler_t*) vlc_object_find( p_sout, VLC_OBJECT_ANNOUNCE, FIND_ANYWHERE ); if( !p_announce ) { msg_Dbg( p_sout, "no announce handler found, creating one" ); p_announce = announce_HandlerCreate( p_sout ); if( !p_announce ) { msg_Err( p_sout, "Creation failed" ); return NULL; } vlc_object_yield( p_announce ); } if( p_method->i_type != METHOD_TYPE_SAP ) { msg_Warn( p_sout, "forcing SAP announcement"); } p_session = sout_AnnounceSessionCreate(); p_session->psz_sdp = strdup( psz_sdp ); p_session->psz_uri = strdup( psz_uri ); announce_Register( p_announce, p_session, p_method ); vlc_object_release( p_announce ); return p_session; }
/***************************************************************************** * ItemChange: Playlist item change callback *****************************************************************************/ static int ItemChange( vlc_object_t *p_this, const char *psz_var, vlc_value_t oldval, vlc_value_t newval, void *param ) { char psz_tmp[MAX_LENGTH]; playlist_t *p_playlist; char *psz_title = NULL; char *psz_artist = NULL; char *psz_album = NULL; input_thread_t *p_input=NULL; intf_thread_t *p_intf = ( intf_thread_t* ) param; intf_sys_t *p_sys = p_intf->p_sys; p_playlist = (playlist_t *)vlc_object_find( p_this, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE ); if( !p_playlist ) return VLC_EGENERIC; p_input = p_playlist->p_input; vlc_object_release( p_playlist ); if( !p_input ) return VLC_SUCCESS; vlc_object_yield( p_input ); if( p_input->b_dead || !p_input->input.p_item->psz_name ) { /* Not playing anything ... */ vlc_object_release( p_input ); return VLC_SUCCESS; } /* Playing something ... */ psz_artist = vlc_input_item_GetInfo( p_input->input.p_item, _("Meta-information"), _(VLC_META_ARTIST) ); psz_album = vlc_input_item_GetInfo( p_input->input.p_item, _("Meta-information"), _("Album/movie/show title" ) ); psz_title = strdup( p_input->input.p_item->psz_name ); vlc_object_release( p_input ); if( psz_title == NULL ) psz_title = strdup( N_("(no title)") ); if( psz_artist == NULL ) psz_artist = strdup( N_("(no artist)") ); if( psz_album == NULL ) psz_album = strdup( N_("(no album)") ); snprintf( psz_tmp, MAX_LENGTH, "<b>%s</b>\n%s - %s", psz_title, psz_artist, psz_album ); free( psz_title ); free( psz_artist ); free( psz_album ); vlc_mutex_lock( &p_sys->lock ); Notify( p_this, psz_tmp ); vlc_mutex_unlock( &p_sys->lock ); return VLC_SUCCESS; }
/** * Creates an empty ACL. * * @param b_allow whether to grant (true) or deny (false) access * by default (ie if none of the ACL entries matched). * * @return an ACL object. NULL in case of error. */ vlc_acl_t *__ACL_Create( vlc_object_t *p_this, bool b_allow ) { vlc_acl_t *p_acl; p_acl = (vlc_acl_t *)malloc( sizeof( *p_acl ) ); if( p_acl == NULL ) return NULL; vlc_object_yield( p_this ); p_acl->p_owner = p_this; p_acl->i_size = 0; p_acl->p_entries = NULL; p_acl->b_allow_default = b_allow; return p_acl; }