Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
3b41ca7d
Commit
3b41ca7d
authored
May 19, 2007
by
Filippo Carone
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
initial structures for libvlc callbacks (code adapted from git pdherbemont_branch)
parent
dc2c11a1
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
218 additions
and
52 deletions
+218
-52
include/vlc/libvlc.h
include/vlc/libvlc.h
+39
-51
include/vlc/libvlc_structures.h
include/vlc/libvlc_structures.h
+162
-0
src/control/libvlc_internal.h
src/control/libvlc_internal.h
+17
-1
No files found.
include/vlc/libvlc.h
View file @
3b41ca7d
...
@@ -34,6 +34,7 @@
...
@@ -34,6 +34,7 @@
#define _LIBVLC_H 1
#define _LIBVLC_H 1
#include <vlc/vlc.h>
#include <vlc/vlc.h>
#include <vlc/libvlc_structures.h>
# ifdef __cplusplus
# ifdef __cplusplus
extern
"C"
{
extern
"C"
{
...
@@ -48,13 +49,6 @@ extern "C" {
...
@@ -48,13 +49,6 @@ extern "C" {
* @{
* @{
*/
*/
typedef
struct
{
int
b_raised
;
int
i_code
;
char
*
psz_message
;
}
libvlc_exception_t
;
/**
/**
* Initialize an exception structure. This can be called several times to reuse
* Initialize an exception structure. This can be called several times to reuse
* an exception structure.
* an exception structure.
...
@@ -103,9 +97,6 @@ VLC_PUBLIC_API char* libvlc_exception_get_message( libvlc_exception_t *p_excepti
...
@@ -103,9 +97,6 @@ VLC_PUBLIC_API char* libvlc_exception_get_message( libvlc_exception_t *p_excepti
* @{
* @{
*/
*/
/** This structure is opaque. It represents a libvlc instance */
typedef
struct
libvlc_instance_t
libvlc_instance_t
;
/**
/**
* Create an initialized libvlc instance
* Create an initialized libvlc instance
* \param argc the number of arguments
* \param argc the number of arguments
...
@@ -139,13 +130,6 @@ VLC_PUBLIC_API void libvlc_destroy( libvlc_instance_t *, libvlc_exception_t * );
...
@@ -139,13 +130,6 @@ VLC_PUBLIC_API void libvlc_destroy( libvlc_instance_t *, libvlc_exception_t * );
* @{
* @{
*/
*/
typedef
struct
{
int
i_id
;
char
*
psz_uri
;
char
*
psz_name
;
}
libvlc_playlist_item_t
;
/**
/**
* Set loop variable
* Set loop variable
*/
*/
...
@@ -308,24 +292,6 @@ VLC_PUBLIC_API int libvlc_input_get_state ( libvlc_input_t *, libvl
...
@@ -308,24 +292,6 @@ VLC_PUBLIC_API int libvlc_input_get_state ( libvlc_input_t *, libvl
* @{
* @{
*/
*/
/**
* Downcast to this general type as placeholder for a platform specific one, such as:
* Drawable on X11,
* CGrafPort on MacOSX,
* HWND on win32
*/
typedef
int
libvlc_drawable_t
;
/**
* Rectangle type for video geometry
*/
typedef
struct
{
int
top
,
left
;
int
bottom
,
right
;
}
libvlc_rectangle_t
;
/**
/**
* Does this input have a video output ?
* Does this input have a video output ?
* \param p_input the input
* \param p_input the input
...
@@ -745,22 +711,6 @@ VLC_PUBLIC_API LIBVLC_VLM_GET_MEDIA_ATTRIBUTE( seekable, int, Bool, 0);
...
@@ -745,22 +711,6 @@ VLC_PUBLIC_API LIBVLC_VLM_GET_MEDIA_ATTRIBUTE( seekable, int, Bool, 0);
* @{
* @{
*/
*/
/** This structure is opaque. It represents a libvlc log instance */
typedef
struct
libvlc_log_t
libvlc_log_t
;
/** This structure is opaque. It represents a libvlc log iterator */
typedef
struct
libvlc_log_iterator_t
libvlc_log_iterator_t
;
typedef
struct
libvlc_log_message_t
{
unsigned
sizeof_msg
;
/* sizeof() of message structure, must be filled in by user */
int
i_severity
;
/* 0=INFO, 1=ERR, 2=WARN, 3=DBG */
const
char
*
psz_type
;
/* module type */
const
char
*
psz_name
;
/* module name */
const
char
*
psz_header
;
/* optional header */
const
char
*
psz_message
;
/* message */
}
libvlc_log_message_t
;
/**
/**
* Returns the VLC messaging verbosity level
* Returns the VLC messaging verbosity level
* \param p_instance libvlc instance
* \param p_instance libvlc instance
...
@@ -839,6 +789,44 @@ VLC_PUBLIC_API libvlc_log_message_t *libvlc_log_iterator_next( libvlc_log_iterat
...
@@ -839,6 +789,44 @@ VLC_PUBLIC_API libvlc_log_message_t *libvlc_log_iterator_next( libvlc_log_iterat
/** @} */
/** @} */
/*****************************************************************************
* Callbacks handling
*****************************************************************************/
/** defgroup libvlc_callbacks Callbacks
* \ingroup libvlc
* LibVLC Event Callbacks
* @{
*/
/**
* Register for a callback notification
* \param p_instance the libvlc instance
* \param i_event_type the desired event mask to which we want to listen
* \param pf_callback function the function to call when an_Event occurs
* \param p_e an initialized exception pointer
*/
/* void libvlc_callback_register_for_eventtype( libvlc_instance_t *p_instance, */
/* libvlc_event_type_t i_event_type, */
/* libvlc_callback_t pf_callback, */
/* libvlc_exception_t *p_e ); */
/**
* Unregister a callback notification
* \param p_instance the libvlc instance
* \param i_event_type the desired event mask to which we want to unregister
* \param pf_function the function to call when an_Event occurs
* \param p_e an initialized exception pointer
*/
/* void libvlc_callback_unregister_for_eventtype( libvlc_instance_t *p_instance, */
/* libvlc_event_type_t i_event_type, */
/* libvlc_callback_t pf_function, */
/* libvlc_exception_t *p_e ); */
/** @} */
# ifdef __cplusplus
# ifdef __cplusplus
}
}
# endif
# endif
...
...
include/vlc/libvlc_structures.h
0 → 100644
View file @
3b41ca7d
/*****************************************************************************
* libvlc.h: libvlc_* new external API structures
*****************************************************************************
* Copyright (C) 1998-2007 the VideoLAN team
* $Id $
*
* Authors: Filippo Carone <littlejohn@videolan.org>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#ifndef _LIBVLC_STRUCTURES_H
#define _LIBVLC_STRUCTURES_H 1
#include <vlc/vlc.h>
# ifdef __cplusplus
extern
"C"
{
# endif
/** This structure is opaque. It represents a libvlc instance */
typedef
struct
libvlc_instance_t
libvlc_instance_t
;
/** defgroup libvlc_exception Exceptions
* \ingroup libvlc
* LibVLC Exceptions handling
* @{
*/
typedef
struct
{
int
b_raised
;
int
i_code
;
char
*
psz_message
;
}
libvlc_exception_t
;
/**@} */
/*****************************************************************************
* Playlist
*****************************************************************************/
/** defgroup libvlc_playlist Playlist
* \ingroup libvlc
* LibVLC Playlist handling
* @{
*/
typedef
struct
{
int
i_id
;
char
*
psz_uri
;
char
*
psz_name
;
}
libvlc_playlist_item_t
;
/**@} */
/*****************************************************************************
* Video
*****************************************************************************/
/** defgroup libvlc_video Video
* \ingroup libvlc
* LibVLC Video handling
* @{
*/
/**
* Downcast to this general type as placeholder for a platform specific one, such as:
* Drawable on X11,
* CGrafPort on MacOSX,
* HWND on win32
*/
typedef
int
libvlc_drawable_t
;
/**
* Rectangle type for video geometry
*/
typedef
struct
{
int
top
,
left
;
int
bottom
,
right
;
}
libvlc_rectangle_t
;
/**@} */
/*****************************************************************************
* Message log handling
*****************************************************************************/
/** defgroup libvlc_log Log
* \ingroup libvlc
* LibVLC Message Logging
* @{
*/
/** This structure is opaque. It represents a libvlc log instance */
typedef
struct
libvlc_log_t
libvlc_log_t
;
/** This structure is opaque. It represents a libvlc log iterator */
typedef
struct
libvlc_log_iterator_t
libvlc_log_iterator_t
;
typedef
struct
libvlc_log_message_t
{
unsigned
sizeof_msg
;
/* sizeof() of message structure, must be filled in by user */
int
i_severity
;
/* 0=INFO, 1=ERR, 2=WARN, 3=DBG */
const
char
*
psz_type
;
/* module type */
const
char
*
psz_name
;
/* module name */
const
char
*
psz_header
;
/* optional header */
const
char
*
psz_message
;
/* message */
}
libvlc_log_message_t
;
/**@} */
/*****************************************************************************
* Callbacks handling
*****************************************************************************/
/** defgroup libvlc_callbacks Callbacks
* \ingroup libvlc
* LibVLC Event Callbacks
* @{
*/
/**
* Available events:
* - VOLUME_CHANGED
* - INPUT_POSITION_CHANGED
*/
typedef
enum
{
VOLUME_CHANGED
,
INPUT_POSITION_CHANGED
,
}
libvlc_event_type_t
;
typedef
struct
{
libvlc_event_type_t
type
;
char
reserved
[
8
];
/* For future use */
}
libvlc_event_t
;
typedef
void
(
*
libvlc_callback_t
)(
struct
libvlc_instance_t
*
,
libvlc_event_t
*
);
/**@} */
# ifdef __cplusplus
}
# endif
#endif
src/control/libvlc_internal.h
View file @
3b41ca7d
...
@@ -30,7 +30,8 @@ extern "C" {
...
@@ -30,7 +30,8 @@ extern "C" {
# endif
# endif
#include <vlc/vlc.h>
#include <vlc/vlc.h>
#include <vlc/libvlc_structures.h>
/***************************************************************************
/***************************************************************************
* Internal creation and destruction functions
* Internal creation and destruction functions
***************************************************************************/
***************************************************************************/
...
@@ -46,14 +47,29 @@ VLC_EXPORT (int, libvlc_InternalAddIntf, ( libvlc_int_t *, const char *, vlc_boo
...
@@ -46,14 +47,29 @@ VLC_EXPORT (int, libvlc_InternalAddIntf, ( libvlc_int_t *, const char *, vlc_boo
* Opaque structures for libvlc API
* Opaque structures for libvlc API
***************************************************************************/
***************************************************************************/
struct
libvlc_callback_entry_t
{
libvlc_callback_t
callback
;
libvlc_event_type_t
eventType
;
};
struct
libvlc_callback_entry_list_t
{
struct
libvlc_callback_entry_t
*
elmt
;
struct
libvlc_callback_entry_list_t
*
next
;
struct
libvlc_callback_entry_list_t
*
prev
;
};
struct
libvlc_instance_t
struct
libvlc_instance_t
{
{
libvlc_int_t
*
p_libvlc_int
;
libvlc_int_t
*
p_libvlc_int
;
vlm_t
*
p_vlm
;
vlm_t
*
p_vlm
;
int
b_playlist_locked
;
int
b_playlist_locked
;
vlc_mutex_t
instance_lock
;
vlc_mutex_t
instance_lock
;
struct
libvlc_callback_entry_list_t
*
p_callback_list
;
};
};
struct
libvlc_input_t
struct
libvlc_input_t
{
{
int
i_input_id
;
///< Input object id. We don't use a pointer to
int
i_input_id
;
///< Input object id. We don't use a pointer to
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment