diff options
author | Hans-Christoph Steiner <eighthave@users.sourceforge.net> | 2008-04-28 04:14:00 +0000 |
---|---|---|
committer | Hans-Christoph Steiner <eighthave@users.sourceforge.net> | 2008-04-28 04:14:00 +0000 |
commit | 4a340f8bbd7d8065a0bf0c5e2dc4dfd185321d45 (patch) | |
tree | 50fb317771f05ca21108451fff7b41f27a022cae | |
parent | f10e1f9aaa00d02d494b8b47b8f10301bfcc66a1 (diff) |
wrote a function to switch the [pd filename] callback message to use a
A_GIMME instead of two symbols, thereby correctly receiving any directory
names with spaces in it.
svn path=/trunk/; revision=9729
-rw-r--r-- | packages/patches/allow_spaces_in_new_directory-0.41.4.patch | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/packages/patches/allow_spaces_in_new_directory-0.41.4.patch b/packages/patches/allow_spaces_in_new_directory-0.41.4.patch new file mode 100644 index 00000000..4db2a537 --- /dev/null +++ b/packages/patches/allow_spaces_in_new_directory-0.41.4.patch @@ -0,0 +1,47 @@ +Index: m_glob.c +=================================================================== +--- m_glob.c (revision 9721) ++++ m_glob.c (working copy) +@@ -11,7 +11,7 @@ + /* These "glob" routines, which implement messages to Pd, are from all + over. Some others are prototyped in m_imp.h as well. */ + +-void glob_setfilename(void *dummy, t_symbol *name, t_symbol *dir); ++void glob_setfilename_gimme(void *dummy, t_symbol *s, int argc, t_atom *argv); + void glob_verifyquit(void *dummy, t_floatarg f); + void glob_dsp(void *dummy, t_symbol *s, int argc, t_atom *argv); + void glob_meters(void *dummy, t_floatarg f); +@@ -74,8 +74,8 @@ + CLASS_DEFAULT, A_NULL); + class_addmethod(glob_pdobject, (t_method)glob_initfromgui, gensym("init"), + A_GIMME, 0); +- class_addmethod(glob_pdobject, (t_method)glob_setfilename, gensym("filename"), +- A_SYMBOL, A_SYMBOL, 0); ++ class_addmethod(glob_pdobject, (t_method)glob_setfilename_gimme, ++ gensym("filename"), A_GIMME, 0); + class_addmethod(glob_pdobject, (t_method)glob_evalfile, gensym("open"), + A_SYMBOL, A_SYMBOL, 0); + class_addmethod(glob_pdobject, (t_method)glob_quit, gensym("quit"), 0); +Index: g_canvas.c +=================================================================== +--- g_canvas.c (revision 9726) ++++ g_canvas.c (working copy) +@@ -138,6 +138,18 @@ + canvas_newdirectory = dirsym; + } + ++void glob_setfilename_gimme(void *dummy, t_symbol *s, int argc, t_atom *argv) ++{ ++ int bufsize; ++ char *buf; ++ t_binbuf *b = binbuf_new(); ++ canvas_newfilename = atom_getsymbolarg(0, argc, argv); ++ binbuf_add(b, argc - 1, argv + 1); ++ binbuf_gettext(b, &buf, &bufsize); ++ buf[bufsize] = 0; ++ canvas_newdirectory = gensym(buf); ++} ++ + t_canvas *canvas_getcurrent(void) + { + return ((t_canvas *)pd_findbyclass(&s__X, canvas_class)); |