aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--playlist.c119
1 files changed, 36 insertions, 83 deletions
diff --git a/playlist.c b/playlist.c
index 3cbc844..b532362 100644
--- a/playlist.c
+++ b/playlist.c
@@ -98,55 +98,12 @@ int alphasort(const struct dirent **, const struct dirent **);
t_widgetbehavior playlist_widgetbehavior;
static t_class *playlist_class;
-static int guidebug=0;
-
static char *playlist_version = "playlist: 1 click file chooser : version 0.12, written by Yves Degoyon (ydegoyon@free.fr)";
#define MAX_DIR_LENGTH 2048 // maximum length for a directory name
#define MIN(a,b) (a>b?b:a)
-#define SYS_VGUI2(a,b) if (guidebug) \
- post(a,b);\
- sys_vgui(a,b)
-
-#define SYS_VGUI3(a,b,c) if (guidebug) \
- post(a,b,c);\
- sys_vgui(a,b,c)
-
-#define SYS_VGUI4(a,b,c,d) if (guidebug) \
- post(a,b,c,d);\
- sys_vgui(a,b,c,d)
-
-#define SYS_VGUI5(a,b,c,d,e) if (guidebug) \
- post(a,b,c,d,e);\
- sys_vgui(a,b,c,d,e)
-
-#define SYS_VGUI6(a,b,c,d,e,f) if (guidebug) \
- post(a,b,c,d,e,f);\
- sys_vgui(a,b,c,d,e,f)
-
-#define SYS_VGUI7(a,b,c,d,e,f,g) if (guidebug) \
- post(a,b,c,d,e,f,g);\
- sys_vgui(a,b,c,d,e,f,g)
-
-#define SYS_VGUI8(a,b,c,d,e,f,g,h) if (guidebug) \
- post(a,b,c,d,e,f,g,h);\
- sys_vgui(a,b,c,d,e,f,g,h)
-
-#define SYS_VGUI9(a,b,c,d,e,f,g,h,i) if (guidebug) \
- post(a,b,c,d,e,f,g,h,i );\
- sys_vgui(a,b,c,d,e,f,g,h,i)
-
-#define SYS_VGUI10(a,b,c,d,e,f,g,h,i,j) if (guidebug) \
- post(a,b,c,d,e,f,g,h,i,j );\
- sys_vgui(a,b,c,d,e,f,g,h,i,j)
-
-#define SYS_VGUI11(a,b,c,d,e,f,g,h,i,j,k) if (guidebug) \
- post(a,b,c,d,e,f,g,h,i,j,k );\
- sys_vgui(a,b,c,d,e,f,g,h,i,j,k)
-
-
typedef struct _playlist
{
t_object x_obj;
@@ -189,10 +146,10 @@ static void playlist_update_dir(t_playlist *x, t_glist *glist)
tv.tv_nsec = 10000000;
// set title
- SYS_VGUI3(".x%lx.c delete %xTITLE\n", canvas, x);
+ sys_vgui(".x%lx.c delete %xTITLE\n", canvas, x);
if ( x->x_graphics )
{
- SYS_VGUI8(".x%lx.c create text %d %d -width %d -text \"%s\" -anchor w -font %s -tags %xTITLE\n",
+ sys_vgui(".x%lx.c create text %d %d -width %d -text \"%s\" -anchor w -font %s -tags %xTITLE\n",
canvas,
text_xpix(&x->x_obj, glist)+5,
text_ypix(&x->x_obj, glist)-10,
@@ -205,7 +162,7 @@ static void playlist_update_dir(t_playlist *x, t_glist *glist)
// delete previous entries
for ( i=x->x_firstseen; i<=x->x_lastseen; i++ )
{
- SYS_VGUI4(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
+ sys_vgui(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
}
// display the content of current directory
@@ -241,8 +198,6 @@ static void playlist_update_dir(t_playlist *x, t_glist *glist)
x->x_pnentries = nentries;
for ( i=0; i<nentries; i++ )
{
- size_t nmatches = 0;
- regmatch_t matchinfos[1];
DIR* tmpdir;
// ckeck if that entry should be displayed
@@ -271,7 +226,7 @@ static void playlist_update_dir(t_playlist *x, t_glist *glist)
x->x_lastseen = x->x_nentries;
strncpy( wrappedname, x->x_dentries[x->x_nentries], MIN(x->x_width/x->x_charwidth, MAX_DIR_LENGTH) );
wrappedname[ x->x_width/x->x_charwidth ] = '\0';
- SYS_VGUI11(".x%lx.c create text %d %d -fill %s -activefill %s -width %d -text \"%s\" -anchor w -font %s -tags %xENTRY%d\n",
+ sys_vgui(".x%lx.c create text %d %d -fill %s -activefill %s -width %d -text \"%s\" -anchor w -font %s -tags %xENTRY%d\n",
canvas,
text_xpix(&x->x_obj, glist)+5,
text_ypix(&x->x_obj, glist)+5+(x->x_nentries-x->x_firstseen)*x->x_charheight,
@@ -345,11 +300,11 @@ static void playlist_draw_new(t_playlist *x, t_glist *glist)
x->x_glist = glist;
if ( x->x_graphics )
{
- SYS_VGUI8(".x%lx.c create rectangle %d %d %d %d -fill %s -tags %xPLAYLIST\n",
+ sys_vgui(".x%lx.c create rectangle %d %d %d %d -fill %s -tags %xPLAYLIST\n",
canvas, text_xpix(&x->x_obj, glist), text_ypix(&x->x_obj, glist),
text_xpix(&x->x_obj, glist) + x->x_width, text_ypix(&x->x_obj, glist) + x->x_height,
x->x_bgcolor, x);
- SYS_VGUI8(".x%lx.c create rectangle %d %d %d %d -fill %s -tags %xSCROLLLIST\n",
+ sys_vgui(".x%lx.c create rectangle %d %d %d %d -fill %s -tags %xSCROLLLIST\n",
canvas, text_xpix(&x->x_obj, glist)+4*x->x_width/5, text_ypix(&x->x_obj, glist),
text_xpix(&x->x_obj, glist) + x->x_width, text_ypix(&x->x_obj, glist) + x->x_height,
x->x_sbcolor, x);
@@ -369,24 +324,24 @@ static void playlist_draw_move(t_playlist *x, t_glist *glist)
if ( x->x_graphics )
{
- SYS_VGUI7(".x%lx.c coords %xPLAYLIST %d %d %d %d\n",
+ sys_vgui(".x%lx.c coords %xPLAYLIST %d %d %d %d\n",
canvas, x,
text_xpix(&x->x_obj, glist), text_ypix(&x->x_obj, glist),
text_xpix(&x->x_obj, glist)+x->x_width,
text_ypix(&x->x_obj, glist)+x->x_height);
- SYS_VGUI7(".x%lx.c coords %xSCROLLLIST %d %d %d %d\n",
+ sys_vgui(".x%lx.c coords %xSCROLLLIST %d %d %d %d\n",
canvas, x,
text_xpix(&x->x_obj, glist)+4*x->x_width/5, text_ypix(&x->x_obj, glist),
text_xpix(&x->x_obj, glist)+x->x_width,
text_ypix(&x->x_obj, glist)+x->x_height);
- SYS_VGUI5(".x%lx.c coords %xTITLE %d %d\n",
+ sys_vgui(".x%lx.c coords %xTITLE %d %d\n",
canvas, x,
text_xpix(&x->x_obj, glist)+5, text_ypix(&x->x_obj, glist)-10 );
}
for ( i=x->x_firstseen; i<=x->x_lastseen; i++ )
{
// nanosleep( &tv, NULL );
- SYS_VGUI6(".x%lx.c coords %xENTRY%d %d %d\n",
+ sys_vgui(".x%lx.c coords %xENTRY%d %d %d\n",
canvas, x, i,
text_xpix(&x->x_obj, glist)+5,
text_ypix(&x->x_obj, glist)+5+(i-x->x_firstseen)*x->x_charheight);
@@ -402,13 +357,13 @@ static void playlist_draw_erase(t_playlist* x, t_glist* glist)
if ( x->x_graphics )
{
- SYS_VGUI3(".x%lx.c delete %xPLAYLIST\n", canvas, x);
- SYS_VGUI3(".x%lx.c delete %xSCROLLLIST\n", canvas, x);
- SYS_VGUI3(".x%lx.c delete %xTITLE\n", canvas, x);
+ sys_vgui(".x%lx.c delete %xPLAYLIST\n", canvas, x);
+ sys_vgui(".x%lx.c delete %xSCROLLLIST\n", canvas, x);
+ sys_vgui(".x%lx.c delete %xTITLE\n", canvas, x);
}
for ( i=x->x_firstseen; i<=x->x_lastseen; i++ )
{
- SYS_VGUI4(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
+ sys_vgui(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
}
}
@@ -420,11 +375,11 @@ static void playlist_draw_select(t_playlist* x, t_glist* glist)
if(x->x_selected)
{
/* sets the item in blue */
- if (x->x_graphics) SYS_VGUI3(".x%lx.c itemconfigure %xPLAYLIST -outline #0000FF\n", canvas, x);
+ if (x->x_graphics) sys_vgui(".x%lx.c itemconfigure %xPLAYLIST -outline #0000FF\n", canvas, x);
}
else
{
- if (x->x_graphics) SYS_VGUI3(".x%lx.c itemconfigure %xPLAYLIST -outline #000000\n", canvas, x);
+ if (x->x_graphics) sys_vgui(".x%lx.c itemconfigure %xPLAYLIST -outline #000000\n", canvas, x);
}
}
@@ -520,7 +475,7 @@ static void playlist_motion(t_playlist *x, t_floatarg dx, t_floatarg dy)
{
for ( i=x->x_firstseen; i<=x->x_lastseen; i++ )
{
- SYS_VGUI4(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
+ sys_vgui(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
}
x->x_firstseen++;
for ( i=x->x_firstseen; i< x->x_nentries; i++ )
@@ -532,7 +487,7 @@ static void playlist_motion(t_playlist *x, t_floatarg dx, t_floatarg dy)
x->x_lastseen = i;
strncpy( wrappedname, x->x_dentries[i], x->x_width/x->x_charwidth );
wrappedname[ x->x_width/x->x_charwidth ] = '\0';
- SYS_VGUI11(".x%lx.c create text %d %d -fill %s -activefill %s -width %d -text \"%s\" -anchor w -font %s -tags %xENTRY%d\n",
+ sys_vgui(".x%lx.c create text %d %d -fill %s -activefill %s -width %d -text \"%s\" -anchor w -font %s -tags %xENTRY%d\n",
canvas,
text_xpix(&x->x_obj, x->x_glist)+5,
text_ypix(&x->x_obj, x->x_glist)+5+(i-x->x_firstseen)*x->x_charheight,
@@ -545,7 +500,7 @@ static void playlist_motion(t_playlist *x, t_floatarg dx, t_floatarg dy)
}
else break;
}
- SYS_VGUI5(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
+ sys_vgui(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
canvas, x, x->x_itemselected, x->x_secolor);
// post( "playlist : moved down first=%d last=%d", x->x_firstseen, x->x_lastseen );
}
@@ -561,7 +516,7 @@ static void playlist_motion(t_playlist *x, t_floatarg dx, t_floatarg dy)
{
for ( i=x->x_firstseen; i<=x->x_lastseen; i++ )
{
- SYS_VGUI4(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
+ sys_vgui(".x%lx.c delete %xENTRY%d\n", canvas, x, i);
}
x->x_firstseen--;
for ( i=x->x_firstseen; i< x->x_nentries; i++ )
@@ -573,7 +528,7 @@ static void playlist_motion(t_playlist *x, t_floatarg dx, t_floatarg dy)
x->x_lastseen = i;
strncpy( wrappedname, x->x_dentries[i], x->x_width/x->x_charwidth );
wrappedname[ x->x_width/x->x_charwidth ] = '\0';
- SYS_VGUI11(".x%lx.c create text %d %d -fill %s -activefill %s -width %d -text \"%s\" \
+ sys_vgui(".x%lx.c create text %d %d -fill %s -activefill %s -width %d -text \"%s\" \
-anchor w -font %s -tags %xENTRY%d\n",
canvas,
text_xpix(&x->x_obj, x->x_glist)+5,
@@ -587,7 +542,7 @@ static void playlist_motion(t_playlist *x, t_floatarg dx, t_floatarg dy)
}
else break;
}
- SYS_VGUI5(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
+ sys_vgui(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
canvas, x, x->x_itemselected, x->x_secolor);
// post( "playlist : moved up first=%d last=%d", x->x_firstseen, x->x_lastseen );
}
@@ -631,10 +586,10 @@ static int playlist_click(t_gobj *z, struct _glist *glist,
if ( (xpix-text_xpix(&x->x_obj, glist)) < 4*x->x_width/5 )
{
// deselect previously selected item
- SYS_VGUI5(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
+ sys_vgui(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
canvas, x, x->x_itemselected, x->x_fgcolor);
x->x_itemselected = x->x_firstseen + (ypix-text_ypix(&x->x_obj, glist))/x->x_charheight;
- SYS_VGUI5(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
+ sys_vgui(".x%lx.c itemconfigure %xENTRY%d -fill %s\n",
canvas, x, x->x_itemselected, x->x_secolor);
// post( "playlist : selected item : %d", x->x_itemselected );
if ( x->x_dentries && ( x->x_itemselected < x->x_nentries ) )
@@ -743,9 +698,8 @@ static void playlist_dialog(t_playlist *x, t_symbol *s, int argc, t_atom *argv)
static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
{
- t_int i, argoffset=0;
+ t_int argoffset=0;
t_playlist *x;
- char *tmpcurdir;
x = (t_playlist *)pd_new(playlist_class);
@@ -790,7 +744,7 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
}
if ( (int)argv[1].a_w.w_float <= 0 )
{
- pd_error(x, "playlist : wrong width (%d)", (t_int)(int)argv[1].a_w.w_float );
+ pd_error(x, "playlist : wrong width (%d)", (int)argv[1].a_w.w_float );
pd_error(x, "playlist : usage : playlist <extension> <width> <height>" );
return NULL;
}
@@ -805,7 +759,7 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
}
if ( (int)argv[2].a_w.w_float <= 0 )
{
- pd_error(x, "playlist : wrong height (%d)", (t_int)(int)argv[2].a_w.w_float );
+ pd_error(x, "playlist : wrong height (%d)", (int)argv[2].a_w.w_float );
pd_error(x, "playlist : usage : playlist <extension> <width> <height>" );
return NULL;
}
@@ -840,13 +794,13 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
(int)x->x_charheight, argv[5].a_w.w_symbol->s_name );
argoffset=0;
}
- verbose(0, "playlist : font : %s, size : %d", x->x_font, x->x_charheight );
+ verbose(0, "playlist : font : %s, size : %d", x->x_font, (int)x->x_charheight );
}
if ( argc >= 7-argoffset )
{
if ( argv[6-argoffset].a_type != A_SYMBOL )
{
- pd_error(x, "playlist : wrong arguments (background color : %d)", 7-argoffset );
+ pd_error(x, "playlist : wrong arguments (background color : %d)", 7-(int)argoffset );
return NULL;
}
strcpy( x->x_bgcolor, argv[6-argoffset].a_w.w_symbol->s_name );
@@ -855,7 +809,7 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
{
if ( argv[7-argoffset].a_type != A_SYMBOL )
{
- pd_error(x, "playlist : wrong arguments (scrollbar color : %d)", 8-argoffset );
+ pd_error(x, "playlist : wrong arguments (scrollbar color : %d)", 8-(int)argoffset );
return NULL;
}
strcpy( x->x_sbcolor, argv[7-argoffset].a_w.w_symbol->s_name );
@@ -864,7 +818,7 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
{
if ( argv[8-argoffset].a_type != A_SYMBOL )
{
- pd_error(x, "playlist : wrong arguments (foreground color : %d)", 9-argoffset );
+ pd_error(x, "playlist : wrong arguments (foreground color : %d)", 9-(int)argoffset );
return NULL;
}
strcpy( x->x_fgcolor, argv[8-argoffset].a_w.w_symbol->s_name );
@@ -873,7 +827,7 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
{
if ( argv[9-argoffset].a_type != A_SYMBOL )
{
- pd_error(x, "playlist : wrong arguments (selection color : %d)", 10-argoffset );
+ pd_error(x, "playlist : wrong arguments (selection color : %d)", 10-(int)argoffset );
return NULL;
}
strcpy( x->x_secolor, argv[9-argoffset].a_w.w_symbol->s_name );
@@ -889,7 +843,7 @@ static t_playlist *playlist_new(t_symbol *s, int argc, t_atom *argv )
x->x_dentries = NULL;
// get current directory full path
- t_symbol *cwd = canvas_getdir(canvas_getcurrent());
+ t_symbol *cwd = canvas_getdir(x->x_glist);
int cwdlen = strlen(cwd->s_name);
x->x_curdir = ( char * ) getbytes( cwdlen );
strncpy( x->x_curdir, cwd->s_name, cwdlen );
@@ -959,15 +913,14 @@ static void playlist_seek(t_playlist *x, t_floatarg fseeked)
{
return;
}
- SYS_VGUI5(".x%lx.c itemconfigure %xENTRY%d -fill %s\n", canvas, x, x->x_itemselected, x->x_fgcolor);
+ sys_vgui(".x%lx.c itemconfigure %xENTRY%d -fill %s\n", canvas, x, x->x_itemselected, x->x_fgcolor);
x->x_itemselected = iout;
- SYS_VGUI5(".x%lx.c itemconfigure %xENTRY%d -fill %s\n", canvas, x, x->x_itemselected, x->x_secolor);
+ sys_vgui(".x%lx.c itemconfigure %xENTRY%d -fill %s\n", canvas, x, x->x_itemselected, x->x_secolor);
playlist_output_current(x);
}
static void playlist_location(t_playlist *x, t_symbol *flocation)
{
- int iout=0;
char olddir[ MAX_DIR_LENGTH ]; /* remember old location */
strcpy( olddir, x->x_curdir );
@@ -1024,7 +977,7 @@ static void playlist_location(t_playlist *x, t_symbol *flocation)
void playlist_setup(void)
{
- verbose(0, playlist_version );
+ verbose(0, "%s", playlist_version );
playlist_class = class_new(gensym("playlist"), (t_newmethod)playlist_new,
(t_method)playlist_free, sizeof(t_playlist),
CLASS_DEFAULT, A_GIMME, 0);