Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
093de856
Commit
093de856
authored
Aug 02, 2006
by
Clément Stenac
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Interaction cleanup, remove some unused functions, factorize some code, ...
parent
7eee710f
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
223 additions
and
398 deletions
+223
-398
include/vlc_common.h
include/vlc_common.h
+3
-0
include/vlc_interaction.h
include/vlc_interaction.h
+9
-17
include/vlc_symbols.h
include/vlc_symbols.h
+18
-17
modules/demux/avi/avi.c
modules/demux/avi/avi.c
+2
-2
modules/services_discovery/shout.c
modules/services_discovery/shout.c
+4
-3
src/interface/interaction.c
src/interface/interaction.c
+156
-327
src/misc/update.c
src/misc/update.c
+31
-32
No files found.
include/vlc_common.h
View file @
093de856
...
@@ -618,10 +618,13 @@ static int64_t GCD( int64_t a, int64_t b )
...
@@ -618,10 +618,13 @@ static int64_t GCD( int64_t a, int64_t b )
if( !var ) goto error; }
if( !var ) goto error; }
#define DECMALLOC_VOID( var, type ) type* var = (type*)malloc( sizeof(type) );\
#define DECMALLOC_VOID( var, type ) type* var = (type*)malloc( sizeof(type) );\
if( !var ) return;
if( !var ) return;
#define DECMALLOC_ERR( var, type ) type* var = (type*)malloc( sizeof(type) );\
if( !var ) return VLC_ENOMEM;
#define DECMALLOC_NULL( var, type ) type* var = (type*)malloc( sizeof(type) );\
#define DECMALLOC_NULL( var, type ) type* var = (type*)malloc( sizeof(type) );\
if( !var ) return NULL;
if( !var ) return NULL;
#define FREENULL(a) if( a ) { free( a ); a = NULL; }
#define FREENULL(a) if( a ) { free( a ); a = NULL; }
#define FREE(a) if( a ) { free( a ); }
/* Dynamic array handling: realloc array, move data, increment position */
/* Dynamic array handling: realloc array, move data, increment position */
#if defined( _MSC_VER ) && _MSC_VER < 1300 && !defined( UNDER_CE )
#if defined( _MSC_VER ) && _MSC_VER < 1300 && !defined( UNDER_CE )
...
...
include/vlc_interaction.h
View file @
093de856
...
@@ -169,32 +169,24 @@ enum
...
@@ -169,32 +169,24 @@ enum
* Exported symbols
* Exported symbols
***************************************************************************/
***************************************************************************/
#define intf_Interact( a,b ) __intf_Interact( VLC_OBJECT(a), b )
VLC_EXPORT
(
int
,
__intf_Interact
,(
vlc_object_t
*
,
interaction_dialog_t
*
)
);
#define intf_UserFatal( a, b, c, d, e... ) __intf_UserFatal( VLC_OBJECT(a),b,c,d, ## e )
#define intf_UserFatal( a, b, c, d, e... ) __intf_UserFatal( VLC_OBJECT(a),b,c,d, ## e )
VLC_EXPORT
(
void
,
__intf_UserFatal
,(
vlc_object_t
*
,
vlc_bool_t
,
const
char
*
,
const
char
*
,
...)
);
VLC_EXPORT
(
int
,
__intf_UserFatal
,(
vlc_object_t
*
,
vlc_bool_t
,
const
char
*
,
const
char
*
,
...)
);
#define intf_UserWarn( a, c, d, e... ) __intf_UserWarn( VLC_OBJECT(a),c,d, ## e )
#define intf_UserWarn( a, c, d, e... ) __intf_UserWarn( VLC_OBJECT(a),c,d, ## e )
VLC_EXPORT
(
void
,
__intf_UserWarn
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
...)
);
VLC_EXPORT
(
int
,
__intf_UserWarn
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
...)
);
#define intf_UserLoginPassword( a, b, c, d, e... ) __intf_UserLoginPassword( VLC_OBJECT(a),b,c,d,e)
#define intf_UserLoginPassword( a, b, c, d, e... ) __intf_UserLoginPassword( VLC_OBJECT(a),b,c,d,e)
VLC_EXPORT
(
int
,
__intf_UserLoginPassword
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
char
**
,
char
**
)
);
VLC_EXPORT
(
int
,
__intf_UserLoginPassword
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
char
**
,
char
**
)
);
#define intf_UserYesNo( a, b, c, d, e, f ) __intf_UserYesNo( VLC_OBJECT(a),b,c, d, e, f )
#define intf_UserYesNo( a, b, c, d, e, f ) __intf_UserYesNo( VLC_OBJECT(a),b,c, d, e, f )
VLC_EXPORT
(
int
,
__intf_UserYesNo
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
)
);
VLC_EXPORT
(
int
,
__intf_UserYesNo
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
)
);
#define intf_UserProgress( a, b, c, d, e ) __intf_UserProgress( VLC_OBJECT(a),b,c,d,e )
VLC_EXPORT
(
int
,
__intf_UserProgress
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
float
,
int
)
);
#define intf_UserProgressUpdate( a, b, c, d, e ) __intf_UserProgressUpdate( VLC_OBJECT(a),b,c,d,e )
VLC_EXPORT
(
void
,
__intf_UserProgressUpdate
,(
vlc_object_t
*
,
int
,
const
char
*
,
float
,
int
)
);
#define intf_UserProgressIsCancelled( a, b ) __intf_UserProgressIsCancelled( VLC_OBJECT(a),b )
VLC_EXPORT
(
vlc_bool_t
,
__intf_UserProgressIsCancelled
,(
vlc_object_t
*
,
int
)
);
#define intf_UserStringInput( a, b, c, d ) __intf_UserStringInput( VLC_OBJECT(a),b,c,d )
#define intf_UserStringInput( a, b, c, d ) __intf_UserStringInput( VLC_OBJECT(a),b,c,d )
VLC_EXPORT
(
int
,
__intf_UserStringInput
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
char
**
)
);
VLC_EXPORT
(
int
,
__intf_UserStringInput
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
char
**
)
);
#define intf_IntfProgress( a, b, c ) __intf_IntfProgress( VLC_OBJECT(a),b,c )
#define intf_IntfProgress( a, b, c ) __intf_Progress( VLC_OBJECT(a), NULL, b,c, -1 )
VLC_EXPORT
(
int
,
__intf_IntfProgress
,(
vlc_object_t
*
,
const
char
*
,
float
)
);
#define intf_UserProgress( a, b, c, d, e ) __intf_Progress( VLC_OBJECT(a),b,c,d,e )
#define intf_IntfProgressUpdate( a, b, c, d ) __intf_IntfProgressUpdate( VLC_OBJECT(a),b,c,d )
VLC_EXPORT
(
int
,
__intf_Progress
,(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
float
,
int
)
);
VLC_EXPORT
(
void
,
__intf_IntfProgressUpdate
,(
vlc_object_t
*
,
int
,
const
char
*
,
float
)
);
#define intf_ProgressUpdate( a, b, c, d, e ) __intf_ProgressUpdate( VLC_OBJECT(a),b,c,d,e )
VLC_EXPORT
(
void
,
__intf_ProgressUpdate
,(
vlc_object_t
*
,
int
,
const
char
*
,
float
,
int
)
);
#define intf_ProgressIsCancelled( a, b ) __intf_UserProgressIsCancelled( VLC_OBJECT(a),b )
VLC_EXPORT
(
vlc_bool_t
,
__intf_UserProgressIsCancelled
,(
vlc_object_t
*
,
int
)
);
#define intf_UserHide( a, b ) __intf_UserHide( VLC_OBJECT(a), b )
#define intf_UserHide( a, b ) __intf_UserHide( VLC_OBJECT(a), b )
VLC_EXPORT
(
void
,
__intf_UserHide
,(
vlc_object_t
*
,
int
));
VLC_EXPORT
(
void
,
__intf_UserHide
,(
vlc_object_t
*
,
int
));
...
...
include/vlc_symbols.h
View file @
093de856
...
@@ -429,14 +429,14 @@ struct module_symbols_t
...
@@ -429,14 +429,14 @@ struct module_symbols_t
char
*
(
*
FromUTF32_inner
)
(
const
uint32_t
*
);
char
*
(
*
FromUTF32_inner
)
(
const
uint32_t
*
);
int
(
*
__input_Read_inner
)
(
vlc_object_t
*
,
input_item_t
*
,
vlc_bool_t
);
int
(
*
__input_Read_inner
)
(
vlc_object_t
*
,
input_item_t
*
,
vlc_bool_t
);
int
(
*
__net_ConnectUDP_inner
)
(
vlc_object_t
*
p_this
,
const
char
*
psz_host
,
int
i_port
,
int
hlim
);
int
(
*
__net_ConnectUDP_inner
)
(
vlc_object_t
*
p_this
,
const
char
*
psz_host
,
int
i_port
,
int
hlim
);
int
(
*
__intf_Interact_inner
)
(
vlc_object_t
*
,
interaction_dialog_t
*
)
;
void
*
__intf_Interact_deprecated
;
void
(
*
intf_InteractionManage_inner
)
(
playlist_t
*
);
void
(
*
intf_InteractionManage_inner
)
(
playlist_t
*
);
void
(
*
intf_InteractionDestroy_inner
)
(
interaction_t
*
);
void
(
*
intf_InteractionDestroy_inner
)
(
interaction_t
*
);
void
(
*
__intf_UserFatal_inner
)
(
vlc_object_t
*
,
vlc_bool_t
,
const
char
*
,
const
char
*
,
...);
int
(
*
__intf_UserFatal_inner
)
(
vlc_object_t
*
,
vlc_bool_t
,
const
char
*
,
const
char
*
,
...);
int
(
*
__intf_UserLoginPassword_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
char
**
,
char
**
);
int
(
*
__intf_UserLoginPassword_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
char
**
,
char
**
);
int
(
*
__intf_UserYesNo_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
);
int
(
*
__intf_UserYesNo_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
,
const
char
*
);
int
(
*
__intf_UserProgress_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
float
,
int
)
;
void
*
__intf_UserProgress_deprecated
;
void
(
*
__intf_UserProgressUpdate_inner
)
(
vlc_object_t
*
,
int
,
const
char
*
,
float
,
int
)
;
void
*
__intf_UserProgressUpdate_deprecated
;
void
(
*
__intf_UserHide_inner
)
(
vlc_object_t
*
,
int
);
void
(
*
__intf_UserHide_inner
)
(
vlc_object_t
*
,
int
);
void
*
__stats_Create_deprecated
;
void
*
__stats_Create_deprecated
;
int
(
*
__stats_Update_inner
)
(
vlc_object_t
*
,
counter_t
*
,
vlc_value_t
,
vlc_value_t
*
);
int
(
*
__stats_Update_inner
)
(
vlc_object_t
*
,
counter_t
*
,
vlc_value_t
,
vlc_value_t
*
);
...
@@ -517,11 +517,13 @@ struct module_symbols_t
...
@@ -517,11 +517,13 @@ struct module_symbols_t
void
*
stats_TimerClean_deprecated
;
void
*
stats_TimerClean_deprecated
;
void
*
stats_TimersClean_deprecated
;
void
*
stats_TimersClean_deprecated
;
void
(
*
__stats_TimersClean_inner
)
(
vlc_object_t
*
);
void
(
*
__stats_TimersClean_inner
)
(
vlc_object_t
*
);
void
(
*
__intf_IntfProgressUpdate_inner
)
(
vlc_object_t
*
,
int
,
const
char
*
,
float
)
;
void
*
__intf_IntfProgressUpdate_deprecated
;
int
(
*
__intf_IntfProgress_inner
)
(
vlc_object_t
*
,
const
char
*
,
float
)
;
void
*
__intf_IntfProgress_deprecated
;
void
*
streaming_ChainToPsz_deprecated
;
void
*
streaming_ChainToPsz_deprecated
;
void
(
*
__intf_UserWarn_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
...);
int
(
*
__intf_UserWarn_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
...);
vlc_bool_t
(
*
__intf_UserProgressIsCancelled_inner
)
(
vlc_object_t
*
,
int
);
vlc_bool_t
(
*
__intf_UserProgressIsCancelled_inner
)
(
vlc_object_t
*
,
int
);
int
(
*
__intf_Progress_inner
)
(
vlc_object_t
*
,
const
char
*
,
const
char
*
,
float
,
int
);
void
(
*
__intf_ProgressUpdate_inner
)
(
vlc_object_t
*
,
int
,
const
char
*
,
float
,
int
);
};
};
# if defined (__PLUGIN__)
# if defined (__PLUGIN__)
# define aout_FiltersCreatePipeline (p_symbols)->aout_FiltersCreatePipeline_inner
# define aout_FiltersCreatePipeline (p_symbols)->aout_FiltersCreatePipeline_inner
...
@@ -908,14 +910,11 @@ struct module_symbols_t
...
@@ -908,14 +910,11 @@ struct module_symbols_t
# define FromUTF32 (p_symbols)->FromUTF32_inner
# define FromUTF32 (p_symbols)->FromUTF32_inner
# define __input_Read (p_symbols)->__input_Read_inner
# define __input_Read (p_symbols)->__input_Read_inner
# define __net_ConnectUDP (p_symbols)->__net_ConnectUDP_inner
# define __net_ConnectUDP (p_symbols)->__net_ConnectUDP_inner
# define __intf_Interact (p_symbols)->__intf_Interact_inner
# define intf_InteractionManage (p_symbols)->intf_InteractionManage_inner
# define intf_InteractionManage (p_symbols)->intf_InteractionManage_inner
# define intf_InteractionDestroy (p_symbols)->intf_InteractionDestroy_inner
# define intf_InteractionDestroy (p_symbols)->intf_InteractionDestroy_inner
# define __intf_UserFatal (p_symbols)->__intf_UserFatal_inner
# define __intf_UserFatal (p_symbols)->__intf_UserFatal_inner
# define __intf_UserLoginPassword (p_symbols)->__intf_UserLoginPassword_inner
# define __intf_UserLoginPassword (p_symbols)->__intf_UserLoginPassword_inner
# define __intf_UserYesNo (p_symbols)->__intf_UserYesNo_inner
# define __intf_UserYesNo (p_symbols)->__intf_UserYesNo_inner
# define __intf_UserProgress (p_symbols)->__intf_UserProgress_inner
# define __intf_UserProgressUpdate (p_symbols)->__intf_UserProgressUpdate_inner
# define __intf_UserHide (p_symbols)->__intf_UserHide_inner
# define __intf_UserHide (p_symbols)->__intf_UserHide_inner
# define __stats_Update (p_symbols)->__stats_Update_inner
# define __stats_Update (p_symbols)->__stats_Update_inner
# define __stats_Get (p_symbols)->__stats_Get_inner
# define __stats_Get (p_symbols)->__stats_Get_inner
...
@@ -988,10 +987,10 @@ struct module_symbols_t
...
@@ -988,10 +987,10 @@ struct module_symbols_t
# define input_AddSubtitles (p_symbols)->input_AddSubtitles_inner
# define input_AddSubtitles (p_symbols)->input_AddSubtitles_inner
# define __stats_CounterCreate (p_symbols)->__stats_CounterCreate_inner
# define __stats_CounterCreate (p_symbols)->__stats_CounterCreate_inner
# define __stats_TimersClean (p_symbols)->__stats_TimersClean_inner
# define __stats_TimersClean (p_symbols)->__stats_TimersClean_inner
# define __intf_IntfProgressUpdate (p_symbols)->__intf_IntfProgressUpdate_inner
# define __intf_IntfProgress (p_symbols)->__intf_IntfProgress_inner
# define __intf_UserWarn (p_symbols)->__intf_UserWarn_inner
# define __intf_UserWarn (p_symbols)->__intf_UserWarn_inner
# define __intf_UserProgressIsCancelled (p_symbols)->__intf_UserProgressIsCancelled_inner
# define __intf_UserProgressIsCancelled (p_symbols)->__intf_UserProgressIsCancelled_inner
# define __intf_Progress (p_symbols)->__intf_Progress_inner
# define __intf_ProgressUpdate (p_symbols)->__intf_ProgressUpdate_inner
# elif defined (HAVE_DYNAMIC_PLUGINS) && !defined (__BUILTIN__)
# elif defined (HAVE_DYNAMIC_PLUGINS) && !defined (__BUILTIN__)
/******************************************************************
/******************************************************************
* STORE_SYMBOLS: store VLC APIs into p_symbols for plugin access.
* STORE_SYMBOLS: store VLC APIs into p_symbols for plugin access.
...
@@ -1381,14 +1380,11 @@ struct module_symbols_t
...
@@ -1381,14 +1380,11 @@ struct module_symbols_t
((p_symbols)->FromUTF32_inner) = FromUTF32; \
((p_symbols)->FromUTF32_inner) = FromUTF32; \
((p_symbols)->__input_Read_inner) = __input_Read; \
((p_symbols)->__input_Read_inner) = __input_Read; \
((p_symbols)->__net_ConnectUDP_inner) = __net_ConnectUDP; \
((p_symbols)->__net_ConnectUDP_inner) = __net_ConnectUDP; \
((p_symbols)->__intf_Interact_inner) = __intf_Interact; \
((p_symbols)->intf_InteractionManage_inner) = intf_InteractionManage; \
((p_symbols)->intf_InteractionManage_inner) = intf_InteractionManage; \
((p_symbols)->intf_InteractionDestroy_inner) = intf_InteractionDestroy; \
((p_symbols)->intf_InteractionDestroy_inner) = intf_InteractionDestroy; \
((p_symbols)->__intf_UserFatal_inner) = __intf_UserFatal; \
((p_symbols)->__intf_UserFatal_inner) = __intf_UserFatal; \
((p_symbols)->__intf_UserLoginPassword_inner) = __intf_UserLoginPassword; \
((p_symbols)->__intf_UserLoginPassword_inner) = __intf_UserLoginPassword; \
((p_symbols)->__intf_UserYesNo_inner) = __intf_UserYesNo; \
((p_symbols)->__intf_UserYesNo_inner) = __intf_UserYesNo; \
((p_symbols)->__intf_UserProgress_inner) = __intf_UserProgress; \
((p_symbols)->__intf_UserProgressUpdate_inner) = __intf_UserProgressUpdate; \
((p_symbols)->__intf_UserHide_inner) = __intf_UserHide; \
((p_symbols)->__intf_UserHide_inner) = __intf_UserHide; \
((p_symbols)->__stats_Update_inner) = __stats_Update; \
((p_symbols)->__stats_Update_inner) = __stats_Update; \
((p_symbols)->__stats_Get_inner) = __stats_Get; \
((p_symbols)->__stats_Get_inner) = __stats_Get; \
...
@@ -1461,10 +1457,10 @@ struct module_symbols_t
...
@@ -1461,10 +1457,10 @@ struct module_symbols_t
((p_symbols)->input_AddSubtitles_inner) = input_AddSubtitles; \
((p_symbols)->input_AddSubtitles_inner) = input_AddSubtitles; \
((p_symbols)->__stats_CounterCreate_inner) = __stats_CounterCreate; \
((p_symbols)->__stats_CounterCreate_inner) = __stats_CounterCreate; \
((p_symbols)->__stats_TimersClean_inner) = __stats_TimersClean; \
((p_symbols)->__stats_TimersClean_inner) = __stats_TimersClean; \
((p_symbols)->__intf_IntfProgressUpdate_inner) = __intf_IntfProgressUpdate; \
((p_symbols)->__intf_IntfProgress_inner) = __intf_IntfProgress; \
((p_symbols)->__intf_UserWarn_inner) = __intf_UserWarn; \
((p_symbols)->__intf_UserWarn_inner) = __intf_UserWarn; \
((p_symbols)->__intf_UserProgressIsCancelled_inner) = __intf_UserProgressIsCancelled; \
((p_symbols)->__intf_UserProgressIsCancelled_inner) = __intf_UserProgressIsCancelled; \
((p_symbols)->__intf_Progress_inner) = __intf_Progress; \
((p_symbols)->__intf_ProgressUpdate_inner) = __intf_ProgressUpdate; \
(p_symbols)->net_ConvertIPv4_deprecated = NULL; \
(p_symbols)->net_ConvertIPv4_deprecated = NULL; \
(p_symbols)->__playlist_ItemCopy_deprecated = NULL; \
(p_symbols)->__playlist_ItemCopy_deprecated = NULL; \
(p_symbols)->playlist_ItemAddParent_deprecated = NULL; \
(p_symbols)->playlist_ItemAddParent_deprecated = NULL; \
...
@@ -1491,6 +1487,9 @@ struct module_symbols_t
...
@@ -1491,6 +1487,9 @@ struct module_symbols_t
(p_symbols)->playlist_Sort_deprecated = NULL; \
(p_symbols)->playlist_Sort_deprecated = NULL; \
(p_symbols)->playlist_Move_deprecated = NULL; \
(p_symbols)->playlist_Move_deprecated = NULL; \
(p_symbols)->playlist_NodeRemoveParent_deprecated = NULL; \
(p_symbols)->playlist_NodeRemoveParent_deprecated = NULL; \
(p_symbols)->__intf_Interact_deprecated = NULL; \
(p_symbols)->__intf_UserProgress_deprecated = NULL; \
(p_symbols)->__intf_UserProgressUpdate_deprecated = NULL; \
(p_symbols)->__stats_Create_deprecated = NULL; \
(p_symbols)->__stats_Create_deprecated = NULL; \
(p_symbols)->__stats_CounterGet_deprecated = NULL; \
(p_symbols)->__stats_CounterGet_deprecated = NULL; \
(p_symbols)->stats_HandlerDestroy_deprecated = NULL; \
(p_symbols)->stats_HandlerDestroy_deprecated = NULL; \
...
@@ -1499,6 +1498,8 @@ struct module_symbols_t
...
@@ -1499,6 +1498,8 @@ struct module_symbols_t
(p_symbols)->__intf_UserOkayCancel_deprecated = NULL; \
(p_symbols)->__intf_UserOkayCancel_deprecated = NULL; \
(p_symbols)->stats_TimerClean_deprecated = NULL; \
(p_symbols)->stats_TimerClean_deprecated = NULL; \
(p_symbols)->stats_TimersClean_deprecated = NULL; \
(p_symbols)->stats_TimersClean_deprecated = NULL; \
(p_symbols)->__intf_IntfProgressUpdate_deprecated = NULL; \
(p_symbols)->__intf_IntfProgress_deprecated = NULL; \
(p_symbols)->streaming_ChainToPsz_deprecated = NULL; \
(p_symbols)->streaming_ChainToPsz_deprecated = NULL; \
# endif
/* __PLUGIN__ */
# endif
/* __PLUGIN__ */
...
...
modules/demux/avi/avi.c
View file @
093de856
...
@@ -2298,8 +2298,8 @@ static void AVI_IndexCreate( demux_t *p_demux )
...
@@ -2298,8 +2298,8 @@ static void AVI_IndexCreate( demux_t *p_demux )
stream_Size
(
p_demux
->
s
);
stream_Size
(
p_demux
->
s
);
float
f_pos
=
(
float
)
i_pos
;
float
f_pos
=
(
float
)
i_pos
;
p_demux
->
p_sys
->
last_update
=
mdate
();
p_demux
->
p_sys
->
last_update
=
mdate
();
intf_
Intf
ProgressUpdate
(
p_demux
,
p_demux
->
p_sys
->
i_dialog_id
,
intf_ProgressUpdate
(
p_demux
,
p_demux
->
p_sys
->
i_dialog_id
,
_
(
"Fixing AVI Index..."
),
f_pos
);
_
(
"Fixing AVI Index..."
),
f_pos
,
-
1
);
}
}
if
(
AVI_PacketGetHeader
(
p_demux
,
&
pk
)
)
if
(
AVI_PacketGetHeader
(
p_demux
,
&
pk
)
)
...
...
modules/services_discovery/shout.c
View file @
093de856
...
@@ -196,7 +196,8 @@ static void Run( services_discovery_t *p_sd )
...
@@ -196,7 +196,8 @@ static void Run( services_discovery_t *p_sd )
int
i_id
=
input_Read
(
p_sd
,
p_sys
->
p_input
,
VLC_FALSE
);
int
i_id
=
input_Read
(
p_sd
,
p_sys
->
p_input
,
VLC_FALSE
);
int
i_dialog_id
;
int
i_dialog_id
;
i_dialog_id
=
intf_UserProgress
(
p_sd
,
"Shoutcast"
,
"Connecting..."
,
0
.
0
,
0
);
i_dialog_id
=
intf_UserProgress
(
p_sd
,
"Shoutcast"
,
_
(
"Connecting..."
)
,
0
.
0
,
0
);
p_sys
->
b_dialog
=
VLC_TRUE
;
p_sys
->
b_dialog
=
VLC_TRUE
;
while
(
!
p_sd
->
b_die
)
while
(
!
p_sd
->
b_die
)
...
@@ -214,8 +215,8 @@ static void Run( services_discovery_t *p_sd )
...
@@ -214,8 +215,8 @@ static void Run( services_discovery_t *p_sd )
{
{
float
f_pos
=
(
float
)(
p_sys
->
p_node_cat
->
i_children
)
*
2
*
100
.
0
/
float
f_pos
=
(
float
)(
p_sys
->
p_node_cat
->
i_children
)
*
2
*
100
.
0
/
260
/* gruiiik FIXME */
;
260
/* gruiiik FIXME */
;
intf_
User
ProgressUpdate
(
p_sd
,
i_dialog_id
,
"Downloading"
,
intf_ProgressUpdate
(
p_sd
,
i_dialog_id
,
"Downloading"
,
f_pos
,
0
);
f_pos
,
0
);
}
}
vlc_object_release
(
p_input
);
vlc_object_release
(
p_input
);
}
}
...
...
src/interface/interaction.c
View file @
093de856
...
@@ -36,6 +36,7 @@
...
@@ -36,6 +36,7 @@
#include <vlc/vlc.h>
#include <vlc/vlc.h>
#include <vlc/input.h>
#include <vlc/input.h>
#include <assert.h>
#include "vlc_interaction.h"
#include "vlc_interaction.h"
#include "vlc_interface.h"
#include "vlc_interface.h"
...
@@ -44,57 +45,13 @@
...
@@ -44,57 +45,13 @@
/*****************************************************************************
/*****************************************************************************
* Local prototypes
* Local prototypes
*****************************************************************************/
*****************************************************************************/
static
void
intf_
InteractionInit
(
playlist_t
*
p_playlist
);
static
void
InteractionInit
(
playlist_t
*
p_playlist
);
static
interaction_t
*
intf_
InteractionGet
(
vlc_object_t
*
p_this
);
static
interaction_t
*
InteractionGet
(
vlc_object_t
*
p_this
);
static
void
intf_
InteractionSearchInterface
(
interaction_t
*
static
void
InteractionSearchInterface
(
interaction_t
*
p_interaction
);
p_interaction
);
static
int
intf_WaitAnswer
(
interaction_t
*
p_interact
,
static
interaction_dialog_t
*
DialogGetById
(
interaction_t
*
,
int
);
interaction_dialog_t
*
p_dialog
);
static
void
DialogDestroy
(
interaction_dialog_t
*
p_dialog
);
static
int
intf_Send
(
interaction_t
*
p_interact
,
static
int
DialogSend
(
vlc_object_t
*
p_this
,
interaction_dialog_t
*
p_dialog
);
interaction_dialog_t
*
p_dialog
);
static
interaction_dialog_t
*
intf_InteractionGetById
(
vlc_object_t
*
,
int
);
static
void
intf_InteractionDialogDestroy
(
interaction_dialog_t
*
p_dialog
);
/**
* Send an interaction element to the user
*
* \param p_this the calling vlc_object_t
* \param p_interact the interaction element
* \return VLC_SUCCESS or an error code
*/
int
__intf_Interact
(
vlc_object_t
*
p_this
,
interaction_dialog_t
*
p_dialog
)
{
interaction_t
*
p_interaction
=
intf_InteractionGet
(
p_this
);
/* Get an id, if we don't already have one */
if
(
p_dialog
->
i_id
==
0
)
{
p_dialog
->
i_id
=
++
p_interaction
->
i_last_id
;
}
if
(
p_this
->
i_flags
&
OBJECT_FLAGS_NOINTERACT
)
return
VLC_EGENERIC
;
if
(
config_GetInt
(
p_this
,
"interact"
)
||
p_dialog
->
i_flags
&
DIALOG_BLOCKING_ERROR
||
p_dialog
->
i_flags
&
DIALOG_NONBLOCKING_ERROR
)
{
p_dialog
->
p_interaction
=
p_interaction
;
p_dialog
->
p_parent
=
p_this
;
if
(
p_dialog
->
i_type
==
INTERACT_DIALOG_TWOWAY
)
{
return
intf_WaitAnswer
(
p_interaction
,
p_dialog
);
}
else
{
p_dialog
->
i_flags
|=
DIALOG_GOT_ANSWER
;
return
intf_Send
(
p_interaction
,
p_dialog
);
}
}
else
return
VLC_EGENERIC
;
}
/**
/**
* Destroy the interaction system
* Destroy the interaction system
...
@@ -104,16 +61,13 @@ int __intf_Interact( vlc_object_t *p_this, interaction_dialog_t *p_dialog )
...
@@ -104,16 +61,13 @@ int __intf_Interact( vlc_object_t *p_this, interaction_dialog_t *p_dialog )
void
intf_InteractionDestroy
(
interaction_t
*
p_interaction
)
void
intf_InteractionDestroy
(
interaction_t
*
p_interaction
)
{
{
int
i
;
int
i
;
// Remove all dialogs - Interfaces must be able to clean up their data
// Remove all dialogs - Interfaces must be able to clean up their data
for
(
i
=
p_interaction
->
i_dialogs
-
1
;
i
>=
0
;
i
--
)
for
(
i
=
p_interaction
->
i_dialogs
-
1
;
i
>=
0
;
i
--
)
{
{
interaction_dialog_t
*
p_dialog
=
p_interaction
->
pp_dialogs
[
i
];
interaction_dialog_t
*
p_dialog
=
p_interaction
->
pp_dialogs
[
i
];
intf_Interaction
DialogDestroy
(
p_dialog
);
DialogDestroy
(
p_dialog
);
REMOVE_ELEM
(
p_interaction
->
pp_dialogs
,
p_interaction
->
i_dialogs
,
i
);
REMOVE_ELEM
(
p_interaction
->
pp_dialogs
,
p_interaction
->
i_dialogs
,
i
);
}
}
vlc_object_destroy
(
p_interaction
);
vlc_object_destroy
(
p_interaction
);
}
}
...
@@ -128,26 +82,21 @@ void intf_InteractionManage( playlist_t *p_playlist )
...
@@ -128,26 +82,21 @@ void intf_InteractionManage( playlist_t *p_playlist )
{
{
vlc_value_t
val
;
vlc_value_t
val
;
int
i_index
;
int
i_index
;
interaction_t
*
p_interaction
;
interaction_t
*
p_interaction
=
p_playlist
->
p_interaction
;
p_interaction
=
p_playlist
->
p_interaction
;
// Nothing to do
// Nothing to do
if
(
p_interaction
->
i_dialogs
==
0
)
return
;
if
(
p_interaction
->
i_dialogs
==
0
)
return
;
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
intf_InteractionSearchInterface
(
p_interaction
);
InteractionSearchInterface
(
p_interaction
);
if
(
!
p_interaction
->
p_intf
)
if
(
!
p_interaction
->
p_intf
)
{
{
// We mark all dialogs as answered with their "default" answer
// We mark all dialogs as answered with their "default" answer
for
(
i_index
=
0
;
i_index
<
p_interaction
->
i_dialogs
;
i_index
++
)
for
(
i_index
=
0
;
i_index
<
p_interaction
->
i_dialogs
;
i_index
++
)
{
{
interaction_dialog_t
*
p_dialog
=
p_interaction
->
pp_dialogs
[
i_index
];
interaction_dialog_t
*
p_dialog
=
p_interaction
->
pp_dialogs
[
i_index
];
p_dialog
->
i_return
=
DIALOG_DEFAULT
;
// Give default answer
// Give default answer
p_dialog
->
i_return
=
DIALOG_DEFAULT
;
// Pretend we have hidden and destroyed it
// Pretend we have hidden and destroyed it
if
(
p_dialog
->
i_status
==
HIDDEN_DIALOG
)
if
(
p_dialog
->
i_status
==
HIDDEN_DIALOG
)
...
@@ -200,7 +149,7 @@ void intf_InteractionManage( playlist_t *p_playlist )
...
@@ -200,7 +149,7 @@ void intf_InteractionManage( playlist_t *p_playlist )
REMOVE_ELEM
(
p_interaction
->
pp_dialogs
,
p_interaction
->
i_dialogs
,
REMOVE_ELEM
(
p_interaction
->
pp_dialogs
,
p_interaction
->
i_dialogs
,
i_index
);
i_index
);
i_index
--
;
i_index
--
;
intf_Interaction
DialogDestroy
(
p_dialog
);
DialogDestroy
(
p_dialog
);
break
;
break
;
case
NEW_DIALOG
:
case
NEW_DIALOG
:
// This is truly a new dialog, send it.
// This is truly a new dialog, send it.
...
@@ -221,55 +170,42 @@ void intf_InteractionManage( playlist_t *p_playlist )
...
@@ -221,55 +170,42 @@ void intf_InteractionManage( playlist_t *p_playlist )
vlc_mutex_unlock
(
&
p_playlist
->
p_interaction
->
object_lock
);
vlc_mutex_unlock
(
&
p_playlist
->
p_interaction
->
object_lock
);
}
}
#define DIALOG_INIT( type ) \
#define INTERACT_INIT( new ) \
DECMALLOC_ERR( p_new, interaction_dialog_t ); \
new = (interaction_dialog_t*)malloc( \
memset( p_new, 0, sizeof( interaction_dialog_t ) ); \
sizeof( interaction_dialog_t ) ); \
p_new->b_cancelled = VLC_FALSE; \
new->psz_title = NULL; \
p_new->i_status = NEW_DIALOG; \
new->psz_description = NULL; \
p_new->i_type = INTERACT_DIALOG_##type; \
new->psz_default_button = NULL; \
p_new->psz_returned[0] = NULL; \
new->psz_alternate_button = NULL; \
p_new->psz_returned[1] = NULL;
new->psz_other_button = NULL; \
new->i_timeToGo = 0; \
#define FORMAT_DESC \
new->b_cancelled = VLC_FALSE; \
va_start( args, psz_format ); \
new->p_private = NULL; \
vasprintf( &p_new->psz_description, psz_format, args ); \
new->i_id = 0; \
va_end( args );
new->i_flags = 0; \
new->i_status = NEW_DIALOG;
/** Send an error message, both in a blocking and non-blocking way
#define INTERACT_FREE( new ) \
if( new->psz_title ) free( new->psz_title ); \
if( new->psz_description ) free( new->psz_description );
/** Helper function to send an error message, both in a blocking and non-blocking way
* \param p_this Parent vlc_object
* \param p_this Parent vlc_object
* \param b_blocking Is this dialog blocking or not?
* \param b_blocking Is this dialog blocking or not?
* \param psz_title Title for the dialog
* \param psz_title Title for the dialog
* \param psz_format The message to display
* \param psz_format The message to display
* */
* */
void
__intf_UserFatal
(
vlc_object_t
*
p_this
,
int
__intf_UserFatal
(
vlc_object_t
*
p_this
,
vlc_bool_t
b_blocking
,
vlc_bool_t
b_blocking
,
const
char
*
psz_title
,
const
char
*
psz_title
,
const
char
*
psz_format
,
...
)
const
char
*
psz_format
,
...
)
{
{
va_list
args
;
va_list
args
;
interaction_dialog_t
*
p_new
=
NULL
;
DIALOG_INIT
(
ONEWAY
);
INTERACT_INIT
(
p_new
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
i_type
=
INTERACT_DIALOG_ONEWAY
;
FORMAT_DESC
;
va_start
(
args
,
psz_format
);
vasprintf
(
&
p_new
->
psz_description
,
psz_format
,
args
);
va_end
(
args
);
if
(
b_blocking
)
if
(
b_blocking
)
p_new
->
i_flags
=
DIALOG_BLOCKING_ERROR
;
p_new
->
i_flags
=
DIALOG_BLOCKING_ERROR
;
else
else
p_new
->
i_flags
=
DIALOG_NONBLOCKING_ERROR
;
p_new
->
i_flags
=
DIALOG_NONBLOCKING_ERROR
;
intf_Interact
(
p_this
,
p_new
);
return
DialogSend
(
p_this
,
p_new
);
}
}
/** Helper function to send an warning, which is always shown non-blocking
/** Helper function to send an warning, which is always shown non-blocking
...
@@ -277,25 +213,19 @@ void __intf_UserFatal( vlc_object_t *p_this,
...
@@ -277,25 +213,19 @@ void __intf_UserFatal( vlc_object_t *p_this,
* \param psz_title Title for the dialog
* \param psz_title Title for the dialog
* \param psz_format The message to display
* \param psz_format The message to display
* */
* */
void
__intf_UserWarn
(
vlc_object_t
*
p_this
,
int
__intf_UserWarn
(
vlc_object_t
*
p_this
,
const
char
*
psz_title
,
const
char
*
psz_title
,
const
char
*
psz_format
,
...
)
const
char
*
psz_format
,
...
)
{
{
va_list
args
;
va_list
args
;
interaction_dialog_t
*
p_new
=
NULL
;
DIALOG_INIT
(
ONEWAY
);
INTERACT_INIT
(
p_new
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
i_type
=
INTERACT_DIALOG_ONEWAY
;
FORMAT_DESC
va_start
(
args
,
psz_format
);
vasprintf
(
&
p_new
->
psz_description
,
psz_format
,
args
);
va_end
(
args
);
p_new
->
i_flags
=
DIALOG_WARNING
;
p_new
->
i_flags
=
DIALOG_WARNING
;
intf_Interact
(
p_this
,
p_new
);
return
DialogSend
(
p_this
,
p_new
);
}
}
/** Helper function to ask a yes-no-cancel question
/** Helper function to ask a yes-no-cancel question
...
@@ -314,12 +244,8 @@ int __intf_UserYesNo( vlc_object_t *p_this,
...
@@ -314,12 +244,8 @@ int __intf_UserYesNo( vlc_object_t *p_this,
const
char
*
psz_alternate
,
const
char
*
psz_alternate
,
const
char
*
psz_other
)
const
char
*
psz_other
)
{
{
int
i_ret
;
DIALOG_INIT
(
TWOWAY
);
interaction_dialog_t
*
p_new
=
NULL
;
INTERACT_INIT
(
p_new
);
p_new
->
i_type
=
INTERACT_DIALOG_TWOWAY
;
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_description
=
strdup
(
psz_description
);
p_new
->
psz_description
=
strdup
(
psz_description
);
p_new
->
i_flags
=
DIALOG_YES_NO_CANCEL
;
p_new
->
i_flags
=
DIALOG_YES_NO_CANCEL
;
...
@@ -327,43 +253,35 @@ int __intf_UserYesNo( vlc_object_t *p_this,
...
@@ -327,43 +253,35 @@ int __intf_UserYesNo( vlc_object_t *p_this,
p_new
->
psz_alternate_button
=
strdup
(
psz_alternate
);
p_new
->
psz_alternate_button
=
strdup
(
psz_alternate
);
if
(
psz_other
)
if
(
psz_other
)
p_new
->
psz_other_button
=
strdup
(
psz_other
);
p_new
->
psz_other_button
=
strdup
(
psz_other
);
else
p_new
->
psz_other_button
=
NULL
;
i_ret
=
intf_Interact
(
p_this
,
p_new
);
return
i_ret
;
return
DialogSend
(
p_this
,
p_new
)
;
}
}
/** Helper function to create a dialogue showing a progress-bar with some info
/** Helper function to create a dialogue showing a progress-bar with some info
* \param p_this Parent vlc_object
* \param p_this Parent vlc_object
* \param psz_title Title for the dialog
* \param psz_title Title for the dialog
(NULL implies main intf )
* \param psz_status Current status
* \param psz_status Current status
* \param f_position Current position (0.0->100.0)
* \param f_position Current position (0.0->100.0)
* \param i_timeToGo Time (in sec) to go until process is finished
* \param i_timeToGo Time (in sec) to go until process is finished
* \return Dialog id, to give to UserProgressUpdate
* \return Dialog id, to give to UserProgressUpdate
*/
*/
int
__intf_UserProgress
(
vlc_object_t
*
p_this
,
int
__intf_Progress
(
vlc_object_t
*
p_this
,
const
char
*
psz_title
,
const
char
*
psz_title
,
const
char
*
psz_status
,
float
f_pos
,
int
i_time
)
const
char
*
psz_status
,
float
f_pos
,
int
i_time
)
{
{
int
i_ret
;
DIALOG_INIT
(
ONEWAY
);
interaction_dialog_t
*
p_new
=
NULL
;
INTERACT_INIT
(
p_new
);
p_new
->
i_type
=
INTERACT_DIALOG_ONEWAY
;
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_description
=
strdup
(
psz_status
);
p_new
->
psz_description
=
strdup
(
psz_status
);
p_new
->
val
.
f_float
=
f_pos
;
p_new
->
val
.
f_float
=
f_pos
;
p_new
->
i_timeToGo
=
i_time
;
p_new
->
i_timeToGo
=
i_time
;
p_new
->
i_flags
=
DIALOG_USER_PROGRESS
;
if
(
psz_title
)
{
i_ret
=
intf_Interact
(
p_this
,
p_new
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
i_flags
=
DIALOG_USER_PROGRESS
;
}
else
p_new
->
i_flags
=
DIALOG_INTF_PROGRESS
;
DialogSend
(
p_this
,
p_new
);
return
p_new
->
i_id
;
return
p_new
->
i_id
;
}
}
...
@@ -375,17 +293,16 @@ int __intf_UserProgress( vlc_object_t *p_this,
...
@@ -375,17 +293,16 @@ int __intf_UserProgress( vlc_object_t *p_this,
* \param i_timeToGo Time (in sec) to go until process is finished
* \param i_timeToGo Time (in sec) to go until process is finished
* \return nothing
* \return nothing
*/
*/
void
__intf_UserProgressUpdate
(
vlc_object_t
*
p_this
,
int
i_id
,
void
__intf_ProgressUpdate
(
vlc_object_t
*
p_this
,
int
i_id
,
const
char
*
psz_status
,
float
f_pos
,
const
char
*
psz_status
,
float
f_pos
,
int
i_time
)
int
i_time
)
{
{
interaction_t
*
p_interaction
=
intf_
InteractionGet
(
p_this
);
interaction_t
*
p_interaction
=
InteractionGet
(
p_this
);
interaction_dialog_t
*
p_dialog
;
interaction_dialog_t
*
p_dialog
;
if
(
!
p_interaction
)
return
;
if
(
!
p_interaction
)
return
;
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
p_dialog
=
intf_InteractionGetById
(
p_this
,
i_id
);
p_dialog
=
DialogGetById
(
p_interaction
,
i_id
);
if
(
!
p_dialog
)
if
(
!
p_dialog
)
{
{
...
@@ -393,8 +310,7 @@ void __intf_UserProgressUpdate( vlc_object_t *p_this, int i_id,
...
@@ -393,8 +310,7 @@ void __intf_UserProgressUpdate( vlc_object_t *p_this, int i_id,
return
;
return
;
}
}
if
(
p_dialog
->
psz_description
)
FREE
(
p_dialog
->
psz_description
);
free
(
p_dialog
->
psz_description
);
p_dialog
->
psz_description
=
strdup
(
psz_status
);
p_dialog
->
psz_description
=
strdup
(
psz_status
);
p_dialog
->
val
.
f_float
=
f_pos
;
p_dialog
->
val
.
f_float
=
f_pos
;
...
@@ -404,29 +320,31 @@ void __intf_UserProgressUpdate( vlc_object_t *p_this, int i_id,
...
@@ -404,29 +320,31 @@ void __intf_UserProgressUpdate( vlc_object_t *p_this, int i_id,
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
}
}
/** Helper function to communicate dialogue cancellations between the intf-module and caller
/** Helper function to communicate dialogue cancellations between the
* interface module and the caller
* \param p_this Parent vlc_object
* \param p_this Parent vlc_object
* \param i_id Identifier of the dialogue
* \param i_id Identifier of the dialogue
* \return Either true or false
* \return Either true or false
*/
*/
vlc_bool_t
__intf_UserProgressIsCancelled
(
vlc_object_t
*
p_this
,
int
i_id
)
vlc_bool_t
__intf_UserProgressIsCancelled
(
vlc_object_t
*
p_this
,
int
i_id
)
{
{
interaction_t
*
p_interaction
=
intf_
InteractionGet
(
p_this
);
interaction_t
*
p_interaction
=
InteractionGet
(
p_this
);
interaction_dialog_t
*
p_dialog
;
interaction_dialog_t
*
p_dialog
;
vlc_bool_t
b_cancel
;
if
(
!
p_interaction
)
return
VLC_TRUE
;
if
(
!
p_interaction
)
return
VLC_TRUE
;
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
p_dialog
=
intf_InteractionGetById
(
p_this
,
i_id
);
p_dialog
=
DialogGetById
(
p_interaction
,
i_id
);
if
(
!
p_dialog
)
if
(
!
p_dialog
)
{
{
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
return
VLC_TRUE
;
return
VLC_TRUE
;
}
}
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
b_cancel
=
p_dialog
->
b_cancelled
;
return
p_dialog
->
b_cancelled
;
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
);
return
b_cancel
;
}
}
/** Helper function to make a login/password dialogue
/** Helper function to make a login/password dialogue
...
@@ -443,22 +361,19 @@ int __intf_UserLoginPassword( vlc_object_t *p_this,
...
@@ -443,22 +361,19 @@ int __intf_UserLoginPassword( vlc_object_t *p_this,
char
**
ppsz_login
,
char
**
ppsz_login
,
char
**
ppsz_password
)
char
**
ppsz_password
)
{
{
int
i_ret
;
int
i_ret
;
interaction_dialog_t
*
p_new
=
NULL
;
DIALOG_INIT
(
TWOWAY
);
INTERACT_INIT
(
p_new
);
p_new
->
i_type
=
INTERACT_DIALOG_TWOWAY
;
p_new
->
i_type
=
INTERACT_DIALOG_TWOWAY
;
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_description
=
strdup
(
psz_description
);
p_new
->
psz_description
=
strdup
(
psz_description
);
p_new
->
i_flags
=
DIALOG_LOGIN_PW_OK_CANCEL
;
p_new
->
i_flags
=
DIALOG_LOGIN_PW_OK_CANCEL
;
i_ret
=
intf_Interact
(
p_this
,
p_new
);
i_ret
=
DialogSend
(
p_this
,
p_new
);
if
(
i_ret
!=
DIALOG_CANCELLED
)
if
(
i_ret
!=
DIALOG_CANCELLED
)
{
{
assert
(
p_new
->
psz_returned
[
0
]
&&
p_new
->
psz_returned
[
1
]
);
*
ppsz_login
=
strdup
(
p_new
->
psz_returned
[
0
]
);
*
ppsz_login
=
strdup
(
p_new
->
psz_returned
[
0
]
);
*
ppsz_password
=
strdup
(
p_new
->
psz_returned
[
1
]
);
*
ppsz_password
=
strdup
(
p_new
->
psz_returned
[
1
]
);
}
}
...
@@ -477,88 +392,23 @@ int __intf_UserStringInput( vlc_object_t *p_this,
...
@@ -477,88 +392,23 @@ int __intf_UserStringInput( vlc_object_t *p_this,
const
char
*
psz_description
,
const
char
*
psz_description
,
char
**
ppsz_usersString
)
char
**
ppsz_usersString
)
{
{
int
i_ret
;
int
i_ret
;
interaction_dialog_t
*
p_new
=
NULL
;
DIALOG_INIT
(
TWOWAY
);
INTERACT_INIT
(
p_new
);
p_new
->
i_type
=
INTERACT_DIALOG_TWOWAY
;
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_title
=
strdup
(
psz_title
);
p_new
->
psz_description
=
strdup
(
psz_description
);
p_new
->
psz_description
=
strdup
(
psz_description
);
p_new
->
i_flags
=
DIALOG_PSZ_INPUT_OK_CANCEL
;
p_new
->
i_flags
=
DIALOG_PSZ_INPUT_OK_CANCEL
;
i_ret
=
intf_Interact
(
p_this
,
p_new
);
i_ret
=
DialogSend
(
p_this
,
p_new
);
if
(
i_ret
!=
DIALOG_CANCELLED
)
if
(
i_ret
!=
DIALOG_CANCELLED
)
{
{
assert
(
p_new
->
psz_returned
[
0
]
);
*
ppsz_usersString
=
strdup
(
p_new
->
psz_returned
[
0
]
);
*
ppsz_usersString
=
strdup
(
p_new
->
psz_returned
[
0
]
);
}
}
return
i_ret
;
return
i_ret
;
}
}
/** Helper function to create a progress-bar in the main interface with a
* single-line description
* \param p_this Parent vlc_object
* \param psz_status Current status
* \param f_position Current position (0.0->100.0)
* \return Dialog id, to give to IntfProgressUpdate
*/
int
__intf_IntfProgress
(
vlc_object_t
*
p_this
,
const
char
*
psz_status
,
float
f_pos
)
{
int
i_ret
;
interaction_dialog_t
*
p_new
=
NULL
;
INTERACT_INIT
(
p_new
);
p_new
->
i_type
=
INTERACT_DIALOG_ONEWAY
;
p_new
->
psz_description
=
strdup
(
psz_status
);
p_new
->
val
.
f_float
=
f_pos
;
p_new
->
i_flags
=
DIALOG_INTF_PROGRESS
;
i_ret
=
intf_Interact
(
p_this
,
p_new
);
return
p_new
->
i_id
;
}
/** Update the progress bar in the main interface
* \param p_this Parent vlc_object
* \param i_id Identifier of the dialog
* \param psz_status New status
* \param f_position New position (0.0->100.0)
* \return nothing
*/
void
__intf_IntfProgressUpdate
(
vlc_object_t
*
p_this
,
int
i_id
,
const
char
*
psz_status
,
float
f_pos
)
{
interaction_t
*
p_interaction
=
intf_InteractionGet
(
p_this
);
interaction_dialog_t
*
p_dialog
;
if
(
!
p_interaction
)
return
;
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
p_dialog
=
intf_InteractionGetById
(
p_this
,
i_id
);
if
(
!
p_dialog
)
{
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
return
;
}
if
(
p_dialog
->
psz_description
)
free
(
p_dialog
->
psz_description
);
p_dialog
->
psz_description
=
strdup
(
psz_status
);
p_dialog
->
val
.
f_float
=
f_pos
;
p_dialog
->
i_status
=
UPDATED_DIALOG
;
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
)
;
}
/** Hide an interaction dialog
/** Hide an interaction dialog
* \param p_this the parent vlc object
* \param p_this the parent vlc object
* \param i_id the id of the item to hide
* \param i_id the id of the item to hide
...
@@ -566,13 +416,13 @@ void __intf_IntfProgressUpdate( vlc_object_t *p_this, int i_id,
...
@@ -566,13 +416,13 @@ void __intf_IntfProgressUpdate( vlc_object_t *p_this, int i_id,
*/
*/
void
__intf_UserHide
(
vlc_object_t
*
p_this
,
int
i_id
)
void
__intf_UserHide
(
vlc_object_t
*
p_this
,
int
i_id
)
{
{
interaction_t
*
p_interaction
=
intf_
InteractionGet
(
p_this
);
interaction_t
*
p_interaction
=
InteractionGet
(
p_this
);
interaction_dialog_t
*
p_dialog
;
interaction_dialog_t
*
p_dialog
;
if
(
!
p_interaction
)
return
;
if
(
!
p_interaction
)
return
;
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
p_dialog
=
intf_InteractionGetById
(
p_this
,
i_id
);
p_dialog
=
DialogGetById
(
p_interaction
,
i_id
);
if
(
!
p_dialog
)
if
(
!
p_dialog
)
{
{
...
@@ -584,45 +434,35 @@ void __intf_UserHide( vlc_object_t *p_this, int i_id )
...
@@ -584,45 +434,35 @@ void __intf_UserHide( vlc_object_t *p_this, int i_id )
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
);
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
);
}
}
/**********************************************************************
/**********************************************************************
* The following functions are local
* The following functions are local
**********************************************************************/
**********************************************************************/
/* Get the interaction object. Create it if needed */
/* Get the interaction object. Create it if needed */
static
interaction_t
*
intf_
InteractionGet
(
vlc_object_t
*
p_this
)
static
interaction_t
*
InteractionGet
(
vlc_object_t
*
p_this
)
{
{
playlist_t
*
p_playlist
;
playlist_t
*
p_playlist
;
interaction_t
*
p_interaction
;
interaction_t
*
p_interaction
;
p_playlist
=
(
playlist_t
*
)
vlc_object_find
(
p_this
,
VLC_OBJECT_PLAYLIST
,
p_playlist
=
(
playlist_t
*
)
vlc_object_find
(
p_this
,
VLC_OBJECT_PLAYLIST
,
FIND_ANYWHERE
);
FIND_ANYWHERE
);
if
(
!
p_playlist
)
if
(
!
p_playlist
)
{
return
NULL
;
return
NULL
;
}
if
(
p_playlist
->
p_interaction
==
NULL
)
if
(
p_playlist
->
p_interaction
==
NULL
)
{
InteractionInit
(
p_playlist
);
intf_InteractionInit
(
p_playlist
);
}
p_interaction
=
p_playlist
->
p_interaction
;
p_interaction
=
p_playlist
->
p_interaction
;
vlc_object_release
(
p_playlist
);
vlc_object_release
(
p_playlist
);
return
p_interaction
;
return
p_interaction
;
}
}
/* Create the interaction object in the given playlist object */
/* Create the interaction object in the given playlist object */
static
void
intf_
InteractionInit
(
playlist_t
*
p_playlist
)
static
void
InteractionInit
(
playlist_t
*
p_playlist
)
{
{
interaction_t
*
p_interaction
;
interaction_t
*
p_interaction
=
vlc_object_create
(
VLC_OBJECT
(
p_playlist
),
sizeof
(
interaction_t
)
);
p_interaction
=
vlc_object_create
(
VLC_OBJECT
(
p_playlist
),
sizeof
(
interaction_t
)
);
if
(
!
p_interaction
)
if
(
!
p_interaction
)
{
{
msg_Err
(
p_playlist
,
"out of memory"
);
msg_Err
(
p_playlist
,
"out of memory"
);
...
@@ -640,7 +480,7 @@ static void intf_InteractionInit( playlist_t *p_playlist )
...
@@ -640,7 +480,7 @@ static void intf_InteractionInit( playlist_t *p_playlist )
}
}
/* Look for an interface suitable for interaction */
/* Look for an interface suitable for interaction */
static
void
intf_
InteractionSearchInterface
(
interaction_t
*
p_interaction
)
static
void
InteractionSearchInterface
(
interaction_t
*
p_interaction
)
{
{
vlc_list_t
*
p_list
;
vlc_list_t
*
p_list
;
int
i_index
;
int
i_index
;
...
@@ -667,108 +507,97 @@ static void intf_InteractionSearchInterface( interaction_t *p_interaction )
...
@@ -667,108 +507,97 @@ static void intf_InteractionSearchInterface( interaction_t *p_interaction )
vlc_list_release
(
p_list
);
vlc_list_release
(
p_list
);
}
}
/*
Add a dialog to the queue and wait for answer
*/
/*
Find an interaction dialog by its id
*/
static
int
intf_WaitAnswer
(
interaction_t
*
p_interact
,
static
int
eraction_dialog_t
*
DialogGetById
(
interaction_t
*
p_interaction
,
interaction_dialog_t
*
p_dialog
)
int
i_id
)
{
{
int
i
;
int
i
;
vlc_bool_t
b_found
=
VLC_FALSE
;
for
(
i
=
0
;
i
<
p_interaction
->
i_dialogs
;
i
++
)
vlc_mutex_lock
(
&
p_interact
->
object_lock
);
for
(
i
=
0
;
i
<
p_interact
->
i_dialogs
;
i
++
)
{
if
(
p_interact
->
pp_dialogs
[
i
]
->
i_id
==
p_dialog
->
i_id
)
{
b_found
=
VLC_TRUE
;
}
}
if
(
!
b_found
)
{
INSERT_ELEM
(
p_interact
->
pp_dialogs
,
p_interact
->
i_dialogs
,
p_interact
->
i_dialogs
,
p_dialog
);
}
else
p_dialog
->
i_status
=
UPDATED_DIALOG
;
vlc_mutex_unlock
(
&
p_interact
->
object_lock
);
/// \todo Check that the initiating object is not dying
while
(
p_dialog
->
i_status
!=
ANSWERED_DIALOG
&&
p_dialog
->
i_status
!=
HIDING_DIALOG
&&
p_dialog
->
i_status
!=
HIDDEN_DIALOG
&&
!
p_dialog
->
p_parent
->
b_die
)
{
msleep
(
100000
);
}
/// \todo locking
if
(
p_dialog
->
p_parent
->
b_die
)
{
{
p_dialog
->
i_return
=
DIALOG_CANCELLED
;
if
(
p_interaction
->
pp_dialogs
[
i
]
->
i_id
==
i_id
)
p_dialog
->
i_status
=
ANSWERED_DIALOG
;
return
p_interaction
->
pp_dialogs
[
i
]
;
}
}
p_dialog
->
i_flags
|=
DIALOG_GOT_ANSWER
;
return
NULL
;
return
p_dialog
->
i_return
;
}
}
/* Add a dialog to the queue and return */
/* Destroy a dialog */
static
int
intf_Send
(
interaction_t
*
p_interact
,
static
void
DialogDestroy
(
interaction_dialog_t
*
p_dialog
)
interaction_dialog_t
*
p_dialog
)
{
{
int
i
;
FREENULL
(
p_dialog
->
psz_title
);
vlc_bool_t
b_found
=
VLC_FALSE
;
FREENULL
(
p_dialog
->
psz_description
);
if
(
p_interact
==
NULL
)
return
VLC_ENOOBJ
;
FREENULL
(
p_dialog
->
psz_default_button
);
vlc_mutex_lock
(
&
p_interact
->
object_lock
);
FREENULL
(
p_dialog
->
psz_alternate_button
);
FREENULL
(
p_dialog
->
psz_other_button
);
for
(
i
=
0
;
i
<
p_interact
->
i_dialogs
;
i
++
)
free
(
p_dialog
);
{
if
(
p_interact
->
pp_dialogs
[
i
]
->
i_id
==
p_dialog
->
i_id
)
{
b_found
=
VLC_TRUE
;
}
}
if
(
!
b_found
)
{
INSERT_ELEM
(
p_interact
->
pp_dialogs
,
p_interact
->
i_dialogs
,
p_interact
->
i_dialogs
,
p_dialog
);
}
else
p_dialog
->
i_status
=
UPDATED_DIALOG
;
// Pretend we already retrieved the "answer"
p_dialog
->
i_flags
|=
DIALOG_GOT_ANSWER
;
vlc_mutex_unlock
(
&
p_interact
->
object_lock
);
return
VLC_SUCCESS
;
}
}
/*
Find an interaction dialog by its id */
/*
Ask for the dialog to be sent to the user. Wait for answer
static
interaction_dialog_t
*
intf_InteractionGetById
(
vlc_object_t
*
p_this
,
* if required */
int
i_id
)
static
int
DialogSend
(
vlc_object_t
*
p_this
,
interaction_dialog_t
*
p_dialog
)
{
{
interaction_t
*
p_interaction
=
intf_InteractionGet
(
p_this
);
interaction_t
*
p_interaction
=
InteractionGet
(
p_this
);
int
i
;
if
(
!
p_interaction
)
return
NULL
;
/* Get an id, if we don't already have one */
if
(
p_dialog
->
i_id
==
0
)
p_dialog
->
i_id
=
++
p_interaction
->
i_last_id
;
for
(
i
=
0
;
i
<
p_interaction
->
i_dialogs
;
i
++
)
if
(
p_this
->
i_flags
&
OBJECT_FLAGS_NOINTERACT
)
return
VLC_EGENERIC
;
if
(
config_GetInt
(
p_this
,
"interact"
)
||
p_dialog
->
i_flags
&
DIALOG_BLOCKING_ERROR
||
p_dialog
->
i_flags
&
DIALOG_NONBLOCKING_ERROR
)
{
{
if
(
p_interaction
->
pp_dialogs
[
i
]
->
i_id
==
i_id
)
vlc_bool_t
b_found
=
VLC_FALSE
;
int
i
;
p_dialog
->
p_interaction
=
p_interaction
;
p_dialog
->
p_parent
=
p_this
;
/* Check if we have already added this dialog */
vlc_mutex_lock
(
&
p_interaction
->
object_lock
);
for
(
i
=
0
;
i
<
p_interaction
->
i_dialogs
;
i
++
)
{
{
return
p_interaction
->
pp_dialogs
[
i
];
if
(
p_interaction
->
pp_dialogs
[
i
]
->
i_id
==
p_dialog
->
i_id
)
b_found
=
VLC_TRUE
;
}
}
}
/* Add it to the queue, the main loop will send the orders to the
return
NULL
;
* interface */
}
if
(
!
b_found
)
{
#define FREE( i ) { if( i ) free( i ); i = NULL; }
INSERT_ELEM
(
p_interaction
->
pp_dialogs
,
p_interaction
->
i_dialogs
,
static
void
intf_InteractionDialogDestroy
(
interaction_dialog_t
*
p_dialog
)
p_interaction
->
i_dialogs
,
{
p_dialog
);
FREE
(
p_dialog
->
psz_title
);
}
FREE
(
p_dialog
->
psz_description
);
else
FREE
(
p_dialog
->
psz_default_button
);
p_dialog
->
i_status
=
UPDATED_DIALOG
;
FREE
(
p_dialog
->
psz_alternate_button
);
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
);
FREE
(
p_dialog
->
psz_other_button
);
free
(
p_dialog
);
if
(
p_dialog
->
i_type
==
INTERACT_DIALOG_TWOWAY
)
// Wait for answer
}
{
while
(
p_dialog
->
i_status
!=
ANSWERED_DIALOG
&&
p_dialog
->
i_status
!=
HIDING_DIALOG
&&
p_dialog
->
i_status
!=
HIDDEN_DIALOG
&&
!
p_dialog
->
p_parent
->
b_die
)
{
msleep
(
100000
);
}
/// \todo locking ?
if
(
p_dialog
->
p_parent
->
b_die
)
{
p_dialog
->
i_return
=
DIALOG_CANCELLED
;
p_dialog
->
i_status
=
ANSWERED_DIALOG
;
}
p_dialog
->
i_flags
|=
DIALOG_GOT_ANSWER
;
return
p_dialog
->
i_return
;
}
else
{
// Pretend we already retrieved the "answer"
p_dialog
->
i_flags
|=
DIALOG_GOT_ANSWER
;
vlc_mutex_unlock
(
&
p_interaction
->
object_lock
);
return
VLC_SUCCESS
;
}
}
else
return
VLC_EGENERIC
;
}
src/misc/update.c
View file @
093de856
...
@@ -78,7 +78,6 @@
...
@@ -78,7 +78,6 @@
#define UPDATE_VLC_STATUS_URL "http://update.videolan.org/vlc/status.xml"
#define UPDATE_VLC_STATUS_URL "http://update.videolan.org/vlc/status.xml"
#define UPDATE_VLC_MIRRORS_URL "http://update.videolan.org/mirrors.xml"
#define UPDATE_VLC_MIRRORS_URL "http://update.videolan.org/mirrors.xml"
#define FREE( a ) free(a);a=NULL;
#define STRDUP( a ) ( a ? strdup( a ) : NULL )
#define STRDUP( a ) ( a ? strdup( a ) : NULL )
/*****************************************************************************
/*****************************************************************************
...
@@ -167,7 +166,7 @@ void FreeMirrorsList( update_t *p_update )
...
@@ -167,7 +166,7 @@ void FreeMirrorsList( update_t *p_update )
free
(
p_update
->
p_mirrors
[
i
].
psz_type
);
free
(
p_update
->
p_mirrors
[
i
].
psz_type
);
free
(
p_update
->
p_mirrors
[
i
].
psz_base_url
);
free
(
p_update
->
p_mirrors
[
i
].
psz_base_url
);
}
}
FREE
(
p_update
->
p_mirrors
);
FREE
NULL
(
p_update
->
p_mirrors
);
p_update
->
i_mirrors
=
0
;
p_update
->
i_mirrors
=
0
;
p_update
->
b_mirrors
=
VLC_FALSE
;
p_update
->
b_mirrors
=
VLC_FALSE
;
}
}
...
@@ -200,7 +199,7 @@ void FreeReleasesList( update_t *p_update )
...
@@ -200,7 +199,7 @@ void FreeReleasesList( update_t *p_update )
free
(
p_release
->
psz_svn_revision
);
free
(
p_release
->
psz_svn_revision
);
free
(
p_release
->
p_files
);
free
(
p_release
->
p_files
);
}
}
FREE
(
p_update
->
p_releases
);
FREE
NULL
(
p_update
->
p_releases
);
p_update
->
i_releases
=
0
;
p_update
->
i_releases
=
0
;
p_update
->
b_releases
=
VLC_FALSE
;
p_update
->
b_releases
=
VLC_FALSE
;
}
}
...
@@ -308,8 +307,8 @@ void GetMirrorsList( update_t *p_update, vlc_bool_t b_force )
...
@@ -308,8 +307,8 @@ void GetMirrorsList( update_t *p_update, vlc_bool_t b_force )
else
if
(
!
strcmp
(
psz_name
,
"base"
)
)
else
if
(
!
strcmp
(
psz_name
,
"base"
)
)
tmp_mirror
.
psz_base_url
=
STRDUP
(
psz_value
);
tmp_mirror
.
psz_base_url
=
STRDUP
(
psz_value
);
}
}
FREE
(
psz_name
);
FREE
NULL
(
psz_name
);
FREE
(
psz_value
);
FREE
NULL
(
psz_value
);
}
}
if
(
!
strcmp
(
psz_eltname
,
"url"
)
)
if
(
!
strcmp
(
psz_eltname
,
"url"
)
)
{
{
...
@@ -325,7 +324,7 @@ void GetMirrorsList( update_t *p_update, vlc_bool_t b_force )
...
@@ -325,7 +324,7 @@ void GetMirrorsList( update_t *p_update, vlc_bool_t b_force )
tmp_mirror
.
psz_type
=
NULL
;
tmp_mirror
.
psz_type
=
NULL
;
tmp_mirror
.
psz_base_url
=
NULL
;
tmp_mirror
.
psz_base_url
=
NULL
;
}
}
FREE
(
psz_eltname
);
FREE
NULL
(
psz_eltname
);
break
;
break
;
case
XML_READER_ENDELEM
:
case
XML_READER_ENDELEM
:
...
@@ -339,16 +338,16 @@ void GetMirrorsList( update_t *p_update, vlc_bool_t b_force )
...
@@ -339,16 +338,16 @@ void GetMirrorsList( update_t *p_update, vlc_bool_t b_force )
if
(
!
strcmp
(
psz_eltname
,
"mirror"
)
)
if
(
!
strcmp
(
psz_eltname
,
"mirror"
)
)
{
{
FREE
(
tmp_mirror
.
psz_name
);
FREE
NULL
(
tmp_mirror
.
psz_name
);
FREE
(
tmp_mirror
.
psz_location
);
FREE
NULL
(
tmp_mirror
.
psz_location
);
}
}
FREE
(
psz_eltname
);
FREE
NULL
(
psz_eltname
);
break
;
break
;
/*case XML_READER_TEXT:
/*case XML_READER_TEXT:
psz_eltvalue = xml_ReaderValue( p_xml_reader );
psz_eltvalue = xml_ReaderValue( p_xml_reader );
FREE( psz_eltvalue );
FREE
NULL
( psz_eltvalue );
break;*/
break;*/
}
}
}
}
...
@@ -536,8 +535,8 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
...
@@ -536,8 +535,8 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
{
{
b_arch
=
VLC_TRUE
;
b_arch
=
VLC_TRUE
;
}
}
FREE
(
psz_name
);
FREE
NULL
(
psz_name
);
FREE
(
psz_value
);
FREE
NULL
(
psz_value
);
}
}
if
(
(
b_os
&&
b_arch
&&
strcmp
(
psz_eltname
,
"arch"
)
)
)
if
(
(
b_os
&&
b_arch
&&
strcmp
(
psz_eltname
,
"arch"
)
)
)
{
{
...
@@ -579,13 +578,13 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
...
@@ -579,13 +578,13 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
}
}
else
else
{
{
FREE
(
tmp_release
.
psz_major
);
FREE
NULL
(
tmp_release
.
psz_major
);
FREE
(
tmp_release
.
psz_minor
);
FREE
NULL
(
tmp_release
.
psz_minor
);
FREE
(
tmp_release
.
psz_revision
);
FREE
NULL
(
tmp_release
.
psz_revision
);
FREE
(
tmp_release
.
psz_extra
);
FREE
NULL
(
tmp_release
.
psz_extra
);
FREE
(
tmp_release
.
psz_svn_revision
);
FREE
NULL
(
tmp_release
.
psz_svn_revision
);
tmp_release
.
i_type
=
UPDATE_RELEASE_TYPE_STABLE
;
tmp_release
.
i_type
=
UPDATE_RELEASE_TYPE_STABLE
;
FREE
(
tmp_release
.
p_files
);
FREE
NULL
(
tmp_release
.
p_files
);
tmp_release
.
i_files
=
0
;
tmp_release
.
i_files
=
0
;
}
}
}
}
...
@@ -607,7 +606,7 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
...
@@ -607,7 +606,7 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
tmp_file
.
psz_description
=
NULL
;
tmp_file
.
psz_description
=
NULL
;
}
}
}
}
FREE
(
psz_eltname
);
FREE
NULL
(
psz_eltname
);
break
;
break
;
case
XML_READER_ENDELEM
:
case
XML_READER_ENDELEM
:
...
@@ -623,7 +622,7 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
...
@@ -623,7 +622,7 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
b_os
=
VLC_FALSE
;
b_os
=
VLC_FALSE
;
else
if
(
!
strcmp
(
psz_eltname
,
"arch"
)
)
else
if
(
!
strcmp
(
psz_eltname
,
"arch"
)
)
b_arch
=
VLC_FALSE
;
b_arch
=
VLC_FALSE
;
FREE
(
psz_eltname
);
FREE
NULL
(
psz_eltname
);
break
;
break
;
case
XML_READER_TEXT
:
case
XML_READER_TEXT
:
...
@@ -631,7 +630,7 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
...
@@ -631,7 +630,7 @@ void GetFilesList( update_t *p_update, vlc_bool_t b_force )
if
(
p_release
&&
p_release
->
i_files
)
if
(
p_release
&&
p_release
->
i_files
)
p_release
->
p_files
[
p_release
->
i_files
-
1
]
p_release
->
p_files
[
p_release
->
i_files
-
1
]
.
psz_description
=
STRDUP
(
psz_eltvalue
);
.
psz_description
=
STRDUP
(
psz_eltvalue
);
FREE
(
psz_eltvalue
);
FREE
NULL
(
psz_eltvalue
);
break
;
break
;
}
}
}
}
...
@@ -1115,17 +1114,17 @@ void update_iterator_GetData( update_iterator_t *p_uit )
...
@@ -1115,17 +1114,17 @@ void update_iterator_GetData( update_iterator_t *p_uit )
void
update_iterator_ClearData
(
update_iterator_t
*
p_uit
)
void
update_iterator_ClearData
(
update_iterator_t
*
p_uit
)
{
{
p_uit
->
file
.
i_type
=
UPDATE_FILE_TYPE_NONE
;
p_uit
->
file
.
i_type
=
UPDATE_FILE_TYPE_NONE
;
FREE
(
p_uit
->
file
.
psz_md5
);
FREE
NULL
(
p_uit
->
file
.
psz_md5
);
p_uit
->
file
.
l_size
=
0
;
p_uit
->
file
.
l_size
=
0
;
FREE
(
p_uit
->
file
.
psz_description
);
FREE
NULL
(
p_uit
->
file
.
psz_description
);
FREE
(
p_uit
->
file
.
psz_url
);
FREE
NULL
(
p_uit
->
file
.
psz_url
);
FREE
(
p_uit
->
release
.
psz_version
);
FREE
NULL
(
p_uit
->
release
.
psz_version
);
FREE
(
p_uit
->
release
.
psz_svn_revision
);
FREE
NULL
(
p_uit
->
release
.
psz_svn_revision
);
p_uit
->
release
.
i_type
=
UPDATE_RELEASE_TYPE_UNSTABLE
;
p_uit
->
release
.
i_type
=
UPDATE_RELEASE_TYPE_UNSTABLE
;
p_uit
->
release
.
i_status
=
UPDATE_RELEASE_STATUS_NONE
;
p_uit
->
release
.
i_status
=
UPDATE_RELEASE_STATUS_NONE
;
FREE
(
p_uit
->
mirror
.
psz_name
);
FREE
NULL
(
p_uit
->
mirror
.
psz_name
);
FREE
(
p_uit
->
mirror
.
psz_location
);
FREE
NULL
(
p_uit
->
mirror
.
psz_location
);
FREE
(
p_uit
->
mirror
.
psz_type
);
FREE
NULL
(
p_uit
->
mirror
.
psz_type
);
}
}
/**
/**
...
@@ -1308,8 +1307,8 @@ void update_download_for_real( download_thread_t *p_this )
...
@@ -1308,8 +1307,8 @@ void update_download_for_real( download_thread_t *p_this )
p_this
->
psz_status
,
psz_s1
,
psz_s2
,
f_progress
);
p_this
->
psz_status
,
psz_s1
,
psz_s2
,
f_progress
);
free
(
psz_s1
);
free
(
psz_s2
);
free
(
psz_s1
);
free
(
psz_s2
);
intf_
User
ProgressUpdate
(
p_vlc
,
i_progress
,
intf_ProgressUpdate
(
p_vlc
,
i_progress
,
psz_status
,
f_progress
,
0
);
psz_status
,
f_progress
,
0
);
}
}
free
(
p_buffer
);
free
(
p_buffer
);
...
@@ -1321,7 +1320,7 @@ void update_download_for_real( download_thread_t *p_this )
...
@@ -1321,7 +1320,7 @@ void update_download_for_real( download_thread_t *p_this )
asprintf
(
&
psz_status
,
"%s
\n
Done %s (100.00%%)"
,
asprintf
(
&
psz_status
,
"%s
\n
Done %s (100.00%%)"
,
p_this
->
psz_status
,
psz_s2
);
p_this
->
psz_status
,
psz_s2
);
free
(
psz_s2
);
free
(
psz_s2
);
intf_
User
ProgressUpdate
(
p_vlc
,
i_progress
,
psz_status
,
100
.
0
,
0
);
intf_ProgressUpdate
(
p_vlc
,
i_progress
,
psz_status
,
100
.
0
,
0
);
free
(
psz_status
);
free
(
psz_status
);
}
}
}
}
...
...
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