/*****************************************************************************
* Preamble
*****************************************************************************/
-#include <stdlib.h>
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
#include <vlc/vlc.h>
-#include <vlc/input.h>
-#include <vlc/vout.h>
+
+#include <vlc_input.h>
+#include <vlc_access.h>
#include "vlc_keys.h"
#include <vlc_osd.h>
-#include "charset.h"
+#include <vlc_charset.h>
#include <errno.h>
#include <time.h>
#define RECORD_PATH_TXT N_("Record directory")
#define RECORD_PATH_LONGTXT N_( \
- "Allows you to specify the directory where the record will be stored" )
+ "Directory where the record will be stored." )
static int Open ( vlc_object_t * );
static void Close( vlc_object_t * );
add_directory( "record-path", NULL, NULL,
RECORD_PATH_TXT, RECORD_PATH_LONGTXT, VLC_TRUE );
+ change_unsafe();
set_callbacks( Open, Close );
*****************************************************************************/
static block_t *Block ( access_t * );
-static int Read ( access_t *, uint8_t *, int );
+static ssize_t Read ( access_t *, uint8_t *, size_t );
static int Control( access_t *, int i_query, va_list args );
static int Seek ( access_t *, int64_t );
vlc_bool_t b_dump;
char *psz_path;
- char *psz_ext;
+ const char *psz_ext;
char *psz_file;
int64_t i_size;
FILE *f;
if( *psz == '\0' )
{
free( psz );
- if( p_access->p_vlc->psz_homedir )
- psz = strdup( p_access->p_vlc->psz_homedir );
+ if( p_access->p_libvlc->psz_homedir ) /* XXX: This should never happen */
+ psz = strdup( p_access->p_libvlc->psz_homedir );
}
p_sys->psz_path = psz;
msg_Dbg( p_access, "Record access filter path %s", psz );
/* catch all key event */
- var_AddCallback( p_access->p_vlc, "key-pressed", EventKey, p_access );
+ var_AddCallback( p_access->p_libvlc, "key-pressed", EventKey, p_access );
return VLC_SUCCESS;
}
access_t *p_access = (access_t*)p_this;
access_sys_t *p_sys = p_access->p_sys;
- var_DelCallback( p_access->p_vlc, "key-pressed", EventKey, p_access );
+ var_DelCallback( p_access->p_libvlc, "key-pressed", EventKey, p_access );
if( p_sys->f )
{
/*****************************************************************************
*
*****************************************************************************/
-static int Read( access_t *p_access, uint8_t *p_buffer, int i_len )
+static ssize_t Read( access_t *p_access, uint8_t *p_buffer, size_t i_len )
{
access_t *p_src = p_access->p_source;
int i_ret;
access_t *p_access = p_data;
access_sys_t *p_sys = p_access->p_sys;
- struct hotkey *p_hotkeys = p_access->p_vlc->p_hotkeys;
+ struct hotkey *p_hotkeys = p_access->p_libvlc->p_hotkeys;
int i_action = -1, i;
for( i = 0; p_hotkeys[i].psz_action != NULL; i++ )
if( p_sys->i_vout_chan != -1 )
{
if( b_dump )
- vout_OSDMessage( p_vout, p_sys->i_vout_chan, "Recording" );
+ vout_OSDMessage( p_vout, p_sys->i_vout_chan, _("Recording") );
else
- vout_OSDMessage( p_vout, p_sys->i_vout_chan, "Recording done" );
+ vout_OSDMessage( p_vout, p_sys->i_vout_chan, _("Recording done") );
}
vlc_object_release( p_vout );
}
p_input = vlc_object_find( p_access, VLC_OBJECT_INPUT, FIND_PARENT );
if( p_input )
{
- vlc_mutex_lock( &p_input->input.p_item->lock );
- if( p_input->input.p_item->psz_name )
+ input_item_t * p_item = input_GetItem( p_input );
+ vlc_mutex_lock( &p_item->lock );
+ if( p_item->psz_name )
{
- char *p = strrchr( p_input->input.p_item->psz_name, '/' );
+ char *p = strrchr( p_item->psz_name, '/' );
if( p == NULL )
- p = strrchr( p_input->input.p_item->psz_name, '\\' );
+ p = strrchr( p_item->psz_name, '\\' );
if( p == NULL )
- psz_name = strdup( p_input->input.p_item->psz_name );
+ psz_name = strdup( p_item->psz_name );
else if( p[1] != '\0' )
psz_name = strdup( &p[1] );
}
- vlc_mutex_unlock( &p_input->input.p_item->lock );
+ vlc_mutex_unlock( &p_item->lock );
vlc_object_release( p_input );
}
- if( psz_name == NULL )
- psz_name = strdup( "Unknown" );
-
- asprintf( &p_sys->psz_file, "%s/%s %d-%d-%d %.2dh%.2dm%.2ds.%s",
- p_sys->psz_path, psz_name,
- l.tm_mday, l.tm_mon+1, l.tm_year+1900,
- l.tm_hour, l.tm_min, l.tm_sec,
- p_sys->psz_ext );
+ if( asprintf( &p_sys->psz_file, "%s %d-%d-%d %.2dh%.2dm%.2ds.%s",
+ ( psz_name != NULL ) ? psz_name : "Unknown",
+ l.tm_mday, l.tm_mon+1, l.tm_year+1900,
+ l.tm_hour, l.tm_min, l.tm_sec,
+ p_sys->psz_ext ) == -1 )
+ p_sys->psz_file = NULL;
free( psz_name );
+ if( p_sys->psz_file == NULL )
+ {
+ p_sys->b_dump = VLC_FALSE;
+ return;
+ }
/* Remove all forbidden characters (except (back)slashes) */
for( psz = p_sys->psz_file; *psz; psz++ )
#endif
}
+ psz_name = p_sys->psz_file;
+
+#if defined (WIN32) || defined (UNDER_CE)
+#define DIR_SEP "\\"
+#else
+#define DIR_SEP "/"
+#endif
+ if( asprintf( &p_sys->psz_file, "%s" DIR_SEP "%s",
+ p_sys->psz_path, psz_name ) == -1 )
+ p_sys->psz_file = NULL;
+ free( psz_name );
+ if( p_sys->psz_file == NULL )
+ {
+ p_sys->b_dump = VLC_FALSE;
+ return;
+ }
+
msg_Dbg( p_access, "dump in file '%s'", p_sys->psz_file );
p_sys->f = utf8_fopen( p_sys->psz_file, "wb" );
if( p_sys->f == NULL )
{
- msg_Err( p_access, "cannot open file '%s' (%s)",
- p_sys->psz_file, strerror(errno) );
+ msg_Err( p_access, "cannot open file '%s' (%m)",
+ p_sys->psz_file );
free( p_sys->psz_file );
p_sys->psz_file = NULL;
p_sys->b_dump = VLC_FALSE;