Mercurial > mplayer.hg
annotate gui/ui/gtk/playlist.c @ 34399:f2c03009068d
Don't explicitly set stream type if the type doesn't change.
Use a self-explanatory symbolic constant which makes the code
more easily understandable.
author | ib |
---|---|
date | Mon, 02 Jan 2012 15:16:55 +0000 |
parents | 6e4af5500f8f |
children | a650895d50a5 |
rev | line source |
---|---|
33572 | 1 /* |
2 * This file is part of MPlayer. | |
3 * | |
4 * MPlayer is free software; you can redistribute it and/or modify | |
5 * it under the terms of the GNU General Public License as published by | |
6 * the Free Software Foundation; either version 2 of the License, or | |
7 * (at your option) any later version. | |
8 * | |
9 * MPlayer is distributed in the hope that it will be useful, | |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 * GNU General Public License for more details. | |
13 * | |
14 * You should have received a copy of the GNU General Public License along | |
15 * with MPlayer; if not, write to the Free Software Foundation, Inc., | |
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | |
17 */ | |
18 | |
19 #include <sys/types.h> | |
20 #include <sys/stat.h> | |
21 #include <string.h> | |
22 #include <dirent.h> | |
23 #include <unistd.h> | |
24 #include <stdio.h> | |
25 #include <stdlib.h> | |
26 | |
27 #include <gdk/gdkkeysyms.h> | |
28 #include <gtk/gtk.h> | |
29 | |
30 #include "config.h" | |
31 #include "help_mp.h" | |
32 #include "stream/stream.h" | |
33 | |
33750
8b5898908212
Remove variable holding history of selected files from interface.[ch].
ib
parents:
33742
diff
changeset
|
34 #include "gui/cfg.h" |
33572 | 35 #include "gui/ui/widgets.h" |
33742
e1539e14d60f
Move purely list related parts of gtkSet() from interface.c to list.c.
ib
parents:
33740
diff
changeset
|
36 #include "gui/util/list.h" |
33739 | 37 #include "gui/util/mem.h" |
33572 | 38 #include "playlist.h" |
39 #include "tools.h" | |
40 | |
33575 | 41 #include "gui/ui/pixmaps/open2.xpm" |
42 #include "gui/ui/pixmaps/dir2.xpm" | |
33572 | 43 |
44 GtkWidget * PlayList = NULL; | |
45 static GtkWidget * CTDirTree; | |
46 static GtkWidget * CLFiles; | |
47 static GtkWidget * CLSelected; | |
48 static GtkWidget * Add; | |
49 static GtkWidget * Remove; | |
50 static GtkWidget * Ok; | |
51 static GtkWidget * Cancel; | |
52 static GdkPixmap * pxOpenedBook; | |
53 static GdkPixmap * pxClosedBook; | |
54 static GdkBitmap * msOpenedBook; | |
55 static GdkBitmap * msClosedBook; | |
56 | |
57 static int NrOfEntrys = 0; | |
58 static int NrOfSelected = 0; | |
59 static int * CLFileSelected = NULL; | |
60 static int * CLListSelected = NULL; | |
61 | |
62 static int sigSel; | |
63 static int sigUnsel; | |
64 static int sigEvent; | |
65 | |
66 typedef struct | |
67 { | |
68 int scaned; | |
69 char * path; | |
70 } DirNodeType; | |
71 | |
72 static GtkCTreeNode * sibling; | |
73 static GtkCTreeNode * parent; | |
74 static gchar * current_path; | |
75 static gchar * old_path = NULL; | |
76 | |
77 static int compare_func(const void *a, const void *b) | |
78 { | |
79 char * tmp; | |
80 int i; | |
81 if ( !a || !b || !( (DirNodeType *)a )->path ) return -1; | |
82 tmp=strdup( (char *)b ); tmp[strlen( tmp )-1]=0; | |
83 i=strcmp( ( (DirNodeType *)a )->path,tmp ); | |
84 free( tmp ); | |
85 return i; | |
86 } | |
87 | |
88 static void scan_dir( char * path ); | |
89 | |
90 void ShowPlayList( void ) | |
91 { | |
92 if ( PlayList ) gtkActive( PlayList ); | |
93 else PlayList=create_PlayList(); | |
94 | |
95 if ( old_path && *old_path ) | |
96 { | |
97 char * currentdir = strdup( old_path ); | |
98 char * tpath,* pos; | |
99 GtkCTreeNode * node,* nextnode; | |
100 gboolean leaf; | |
101 tpath=strdup( "/" ); | |
102 pos=strtok( currentdir,"/" ); | |
103 node=gtk_ctree_find_by_row_data_custom( GTK_CTREE( CTDirTree ),NULL,"/",compare_func ); | |
104 do | |
105 { | |
106 char * tpathnew = g_strconcat( tpath,pos,"/",NULL ); | |
107 free( tpath ); tpath=tpathnew; | |
108 nextnode=gtk_ctree_find_by_row_data_custom( GTK_CTREE( CTDirTree ),node,tpath,compare_func ); | |
109 if ( !nextnode ) break; | |
110 node=nextnode; | |
111 pos=strtok( NULL,"/" ); | |
112 gtk_ctree_get_node_info( GTK_CTREE( CTDirTree ),node,NULL,NULL,NULL,NULL,NULL,NULL,&leaf,NULL ); | |
113 if ( !leaf && pos ) gtk_ctree_expand( GTK_CTREE( CTDirTree ),node ); | |
114 else | |
115 { | |
116 DirNodeType * DirNode; | |
117 gtk_ctree_select( GTK_CTREE( CTDirTree ),node ); | |
118 DirNode=gtk_ctree_node_get_row_data( GTK_CTREE( CTDirTree ),node ); | |
119 current_path=DirNode->path; | |
120 scan_dir( DirNode->path ); | |
121 free( CLFileSelected ); | |
122 CLFileSelected=calloc( 1,NrOfEntrys * sizeof( int ) ); | |
123 break; | |
124 } | |
125 } while( pos ); | |
126 free( tpath ); | |
127 free( currentdir ); | |
128 } | |
129 else gtk_ctree_select( GTK_CTREE( CTDirTree ),parent ); | |
130 | |
131 gtk_clist_freeze( GTK_CLIST( CLSelected ) ); | |
132 gtk_clist_clear( GTK_CLIST( CLSelected ) ); | |
133 if ( plList ) | |
134 { | |
135 gchar * name, * path; | |
136 plItem * next = plList; | |
137 while ( next || next->next ) | |
138 { | |
139 char * text[1][3]; text[0][2]=""; | |
140 name = g_filename_to_utf8( next->name, -1, NULL, NULL, NULL ); | |
141 path = g_filename_to_utf8( next->path, -1, NULL, NULL, NULL ); | |
142 text[0][0]=name ? name : next->name; | |
143 text[0][1]=path ? path : next->path; | |
144 gtk_clist_append( GTK_CLIST( CLSelected ),text[0] ); | |
145 g_free( path ); | |
146 g_free( name ); | |
147 NrOfSelected++; | |
148 if ( next->next ) next=next->next; else break; | |
149 } | |
150 CLListSelected=calloc( 1,NrOfSelected * sizeof( int ) ); | |
151 } | |
152 gtk_clist_thaw( GTK_CLIST( CLSelected ) ); | |
153 | |
154 gtk_widget_show( PlayList ); | |
155 } | |
156 | |
157 void HidePlayList( void ) | |
158 { | |
159 if ( !PlayList ) return; | |
160 NrOfSelected=NrOfEntrys=0; | |
33739 | 161 nfree( CLListSelected ); nfree( CLFileSelected ); |
33572 | 162 free( old_path ); |
163 old_path=strdup( current_path ); | |
164 gtk_widget_hide( PlayList ); | |
165 gtk_widget_destroy( PlayList ); | |
166 PlayList=NULL; | |
167 } | |
168 | |
169 static void plRowSelect( GtkCList * clist,gint row,gint column,GdkEvent * event,gpointer user_data ) | |
170 { | |
171 switch ( (int) user_data ) | |
172 { | |
173 case 0: CLFileSelected[row]=1; break; | |
174 case 1: CLListSelected[row]=1; break; | |
175 } | |
176 } | |
177 | |
178 static void plUnRowSelect( GtkCList * clist,gint row,gint column,GdkEvent * event,gpointer user_data ) | |
179 { | |
180 switch ( (int) user_data ) | |
181 { | |
182 case 0: CLFileSelected[row]=0; break; | |
183 case 1: CLListSelected[row]=0; break; | |
184 } | |
185 } | |
186 | |
187 static void plButtonReleased( GtkButton * button,gpointer user_data ) | |
188 { | |
189 switch ( (int) user_data ) | |
190 { | |
191 case 1: // ok | |
192 { | |
193 int i; | |
33742
e1539e14d60f
Move purely list related parts of gtkSet() from interface.c to list.c.
ib
parents:
33740
diff
changeset
|
194 if ( plList ) listSet( gtkDelPl,NULL ); |
33572 | 195 for ( i=0;i<NrOfSelected;i++ ) |
196 { | |
197 plItem * item; | |
198 char * text[3]; | |
199 item=calloc( 1,sizeof( plItem ) ); | |
200 gtk_clist_get_text( GTK_CLIST( CLSelected ),i,0,&text[0] ); | |
201 gtk_clist_get_text( GTK_CLIST( CLSelected ),i,1,&text[1] ); | |
202 item->name=g_filename_from_utf8( text[0], -1, NULL, NULL, NULL ); | |
203 if ( !item->name ) item->name = strdup( text[0] ); | |
204 item->path=g_filename_from_utf8( text[1], -1, NULL, NULL, NULL ); | |
205 if ( !item->path ) item->path = strdup( text[1] ); | |
33742
e1539e14d60f
Move purely list related parts of gtkSet() from interface.c to list.c.
ib
parents:
33740
diff
changeset
|
206 listSet( gtkAddPlItem,item ); |
33572 | 207 } |
208 if ( plCurrent ) | |
209 { | |
210 uiSetFileName( plCurrent->path,plCurrent->name,STREAMTYPE_FILE ); | |
33740
2c02269701bd
Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents:
33739
diff
changeset
|
211 // setddup( &guiInfo.Filename,plCurrent->path,plCurrent->name ); |
33894 | 212 // guiInfo.NewPlay=GUI_FILE_NEW; |
33572 | 213 // guiInfo.StreamType=STREAMTYPE_FILE; |
214 } | |
215 } | |
216 case 0: // cancel | |
217 HidePlayList(); | |
218 break; | |
219 case 2: // remove | |
220 { | |
221 int i; int j; int c=0; | |
222 | |
223 gtk_signal_handler_block( GTK_OBJECT( CLSelected ),sigSel ); | |
224 gtk_signal_handler_block( GTK_OBJECT( CLSelected ),sigUnsel ); | |
225 gtk_signal_handler_block( GTK_OBJECT( CLSelected ),sigEvent ); | |
226 | |
227 gtk_clist_freeze( GTK_CLIST( CLSelected ) ); | |
228 for ( i=0;i<NrOfSelected-c;i++ ) | |
229 if ( CLListSelected[i] ) | |
230 { | |
231 gtk_clist_remove( GTK_CLIST( CLSelected ),i - c ); | |
232 c++; | |
233 for ( j=i;j<NrOfSelected-c;j++ ) | |
234 CLListSelected[i] = CLListSelected[i+1]; | |
235 } | |
236 NrOfSelected-=c; | |
237 gtk_clist_thaw( GTK_CLIST( CLSelected ) ); | |
238 | |
239 gtk_signal_handler_unblock( GTK_OBJECT( CLSelected ),sigSel ); | |
240 gtk_signal_handler_unblock( GTK_OBJECT( CLSelected ),sigUnsel ); | |
241 gtk_signal_handler_unblock( GTK_OBJECT( CLSelected ),sigEvent ); | |
242 | |
243 } | |
244 break; | |
245 case 3: // add | |
246 { | |
247 int i; | |
248 void *p; | |
249 char * itext[1][2]; | |
250 gchar * cpath; | |
251 char * text[1][3]; text[0][2]=""; | |
252 gtk_clist_freeze( GTK_CLIST( CLSelected ) ); | |
253 for ( i=0;i<NrOfEntrys;i++ ) | |
254 { | |
255 if ( CLFileSelected[i] ) | |
256 { | |
257 NrOfSelected++; | |
258 p=realloc( CLListSelected,NrOfSelected * sizeof( int ) ); | |
259 if ( !p ) NrOfSelected--; | |
260 else | |
261 { | |
262 CLListSelected=p; | |
263 CLListSelected[NrOfSelected - 1]=0; | |
264 gtk_clist_get_text( GTK_CLIST( CLFiles ),i,0,(char **)&itext ); | |
265 cpath=g_filename_to_utf8( current_path, -1, NULL, NULL, NULL ); | |
266 text[0][0]=itext[0][0]; text[0][1]=cpath ? cpath : current_path; | |
267 gtk_clist_append( GTK_CLIST( CLSelected ),text[0] ); | |
268 g_free( cpath ); | |
269 } | |
270 } | |
271 } | |
272 gtk_clist_thaw( GTK_CLIST( CLSelected ) ); | |
273 } | |
274 break; | |
275 } | |
276 } | |
277 | |
34348 | 278 static gboolean plKeyReleased( GtkWidget * widget, |
279 GdkEventKey * event, | |
280 gpointer user_data ) | |
281 { | |
34349 | 282 if (event->keyval == GDK_Return) |
283 { | |
284 if ( GTK_WIDGET_TYPE( widget ) == GTK_TYPE_BUTTON ) plButtonReleased( NULL, user_data ); | |
285 else | |
286 { | |
287 switch ( (int) user_data ) | |
288 { | |
289 case 0: | |
290 plButtonReleased( NULL, (void *) 3 ); | |
291 break; | |
292 case 1: | |
293 plButtonReleased( NULL, (void *) 2 ); | |
294 break; | |
295 } | |
296 } | |
297 } | |
34348 | 298 return FALSE; |
299 } | |
300 | |
33572 | 301 static gboolean plEvent ( GtkWidget * widget, |
302 GdkEvent * event, | |
303 gpointer user_data ) | |
304 { | |
305 GdkEventButton *bevent; | |
306 gint row, col; | |
307 | |
308 (void) user_data; | |
309 | |
310 bevent = (GdkEventButton *) event; | |
311 | |
312 if ( event->type == GDK_BUTTON_RELEASE && bevent->button == 2 ) | |
313 { | |
314 if ( gtk_clist_get_selection_info( GTK_CLIST( widget ), bevent->x, bevent->y, &row, &col ) ) | |
315 { | |
316 switch ( (int) user_data ) | |
317 { | |
318 case 0: | |
319 CLFileSelected[row] = 1; | |
320 plButtonReleased( NULL, (void *) 3 ); | |
321 CLFileSelected[row] = 0; | |
322 return TRUE; | |
323 | |
324 case 1: | |
325 CLListSelected[row] = 1; | |
326 plButtonReleased( NULL, (void *) 2 ); | |
327 return TRUE; | |
328 } | |
329 } | |
330 } | |
331 | |
332 return FALSE; | |
333 } | |
334 | |
335 static int check_for_subdir( gchar * path ) | |
336 { | |
337 DIR * dir; | |
338 struct dirent * dirent; | |
339 struct stat statbuf; | |
340 gchar * npath; | |
341 | |
342 if ( (dir=opendir( path )) ) | |
343 { | |
344 while ( (dirent=readdir( dir )) ) | |
345 { | |
346 if ( dirent->d_name[0] != '.' ) | |
347 { | |
348 npath=calloc( 1,strlen( path ) + strlen( dirent->d_name ) + 3 ); | |
349 sprintf( npath,"%s/%s",path,dirent->d_name ); | |
350 if ( stat( npath,&statbuf ) != -1 && S_ISDIR( statbuf.st_mode ) ) | |
351 { free( npath ); closedir( dir ); return 1; } | |
352 free( npath ); | |
353 } | |
354 } | |
355 closedir( dir ); | |
356 } | |
357 return 0; | |
358 } | |
359 | |
360 static void plCTree( GtkCTree * ctree,GtkCTreeNode * parent_node,gpointer user_data ) | |
361 { | |
362 GtkCTreeNode * node; | |
363 DirNodeType * DirNode; | |
364 gchar * text, * name = NULL; | |
365 gchar * dummy = "dummy"; | |
366 int subdir = 1; | |
367 DIR * dir = NULL; | |
368 struct dirent * dirent; | |
369 gchar * path; | |
370 struct stat statbuf; | |
371 | |
372 DirNode=gtk_ctree_node_get_row_data( ctree,parent_node ); | |
373 if ( !DirNode->scaned ) | |
374 { | |
375 DirNode->scaned=1; current_path=DirNode->path; | |
376 gtk_clist_freeze( GTK_CLIST( ctree ) ); | |
377 node=gtk_ctree_find_by_row_data( ctree,parent_node,NULL ); | |
378 gtk_ctree_remove_node( ctree,node ); | |
379 | |
380 if ( (dir=opendir( DirNode->path ) ) ) | |
381 { | |
382 while( (dirent=readdir( dir )) ) | |
383 { | |
384 path=calloc( 1,strlen( DirNode->path ) + strlen( dirent->d_name ) + 2 ); | |
385 if ( !strcmp( current_path,"/" ) ) sprintf( path,"/%s",dirent->d_name ); | |
386 else sprintf( path,"%s/%s",current_path,dirent->d_name ); | |
387 text=dirent->d_name; | |
388 g_free( name ); | |
389 name=g_filename_to_utf8( text, -1, NULL, NULL, NULL ); | |
390 | |
391 if ( stat( path,&statbuf ) != -1 && S_ISDIR( statbuf.st_mode ) && dirent->d_name[0] != '.' ) | |
392 { | |
393 DirNode=malloc( sizeof( DirNodeType ) ); DirNode->scaned=0; DirNode->path=strdup( path ); | |
394 subdir=check_for_subdir( path ); | |
395 node=gtk_ctree_insert_node( ctree,parent_node,NULL,(name ? &name : &text ),4,pxOpenedBook,msOpenedBook,pxClosedBook,msClosedBook,!subdir,FALSE ); | |
396 gtk_ctree_node_set_row_data_full( ctree,node,DirNode,NULL ); | |
397 if ( subdir ) node=gtk_ctree_insert_node( ctree,node,NULL,&dummy,4,NULL,NULL,NULL,NULL,FALSE,FALSE ); | |
398 } | |
399 free( path ); path=NULL; | |
400 } | |
401 closedir( dir ); | |
402 } | |
403 | |
404 gtk_ctree_sort_node( ctree,parent_node ); | |
405 gtk_clist_thaw( GTK_CLIST( ctree ) ); | |
406 } | |
407 | |
408 g_free( name ); | |
409 } | |
410 | |
411 static void scan_dir( char * path ) | |
412 { | |
413 DIR * dir = NULL; | |
414 char * curr; | |
415 struct dirent * dirent; | |
416 struct stat statbuf; | |
417 gchar * name; | |
418 char * text[1][2]; text[0][1]=""; | |
419 | |
420 gtk_clist_clear( GTK_CLIST( CLFiles ) ); | |
421 if ( (dir=opendir( path )) ) | |
422 { | |
423 NrOfEntrys=0; | |
424 while( (dirent=readdir( dir )) ) | |
425 { | |
426 curr=calloc( 1,strlen( path ) + strlen( dirent->d_name ) + 3 ); sprintf( curr,"%s/%s",path,dirent->d_name ); | |
427 if ( stat( curr,&statbuf ) != -1 && ( S_ISREG( statbuf.st_mode ) || S_ISLNK( statbuf.st_mode ) ) ) | |
428 { | |
429 name=g_filename_to_utf8( dirent->d_name, -1, NULL, NULL, NULL ); | |
430 text[0][0]=name ? name : dirent->d_name; | |
431 gtk_clist_append( GTK_CLIST( CLFiles ), text[0] ); | |
432 g_free( name ); | |
433 NrOfEntrys++; | |
434 } | |
435 free( curr ); | |
436 } | |
437 closedir( dir ); | |
438 gtk_clist_sort( GTK_CLIST( CLFiles ) ); | |
439 } | |
440 } | |
441 | |
442 static void plCTRow(GtkWidget * widget, gint row, gint column, GdkEventButton * bevent, gpointer data) | |
443 { | |
444 DirNodeType * DirNode; | |
445 GtkCTreeNode * node; | |
446 node=gtk_ctree_node_nth( GTK_CTREE( widget ),row ); | |
447 DirNode=gtk_ctree_node_get_row_data( GTK_CTREE( widget ),node ); | |
448 current_path=DirNode->path; | |
449 gtk_ctree_expand( GTK_CTREE( widget ),node ); | |
450 scan_dir( DirNode->path ); | |
451 free( CLFileSelected ); | |
452 CLFileSelected=calloc( 1,NrOfEntrys * sizeof( int ) ); | |
453 } | |
454 | |
455 GtkWidget * create_PlayList( void ) | |
456 { | |
457 GtkWidget * vbox1; | |
458 GtkWidget * hbox1; | |
459 GtkWidget * scrolledwindow1; | |
460 GtkWidget * vbox2; | |
461 GtkWidget * scrolledwindow2; | |
462 GtkWidget * scrolledwindow3; | |
463 GtkWidget * hbuttonbox1; | |
464 GtkAccelGroup * accel_group; | |
465 GdkColor transparent = { 0,0,0,0 }; | |
466 gchar * root = "/"; | |
467 gchar * dummy = "dummy"; | |
468 DirNodeType * DirNode; | |
469 | |
470 accel_group=gtk_accel_group_new(); | |
471 | |
472 PlayList=gtk_window_new( GTK_WINDOW_TOPLEVEL ); | |
473 gtk_object_set_data( GTK_OBJECT( PlayList ),"PlayList",PlayList ); | |
474 gtk_widget_set_usize( PlayList,512,384 ); | |
475 gtk_window_set_title( GTK_WINDOW( PlayList ),MSGTR_PlayList ); | |
476 gtk_window_set_position( GTK_WINDOW( PlayList ),GTK_WIN_POS_CENTER ); | |
477 // gtk_window_set_policy( GTK_WINDOW( PlayList ),FALSE,FALSE,FALSE ); | |
478 gtk_window_set_wmclass( GTK_WINDOW( PlayList ),"Playlist","MPlayer" ); | |
479 | |
480 gtk_widget_realize( PlayList ); | |
481 gtkAddIcon( PlayList ); | |
482 | |
483 vbox1=AddVBox( AddDialogFrame( PlayList ),0 ); | |
484 hbox1=AddHBox( NULL,1 ); | |
485 gtk_box_pack_start( GTK_BOX( vbox1 ),hbox1,TRUE,TRUE,0 ); | |
486 | |
487 scrolledwindow1=gtk_scrolled_window_new( NULL,NULL ); | |
488 gtk_widget_show( scrolledwindow1 ); | |
489 gtk_container_add( GTK_CONTAINER( | |
490 AddFrame( NULL,0,hbox1,1 ) ),scrolledwindow1 ); | |
491 gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scrolledwindow1 ),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC ); | |
492 | |
493 CTDirTree=gtk_ctree_new( 1,0 ); | |
494 gtk_signal_connect( GTK_OBJECT( CTDirTree ),"tree_expand",GTK_SIGNAL_FUNC( plCTree ),(void*)0 ); | |
495 gtk_signal_connect( GTK_OBJECT( CTDirTree ),"select_row",GTK_SIGNAL_FUNC( plCTRow ),(void *)0 ); | |
496 gtk_container_add( GTK_CONTAINER( scrolledwindow1 ),CTDirTree ); | |
497 gtk_clist_set_column_auto_resize( GTK_CLIST( CTDirTree ),0,TRUE ); | |
498 gtk_clist_set_column_width( GTK_CLIST( CTDirTree ),0,80 ); | |
499 gtk_clist_set_selection_mode( GTK_CLIST( CTDirTree ),GTK_SELECTION_SINGLE ); | |
500 gtk_ctree_set_line_style( GTK_CTREE( CTDirTree ),GTK_CTREE_LINES_SOLID ); | |
501 gtk_clist_column_titles_show( GTK_CLIST( CTDirTree ) ); | |
502 gtk_clist_set_shadow_type( GTK_CLIST( CTDirTree ),GTK_SHADOW_NONE ); | |
503 | |
33575 | 504 if ( !pxOpenedBook ) pxOpenedBook=gdk_pixmap_create_from_xpm_d( PlayList->window,&msOpenedBook,&transparent,(gchar **)dir2_xpm ); |
505 if ( !pxClosedBook ) pxClosedBook=gdk_pixmap_create_from_xpm_d( PlayList->window,&msClosedBook,&transparent,(gchar **)open2_xpm ); | |
33572 | 506 |
507 parent=gtk_ctree_insert_node( GTK_CTREE( CTDirTree ),NULL,NULL,&root,4,pxOpenedBook,msOpenedBook,pxClosedBook,msClosedBook,FALSE,FALSE ); | |
508 DirNode=malloc( sizeof( DirNodeType ) ); | |
509 DirNode->scaned=0; DirNode->path=strdup( root ); | |
510 gtk_ctree_node_set_row_data_full(GTK_CTREE( CTDirTree ),parent,DirNode,NULL ); | |
511 sibling=gtk_ctree_insert_node( GTK_CTREE( CTDirTree ),parent,NULL,&dummy,4,NULL,NULL,NULL,NULL,TRUE,TRUE ); | |
512 gtk_ctree_expand( GTK_CTREE( CTDirTree ),parent ); | |
513 gtk_widget_show( CTDirTree ); | |
514 | |
33873 | 515 if ( fsHistory[0] ) old_path = g_filename_from_utf8( fsHistory[0], -1, NULL, NULL, NULL ); |
33572 | 516 |
517 gtk_clist_set_column_widget( GTK_CLIST( CTDirTree ),0, | |
518 AddLabel( MSGTR_PLAYLIST_DirectoryTree,NULL ) ); | |
519 | |
34347 | 520 gtk_clist_column_title_passive( GTK_CLIST( CTDirTree ),0 ); |
521 | |
33572 | 522 vbox2=AddVBox( |
523 AddFrame( NULL,1,hbox1,1 ),0 ); | |
524 | |
525 scrolledwindow2=gtk_scrolled_window_new( NULL,NULL ); | |
526 gtk_widget_show( scrolledwindow2 ); | |
527 gtk_box_pack_start( GTK_BOX( vbox2 ),scrolledwindow2,TRUE,TRUE,0 ); | |
528 gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scrolledwindow2 ),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC ); | |
529 | |
530 CLFiles=gtk_clist_new( 1 ); | |
531 gtk_widget_show( CLFiles ); | |
532 gtk_container_add( GTK_CONTAINER( scrolledwindow2 ),CLFiles ); | |
533 gtk_clist_set_column_width( GTK_CLIST( CLFiles ),0,80 ); | |
534 gtk_clist_set_selection_mode( GTK_CLIST( CLFiles ),GTK_SELECTION_EXTENDED ); | |
535 gtk_clist_column_titles_show( GTK_CLIST( CLFiles ) ); | |
536 gtk_clist_set_shadow_type( GTK_CLIST( CLFiles ),GTK_SHADOW_NONE ); | |
537 | |
538 gtk_clist_set_column_widget( GTK_CLIST( CLFiles ),0, | |
539 AddLabel( MSGTR_PLAYLIST_Files,NULL ) ); | |
540 | |
34347 | 541 gtk_clist_column_title_passive( GTK_CLIST( CLFiles ),0 ); |
542 | |
33572 | 543 AddHSeparator( vbox2 ); |
544 | |
545 scrolledwindow3=gtk_scrolled_window_new( NULL,NULL ); | |
546 gtk_widget_show( scrolledwindow3 ); | |
547 gtk_box_pack_start( GTK_BOX( vbox2 ),scrolledwindow3,TRUE,TRUE,0 ); | |
548 gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scrolledwindow3 ),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC ); | |
549 | |
550 CLSelected=gtk_clist_new( 2 ); | |
551 gtk_widget_show( CLSelected ); | |
552 gtk_container_add( GTK_CONTAINER( scrolledwindow3 ),CLSelected ); | |
553 gtk_clist_set_column_width( GTK_CLIST( CLSelected ),0,295 ); | |
554 gtk_clist_set_column_width( GTK_CLIST( CLSelected ),1,295 ); | |
555 gtk_clist_set_selection_mode( GTK_CLIST( CLSelected ),GTK_SELECTION_MULTIPLE ); | |
556 gtk_clist_column_titles_show( GTK_CLIST( CLSelected ) ); | |
557 gtk_clist_set_shadow_type( GTK_CLIST( CLSelected ),GTK_SHADOW_NONE ); | |
558 | |
559 gtk_clist_set_column_widget( GTK_CLIST( CLSelected ),0, | |
560 AddLabel( MSGTR_PLAYLIST_Selected,NULL ) ); | |
561 | |
562 gtk_clist_set_column_widget( GTK_CLIST( CLSelected ),1, | |
563 AddLabel( MSGTR_PLAYLIST_Path,NULL ) ); | |
564 | |
34347 | 565 gtk_clist_column_title_passive( GTK_CLIST( CLSelected ),0 ); |
566 | |
33572 | 567 AddHSeparator( vbox1 ); |
568 | |
569 hbuttonbox1=AddHButtonBox( vbox1 ); | |
570 gtk_button_box_set_layout( GTK_BUTTON_BOX( hbuttonbox1 ),GTK_BUTTONBOX_END ); | |
571 gtk_button_box_set_spacing( GTK_BUTTON_BOX( hbuttonbox1 ),10 ); | |
572 | |
573 Add=AddButton( MSGTR_Add,hbuttonbox1 ); | |
574 Remove=AddButton( MSGTR_Remove,hbuttonbox1 ); | |
575 Ok=AddButton( MSGTR_Ok,hbuttonbox1 ); | |
576 Cancel=AddButton( MSGTR_Cancel,hbuttonbox1 ); | |
577 | |
578 gtk_widget_add_accelerator( Cancel,"clicked",accel_group,GDK_Escape,0,GTK_ACCEL_VISIBLE ); | |
579 | |
580 gtk_signal_connect( GTK_OBJECT( PlayList ),"destroy",GTK_SIGNAL_FUNC( WidgetDestroy ),&PlayList ); | |
581 | |
582 gtk_signal_connect( GTK_OBJECT( CLFiles ),"select_row",GTK_SIGNAL_FUNC( plRowSelect ),(void *)0 ); | |
583 gtk_signal_connect( GTK_OBJECT( CLFiles ),"unselect_row",GTK_SIGNAL_FUNC( plUnRowSelect ),(void *)0 ); | |
584 gtk_signal_connect( GTK_OBJECT( CLFiles ),"event",GTK_SIGNAL_FUNC( plEvent ),(void *)0 ); | |
34349 | 585 gtk_signal_connect( GTK_OBJECT( CLFiles ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void *)0 ); |
33572 | 586 sigSel=gtk_signal_connect( GTK_OBJECT( CLSelected ),"select_row",GTK_SIGNAL_FUNC( plRowSelect ),(void*)1 ); |
587 sigUnsel=gtk_signal_connect( GTK_OBJECT( CLSelected ),"unselect_row",GTK_SIGNAL_FUNC( plUnRowSelect ),(void*)1 ); | |
588 sigEvent=gtk_signal_connect( GTK_OBJECT( CLSelected ),"event",GTK_SIGNAL_FUNC( plEvent ),(void *)1 ); | |
34349 | 589 gtk_signal_connect( GTK_OBJECT( CLSelected ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void *)1 ); |
33572 | 590 |
34348 | 591 gtk_signal_connect( GTK_OBJECT( Add ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)3 ); |
592 gtk_signal_connect( GTK_OBJECT( Add ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)3 ); | |
593 gtk_signal_connect( GTK_OBJECT( Remove ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)2 ); | |
594 gtk_signal_connect( GTK_OBJECT( Remove ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)2 ); | |
595 gtk_signal_connect( GTK_OBJECT( Ok ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)1 ); | |
596 gtk_signal_connect( GTK_OBJECT( Ok ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)1 ); | |
597 gtk_signal_connect( GTK_OBJECT( Cancel ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)0 ); | |
598 gtk_signal_connect( GTK_OBJECT( Cancel ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)0 ); | |
33572 | 599 |
600 gtk_window_add_accel_group( GTK_WINDOW( PlayList ),accel_group ); | |
601 | |
602 return PlayList; | |
603 } |