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
7eba9008
Commit
7eba9008
authored
Dec 12, 2007
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Handle I/O errors while writing the cache file
parent
b25337f6
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
52 additions
and
31 deletions
+52
-31
src/modules/cache.c
src/modules/cache.c
+52
-31
No files found.
src/modules/cache.c
View file @
7eba9008
...
@@ -75,7 +75,7 @@
...
@@ -75,7 +75,7 @@
*****************************************************************************/
*****************************************************************************/
#ifdef HAVE_DYNAMIC_PLUGINS
#ifdef HAVE_DYNAMIC_PLUGINS
static
int
CacheLoadConfig
(
module_t
*
,
FILE
*
);
static
int
CacheLoadConfig
(
module_t
*
,
FILE
*
);
static
void
CacheSaveConfig
(
module_t
*
,
FILE
*
);
static
int
CacheSaveConfig
(
module_t
*
,
FILE
*
);
static
char
*
CacheName
(
void
);
static
char
*
CacheName
(
void
);
/* Sub-version number
/* Sub-version number
...
@@ -451,13 +451,13 @@ void CacheSave( vlc_object_t *p_this )
...
@@ -451,13 +451,13 @@ void CacheSave( vlc_object_t *p_this )
FILE
*
file
;
FILE
*
file
;
int
i
,
j
,
i_cache
;
int
i
,
j
,
i_cache
;
module_cache_t
**
pp_cache
;
module_cache_t
**
pp_cache
;
int32_t
i_file_size
=
0
;
u
int32_t
i_file_size
=
0
;
libvlc_global_data_t
*
p_libvlc_global
=
vlc_global
();
libvlc_global_data_t
*
p_libvlc_global
=
vlc_global
();
psz_cachedir
=
p_this
->
p_libvlc
->
psz_cachedir
;
psz_cachedir
=
p_this
->
p_libvlc
->
psz_cachedir
;
if
(
!
psz_cachedir
)
/* XXX: this should never happen */
if
(
!
psz_cachedir
)
/* XXX: this should never happen */
{
{
msg_Err
(
p_this
,
"
U
nable to get cache directory"
);
msg_Err
(
p_this
,
"
u
nable to get cache directory"
);
return
;
return
;
}
}
...
@@ -467,58 +467,63 @@ void CacheSave( vlc_object_t *p_this )
...
@@ -467,58 +467,63 @@ void CacheSave( vlc_object_t *p_this )
snprintf
(
psz_filename
,
sizeof
(
psz_filename
),
snprintf
(
psz_filename
,
sizeof
(
psz_filename
),
"%s"
DIR_SEP
"CACHEDIR.TAG"
,
psz_cachedir
);
"%s"
DIR_SEP
"CACHEDIR.TAG"
,
psz_cachedir
);
file
=
utf8_fopen
(
psz_filename
,
"wb"
);
file
=
utf8_fopen
(
psz_filename
,
"wb"
);
if
(
file
)
if
(
file
!=
NULL
)
{
{
fwrite
(
psz_tag
,
1
,
strlen
(
psz_tag
),
file
);
if
(
fwrite
(
psz_tag
,
1
,
sizeof
(
psz_tag
)
-
1
,
file
)
!=
1
)
clearerr
(
file
);
/* what else can we do? */
fclose
(
file
);
fclose
(
file
);
}
}
snprintf
(
psz_filename
,
sizeof
(
psz_filename
),
snprintf
(
psz_filename
,
sizeof
(
psz_filename
),
"%s"
DIR_SEP
"%s"
,
psz_cachedir
,
CacheName
()
);
"%s"
DIR_SEP
"%s"
,
psz_cachedir
,
CacheName
()
);
msg_Dbg
(
p_this
,
"
saving plugins cache fil
e %s"
,
psz_filename
);
msg_Dbg
(
p_this
,
"
writing plugins cach
e %s"
,
psz_filename
);
file
=
utf8_fopen
(
psz_filename
,
"wb"
);
file
=
utf8_fopen
(
psz_filename
,
"wb"
);
if
(
!
file
)
if
(
file
==
NULL
)
{
goto
error
;
msg_Warn
(
p_this
,
"could not open plugins cache file %s for writing"
,
psz_filename
);
return
;
}
/* Empty space for file size */
/* Empty space for file size */
fwrite
(
&
i_file_size
,
sizeof
(
char
),
sizeof
(
i_file_size
),
file
);
if
(
fwrite
(
&
i_file_size
,
sizeof
(
i_file_size
),
1
,
file
)
!=
1
)
goto
error
;
/* Contains version number */
/* Contains version number */
fprintf
(
file
,
"%s"
,
"cache "
COPYRIGHT_MESSAGE
);
if
(
fputs
(
"cache "
COPYRIGHT_MESSAGE
,
file
)
==
EOF
)
goto
error
;
/* Sub-version number (to avoid breakage in the dev version when cache
/* Sub-version number (to avoid breakage in the dev version when cache
* structure changes) */
* structure changes) */
i_file_size
=
CACHE_SUBVERSION_NUM
;
i_file_size
=
CACHE_SUBVERSION_NUM
;
fwrite
(
&
i_file_size
,
sizeof
(
char
),
sizeof
(
i_file_size
),
file
);
if
(
fwrite
(
&
i_file_size
,
sizeof
(
i_file_size
),
1
,
file
)
!=
1
)
goto
error
;
/* Language */
/* Language */
fprintf
(
file
,
"%5.5s"
,
_
(
"C"
)
);
if
(
fprintf
(
file
,
"%5.5s"
,
_
(
"C"
))
==
EOF
)
goto
error
;
/* Header marker */
/* Header marker */
i_file_size
=
ftell
(
file
);
i_file_size
=
ftell
(
file
);
fwrite
(
&
i_file_size
,
sizeof
(
char
),
sizeof
(
i_file_size
),
file
);
if
(
fwrite
(
&
i_file_size
,
sizeof
(
i_file_size
),
1
,
file
)
!=
1
)
goto
error
;
i_cache
=
p_libvlc_global
->
p_module_bank
->
i_cache
;
i_cache
=
p_libvlc_global
->
p_module_bank
->
i_cache
;
pp_cache
=
p_libvlc_global
->
p_module_bank
->
pp_cache
;
pp_cache
=
p_libvlc_global
->
p_module_bank
->
pp_cache
;
fwrite
(
&
i_cache
,
sizeof
(
char
),
sizeof
(
i_cache
),
file
);
if
(
fwrite
(
&
i_cache
,
sizeof
(
i_cache
),
1
,
file
)
!=
1
)
goto
error
;
#define SAVE_IMMEDIATE(a) \
fwrite( &a, sizeof(char), sizeof(a), file )
#define SAVE_IMMEDIATE( a ) \
#define SAVE_STRING(a) \
if (fwrite (&a, sizeof(a), 1, file) != 1) \
{ i_size = a ? strlen( a ) + 1 : 0; \
goto error
fwrite( &i_size, sizeof(char), sizeof(i_size), file ); \
#define SAVE_STRING( a ) \
if( a ) fwrite( a, sizeof(char), i_size, file ); \
{ \
uint16_t i_size = (a != NULL) ? (strlen (a) + 1) : 0; \
if ((fwrite (&i_size, sizeof (i_size), 1, file) != 1) \
|| (a && (fwrite (a, 1, i_size, file) != i_size))) \
goto error; \
} while(0)
} while(0)
for
(
i
=
0
;
i
<
i_cache
;
i
++
)
for
(
i
=
0
;
i
<
i_cache
;
i
++
)
{
{
uint16_t
i_size
;
uint32_t
i_submodule
;
uint32_t
i_submodule
;
/* Save common info */
/* Save common info */
...
@@ -546,7 +551,8 @@ void CacheSave( vlc_object_t *p_this )
...
@@ -546,7 +551,8 @@ void CacheSave( vlc_object_t *p_this )
SAVE_IMMEDIATE
(
pp_cache
[
i
]
->
p_module
->
b_submodule
);
SAVE_IMMEDIATE
(
pp_cache
[
i
]
->
p_module
->
b_submodule
);
/* Config stuff */
/* Config stuff */
CacheSaveConfig
(
pp_cache
[
i
]
->
p_module
,
file
);
if
(
CacheSaveConfig
(
pp_cache
[
i
]
->
p_module
,
file
))
goto
error
;
SAVE_STRING
(
pp_cache
[
i
]
->
p_module
->
psz_filename
);
SAVE_STRING
(
pp_cache
[
i
]
->
p_module
->
psz_filename
);
...
@@ -578,15 +584,26 @@ void CacheSave( vlc_object_t *p_this )
...
@@ -578,15 +584,26 @@ void CacheSave( vlc_object_t *p_this )
/* Fill-up file size */
/* Fill-up file size */
i_file_size
=
ftell
(
file
);
i_file_size
=
ftell
(
file
);
fseek
(
file
,
0
,
SEEK_SET
);
fseek
(
file
,
0
,
SEEK_SET
);
fwrite
(
&
i_file_size
,
sizeof
(
char
),
sizeof
(
i_file_size
),
file
);
if
(
fwrite
(
&
i_file_size
,
sizeof
(
i_file_size
),
1
,
file
)
!=
1
)
goto
error
;
fclose
(
file
);
if
(
fclose
(
file
)
==
0
)
return
;
/* success! */
file
=
NULL
;
error:
msg_Warn
(
p_this
,
"could not write plugins cache %s (%m)"
,
psz_filename
);
if
(
file
!=
NULL
)
{
clearerr
(
file
);
fclose
(
file
);
}
}
}
static
void
CacheSaveConfig
(
module_t
*
p_module
,
FILE
*
file
)
static
int
CacheSaveConfig
(
module_t
*
p_module
,
FILE
*
file
)
{
{
uint32_t
i_lines
=
p_module
->
confsize
;
uint32_t
i_lines
=
p_module
->
confsize
;
uint16_t
i_size
;
SAVE_IMMEDIATE
(
p_module
->
i_config_items
);
SAVE_IMMEDIATE
(
p_module
->
i_config_items
);
SAVE_IMMEDIATE
(
p_module
->
i_bool_items
);
SAVE_IMMEDIATE
(
p_module
->
i_bool_items
);
...
@@ -629,6 +646,10 @@ static void CacheSaveConfig( module_t *p_module, FILE *file )
...
@@ -629,6 +646,10 @@ static void CacheSaveConfig( module_t *p_module, FILE *file )
SAVE_IMMEDIATE
(
p_module
->
p_config
[
i
].
pf_callback
);
SAVE_IMMEDIATE
(
p_module
->
p_config
[
i
].
pf_callback
);
}
}
return
0
;
error:
return
-
1
;
}
}
/*****************************************************************************
/*****************************************************************************
...
...
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