Commit 4e412817 authored by Sam Hocevar's avatar Sam Hocevar

  * ./po/no.po: Norwegian translation by Sigmund Augdal. Berd� ka p� t�t.
  * ./src/misc/modules.c: shortcuts for --intf work again, gvlc launches the
    Gtk interface, qvlc launches the Qt interface, etc.
  * ./plugins/fx/scope.c: we now have sound together with --aout scope.
parent 9487d454
...@@ -13,6 +13,7 @@ D: communication with channel server ...@@ -13,6 +13,7 @@ D: communication with channel server
N: Sigmund Augdal N: Sigmund Augdal
E: sigmunau@idi.ntnu.no E: sigmunau@idi.ntnu.no
D: lirc plugin D: lirc plugin
D: norwegian translation
N: Pierre Baillet N: Pierre Baillet
E: oct@zoy.org E: oct@zoy.org
......
...@@ -1163,7 +1163,7 @@ fi ...@@ -1163,7 +1163,7 @@ fi
fi fi
ALL_LINGUAS="de fr ru" ALL_LINGUAS="de fr no ru"
cat >> confdefs.h <<EOF cat >> confdefs.h <<EOF
#define PACKAGE "vlc" #define PACKAGE "vlc"
......
...@@ -34,7 +34,7 @@ dnl Find the right ranlib, even when cross-compiling ...@@ -34,7 +34,7 @@ dnl Find the right ranlib, even when cross-compiling
AC_CHECK_TOOL(RANLIB, ranlib, :) AC_CHECK_TOOL(RANLIB, ranlib, :)
dnl Gettext stuff dnl Gettext stuff
ALL_LINGUAS="de fr ru" ALL_LINGUAS="de fr no ru"
AC_DEFINE_UNQUOTED(PACKAGE, "vlc") AC_DEFINE_UNQUOTED(PACKAGE, "vlc")
AC_DEFINE_UNQUOTED(VERSION, "$VLC_VERSION") AC_DEFINE_UNQUOTED(VERSION, "$VLC_VERSION")
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* scope.c : Scope effect module * scope.c : Scope effect module
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* $Id: scope.c,v 1.2 2002/02/27 22:57:10 sam Exp $ * $Id: scope.c,v 1.3 2002/03/01 16:07:00 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* *
...@@ -35,8 +35,8 @@ ...@@ -35,8 +35,8 @@
#include "audio_output.h" /* aout_thread_t */ #include "audio_output.h" /* aout_thread_t */
#define SCOPE_WIDTH 640 #define SCOPE_WIDTH 320
#define SCOPE_HEIGHT 200 #define SCOPE_HEIGHT 240
#define SCOPE_ASPECT (VOUT_ASPECT_FACTOR*SCOPE_WIDTH/SCOPE_HEIGHT) #define SCOPE_ASPECT (VOUT_ASPECT_FACTOR*SCOPE_WIDTH/SCOPE_HEIGHT)
/***************************************************************************** /*****************************************************************************
...@@ -111,13 +111,37 @@ static int aout_Open( aout_thread_t *p_aout ) ...@@ -111,13 +111,37 @@ static int aout_Open( aout_thread_t *p_aout )
if( p_aout->p_sys == NULL ) if( p_aout->p_sys == NULL )
{ {
intf_ErrMsg("error: %s", strerror(ENOMEM) ); intf_ErrMsg("error: %s", strerror(ENOMEM) );
return( 1 ); return -1;
} }
/* Open video output */
p_aout->p_sys->p_vout = p_aout->p_sys->p_vout =
vout_CreateThread( NULL, SCOPE_WIDTH, SCOPE_HEIGHT, vout_CreateThread( NULL, SCOPE_WIDTH, SCOPE_HEIGHT,
FOURCC_I420, SCOPE_ASPECT ); FOURCC_I420, SCOPE_ASPECT );
/* Open audio output */
p_aout->p_sys->aout.i_format = p_aout->i_format;
p_aout->p_sys->aout.i_rate = p_aout->i_rate;
p_aout->p_sys->aout.i_channels = p_aout->i_channels;
p_aout->p_sys->aout.p_module = module_Need( MODULE_CAPABILITY_AOUT, "",
(void *)&p_aout->p_sys->aout );
if( p_aout->p_sys->aout.p_module == NULL )
{
intf_ErrMsg( "aout error: no suitable aout module" );
vout_DestroyThread( p_aout->p_sys->p_vout, NULL );
free( p_aout->p_sys );
return -1;
}
#define aout_functions p_aout->p_sys->aout.p_module->p_functions->aout.functions.aout
p_aout->p_sys->aout.pf_open = aout_functions.pf_open;
p_aout->p_sys->aout.pf_setformat = aout_functions.pf_setformat;
p_aout->p_sys->aout.pf_getbufinfo = aout_functions.pf_getbufinfo;
p_aout->p_sys->aout.pf_play = aout_functions.pf_play;
p_aout->p_sys->aout.pf_close = aout_functions.pf_close;
#undef aout_functions
return( 0 ); return( 0 );
} }
...@@ -126,15 +150,35 @@ static int aout_Open( aout_thread_t *p_aout ) ...@@ -126,15 +150,35 @@ static int aout_Open( aout_thread_t *p_aout )
*****************************************************************************/ *****************************************************************************/
static int aout_SetFormat( aout_thread_t *p_aout ) static int aout_SetFormat( aout_thread_t *p_aout )
{ {
/* Force the output method */ int i_ret;
p_aout->i_format = AOUT_FMT_U16_LE;
p_aout->i_channels = 2;
/* Force the output method */
p_aout->p_sys->aout.i_format = p_aout->i_format; p_aout->p_sys->aout.i_format = p_aout->i_format;
p_aout->p_sys->aout.i_channels = p_aout->i_channels; p_aout->p_sys->aout.i_channels = p_aout->i_channels;
p_aout->p_sys->aout.i_rate = p_aout->i_rate; p_aout->p_sys->aout.i_rate = p_aout->i_rate;
return( 0 ); /*
* Initialize audio device
*/
i_ret = p_aout->p_sys->aout.pf_setformat( &p_aout->p_sys->aout );
if( i_ret )
{
return i_ret;
}
if( p_aout->p_sys->aout.i_format != p_aout->i_format
|| p_aout->p_sys->aout.i_channels != p_aout->i_channels )
{
intf_ErrMsg( "aout error: plugin isn't cooperative" );
return 0;
}
p_aout->i_channels = p_aout->p_sys->aout.i_channels;
p_aout->i_format = p_aout->p_sys->aout.i_format;
p_aout->i_rate = p_aout->p_sys->aout.i_rate;
return 0;
} }
/***************************************************************************** /*****************************************************************************
...@@ -142,8 +186,8 @@ static int aout_SetFormat( aout_thread_t *p_aout ) ...@@ -142,8 +186,8 @@ static int aout_SetFormat( aout_thread_t *p_aout )
*****************************************************************************/ *****************************************************************************/
static int aout_GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit ) static int aout_GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit )
{ {
/* arbitrary value that should be changed */ return p_aout->p_sys->aout.pf_getbufinfo( &p_aout->p_sys->aout,
return( i_buffer_limit ); i_buffer_limit );
} }
/***************************************************************************** /*****************************************************************************
...@@ -154,67 +198,87 @@ static int aout_GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit ) ...@@ -154,67 +198,87 @@ static int aout_GetBufInfo( aout_thread_t *p_aout, int i_buffer_limit )
static void aout_Play( aout_thread_t *p_aout, byte_t *p_buffer, int i_size ) static void aout_Play( aout_thread_t *p_aout, byte_t *p_buffer, int i_size )
{ {
picture_t *p_outpic; picture_t *p_outpic;
int i_index; int i_index, i_image;
u8 *p_pixel; u8 *ppp_area[2][3];
u16 *p_sample; u16 *p_sample;
/* This is a new frame. Get a structure from the video_output. */ /* Play the real sound */
while( ( p_outpic = vout_CreatePicture( p_aout->p_sys->p_vout, 0, 0, 0 ) ) p_aout->p_sys->aout.pf_play( &p_aout->p_sys->aout, p_buffer, i_size );
== NULL )
for( i_image = 0; (i_image + 1) * SCOPE_WIDTH * 8 < i_size ; i_image++ )
{ {
if( p_aout->b_die ) /* Don't stay here forever */
if( mdate() >= p_aout->date - 10000 )
{ {
return; break;
} }
msleep( VOUT_OUTMEM_SLEEP );
}
/* Blank the picture */
for( i_index = 0 ; i_index < p_outpic->i_planes ; i_index++ )
{
memset( p_outpic->p[i_index].p_pixels, i_index ? 0x80 : 0x00,
p_outpic->p[i_index].i_lines * p_outpic->p[i_index].i_pitch );
}
/* Left channel */ /* This is a new frame. Get a structure from the video_output. */
for( i_index = 0, p_sample = (u16*)p_buffer; while( ( p_outpic = vout_CreatePicture( p_aout->p_sys->p_vout, 0, 0, 0 ) )
i_index < SCOPE_WIDTH && i_index < i_size / 2; == NULL )
i_index++ ) {
{ if( p_aout->b_die )
int i; {
u8 i_value = *p_sample / 256; return;
}
msleep( VOUT_OUTMEM_SLEEP );
}
for( i = 0 ; i < 8 ; i++ ) /* Blank the picture */
for( i_index = 0 ; i_index < p_outpic->i_planes ; i_index++ )
{ {
p_pixel = p_outpic->p[0].p_pixels + (p_outpic->p[0].i_pitch * i_index) / SCOPE_WIDTH + p_outpic->p[0].i_lines * (u8)(i_value+128) / 512 * p_outpic->p[0].i_pitch; memset( p_outpic->p[i_index].p_pixels, i_index ? 0x80 : 0x00,
*p_pixel = 0x9f; p_outpic->p[i_index].i_lines * p_outpic->p[i_index].i_pitch );
p_pixel = p_outpic->p[1].p_pixels + (p_outpic->p[1].i_pitch * i_index) / SCOPE_WIDTH + p_outpic->p[1].i_lines * (u8)(i_value+128) / 512 * p_outpic->p[1].i_pitch;
*p_pixel = 0x00;
p_sample += 2;
} }
}
/* Right channel */ /* We only support 2 channels for now */
for( i_index = 0, p_sample = (u16*)p_buffer + 1; for( i_index = 0 ; i_index < 2 ; i_index++ )
i_index < SCOPE_WIDTH && i_index < i_size / 2; {
i_index++ ) ppp_area[i_index][0] = p_outpic->p[0].p_pixels + i_index * p_outpic->p[0].i_lines / p_aout->i_channels * p_outpic->p[0].i_pitch;
{ ppp_area[i_index][1] = p_outpic->p[1].p_pixels + i_index * p_outpic->p[1].i_lines / p_aout->i_channels * p_outpic->p[1].i_pitch;
int i; ppp_area[i_index][2] = p_outpic->p[2].p_pixels + i_index * p_outpic->p[2].i_lines / p_aout->i_channels * p_outpic->p[2].i_pitch;
u8 i_value = *p_sample / 256; }
for( i = 0 ; i < 8 ; i++ ) for( i_index = 0, p_sample = (u16*)p_buffer;
i_index < SCOPE_WIDTH;
i_index++ )
{ {
p_pixel = p_outpic->p[0].p_pixels + (p_outpic->p[0].i_pitch * i_index) / SCOPE_WIDTH + (p_outpic->p[0].i_lines * (u8)(i_value+128) / 512 + p_outpic->p[0].i_lines / 2) * p_outpic->p[0].i_pitch; int i;
*p_pixel = 0x7f; u8 i_value;
p_pixel = p_outpic->p[2].p_pixels + (p_outpic->p[2].i_pitch * i_index) / SCOPE_WIDTH + (p_outpic->p[2].i_lines * (u8)(i_value+128) / 512 + p_outpic->p[2].i_lines / 2) * p_outpic->p[2].i_pitch;
*p_pixel = 0xdd; for( i = 0 ; i < 2 ; i++ )
p_sample += 2; {
/* Left channel */
i_value = *p_sample++ / 256 + 128;
*(ppp_area[0][0]
+ p_outpic->p[0].i_pitch * i_index / SCOPE_WIDTH
+ p_outpic->p[0].i_lines * i_value / 512
* p_outpic->p[0].i_pitch) = 0xbf;
*(ppp_area[0][1]
+ p_outpic->p[1].i_pitch * i_index / SCOPE_WIDTH
+ p_outpic->p[1].i_lines * i_value / 512
* p_outpic->p[1].i_pitch) = 0xff;
/* Right channel */
i_value = *p_sample++ / 256 + 128;
*(ppp_area[1][0]
+ p_outpic->p[0].i_pitch * i_index / SCOPE_WIDTH
+ p_outpic->p[0].i_lines * i_value / 512
* p_outpic->p[0].i_pitch) = 0x9f;
*(ppp_area[1][2]
+ p_outpic->p[2].i_pitch * i_index / SCOPE_WIDTH
+ p_outpic->p[2].i_lines * i_value / 512
* p_outpic->p[2].i_pitch) = 0xdd;
}
} }
}
/* Display the picture */ /* Display the picture - FIXME: find a better date :-) */
vout_DatePicture( p_aout->p_sys->p_vout, p_outpic, p_aout->date ); vout_DatePicture( p_aout->p_sys->p_vout, p_outpic,
vout_DisplayPicture( p_aout->p_sys->p_vout, p_outpic ); p_aout->date + i_image * 10000 );
vout_DisplayPicture( p_aout->p_sys->p_vout, p_outpic );
p_buffer += SCOPE_WIDTH * 4;
}
} }
/***************************************************************************** /*****************************************************************************
...@@ -222,6 +286,8 @@ static void aout_Play( aout_thread_t *p_aout, byte_t *p_buffer, int i_size ) ...@@ -222,6 +286,8 @@ static void aout_Play( aout_thread_t *p_aout, byte_t *p_buffer, int i_size )
*****************************************************************************/ *****************************************************************************/
static void aout_Close( aout_thread_t *p_aout ) static void aout_Close( aout_thread_t *p_aout )
{ {
p_aout->p_sys->aout.pf_close( &p_aout->p_sys->aout );
module_Unneed( p_aout->p_sys->aout.p_module );
vout_DestroyThread( p_aout->p_sys->p_vout, NULL ); vout_DestroyThread( p_aout->p_sys->p_vout, NULL );
free( p_aout->p_sys ); free( p_aout->p_sys );
} }
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* kde.cpp : KDE plugin for vlc * kde.cpp : KDE plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2001 VideoLAN * Copyright (C) 2001 VideoLAN
* $Id: kde.cpp,v 1.7 2002/02/24 20:51:10 gbazin Exp $ * $Id: kde.cpp,v 1.8 2002/03/01 16:07:00 sam Exp $
* *
* Authors: Andres Krapf <dae@chez.com> Sun Mar 25 2001 * Authors: Andres Krapf <dae@chez.com> Sun Mar 25 2001
* *
...@@ -53,6 +53,7 @@ MODULE_CONFIG_STOP ...@@ -53,6 +53,7 @@ MODULE_CONFIG_STOP
MODULE_INIT_START MODULE_INIT_START
SET_DESCRIPTION( "KDE interface module" ) SET_DESCRIPTION( "KDE interface module" )
ADD_CAPABILITY( INTF, 80 ) ADD_CAPABILITY( INTF, 80 )
ADD_SHORTCUT( "kde" )
ADD_PROGRAM( "kvlc" ) ADD_PROGRAM( "kvlc" )
MODULE_INIT_STOP MODULE_INIT_STOP
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* qt.cpp : Qt plugin for vlc * qt.cpp : Qt plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2001 VideoLAN * Copyright (C) 2001 VideoLAN
* $Id: qt.cpp,v 1.7 2002/02/24 20:51:10 gbazin Exp $ * $Id: qt.cpp,v 1.8 2002/03/01 16:07:00 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* *
...@@ -46,6 +46,7 @@ MODULE_INIT_START ...@@ -46,6 +46,7 @@ MODULE_INIT_START
SET_DESCRIPTION( "Qt interface module" ) SET_DESCRIPTION( "Qt interface module" )
ADD_CAPABILITY( INTF, 80 ) ADD_CAPABILITY( INTF, 80 )
ADD_PROGRAM( "qvlc" ) ADD_PROGRAM( "qvlc" )
ADD_SHORTCUT( "qt" )
MODULE_INIT_STOP MODULE_INIT_STOP
MODULE_ACTIVATE_START MODULE_ACTIVATE_START
......
This diff is collapsed.
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* modules.c : Built-in and plugin modules management functions * modules.c : Built-in and plugin modules management functions
***************************************************************************** *****************************************************************************
* Copyright (C) 2001 VideoLAN * Copyright (C) 2001 VideoLAN
* $Id: modules.c,v 1.55 2002/03/01 00:33:18 massiot Exp $ * $Id: modules.c,v 1.56 2002/03/01 16:07:00 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* Ethan C. Baldridge <BaldridgeE@cadmus.com> * Ethan C. Baldridge <BaldridgeE@cadmus.com>
...@@ -258,9 +258,10 @@ module_t * module_Need( int i_capability, char *psz_name, void *p_data ) ...@@ -258,9 +258,10 @@ module_t * module_Need( int i_capability, char *psz_name, void *p_data )
struct module_s *p_module; struct module_s *p_module;
struct module_list_s* p_next; struct module_list_s* p_next;
} module_list_t; } module_list_t;
struct module_list_s *p_list, *p_first; struct module_list_s *p_list, *p_first, *p_tolock;
int i_ret, i_index = 0; int i_ret, i_index = 0;
boolean_t b_intf = 0;
module_t *p_module; module_t *p_module;
char *psz_realname = NULL; char *psz_realname = NULL;
...@@ -325,25 +326,36 @@ module_t * module_Need( int i_capability, char *psz_name, void *p_data ) ...@@ -325,25 +326,36 @@ module_t * module_Need( int i_capability, char *psz_name, void *p_data )
} }
} }
/* Test if we requested a particular intf plugin */ /* Special case: test if we requested a particular intf plugin */
#if 0 if( i_capability == MODULE_CAPABILITY_INTF )
if( i_capability == MODULE_CAPABILITY_INTF
&& p_module->psz_program != NULL
&& strcmp( p_module->psz_program, p_main->psz_arg0 ) )
{ {
continue; if( p_module->psz_program != NULL
&& !strcmp( p_module->psz_program, p_main->psz_arg0 ) )
{
if( !b_intf )
{
/* Remove previous non-matching plugins */
i_index = 0;
b_intf = 1;
}
}
else
{
if( b_intf )
{
/* This one doesn't match */
continue;
}
}
} }
#endif
/* Store this new module */ /* Store this new module */
p_list[ i_index ].p_module = p_module; p_list[ i_index ].p_module = p_module;
/* Lock it */ /* Add it to the modules-to-probe list */
LockModule( p_module );
if( i_index == 0 ) if( i_index == 0 )
{ {
p_list[ i_index ].p_next = NULL; p_list[ 0 ].p_next = NULL;
p_first = p_list; p_first = p_list;
} }
else else
...@@ -376,7 +388,15 @@ module_t * module_Need( int i_capability, char *psz_name, void *p_data ) ...@@ -376,7 +388,15 @@ module_t * module_Need( int i_capability, char *psz_name, void *p_data )
i_index++; i_index++;
} }
/* We can release the global lock, module refcount were incremented */ /* Lock all selected modules */
p_tolock = p_first;
while( p_tolock != NULL )
{
LockModule( p_tolock->p_module );
p_tolock = p_tolock->p_next;
}
/* We can release the global lock, module refcounts were incremented */
vlc_mutex_unlock( &p_module_bank->lock ); vlc_mutex_unlock( &p_module_bank->lock );
/* Parse the linked list and use the first successful module */ /* Parse the linked list and use the first successful module */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment