aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHans-Christoph Steiner <eighthave@users.sourceforge.net>2009-02-11 06:48:39 +0000
committerHans-Christoph Steiner <eighthave@users.sourceforge.net>2009-02-11 06:48:39 +0000
commit5dc4e53b8ff95791503a4c6dc16c41aa41cae453 (patch)
tree7a4000185586409dd57272fc35649f37bc5a4a5d
parent86df838b5cd57f28cb03e3ad2e924fe4232363d0 (diff)
checked in patch to pd-extended 0.41.4 and submitted it to the patch tracker for Miller
svn path=/trunk/; revision=10758
-rw-r--r--packages/patches/fix_max.pat_exporting-0.41.4.patch117
1 files changed, 117 insertions, 0 deletions
diff --git a/packages/patches/fix_max.pat_exporting-0.41.4.patch b/packages/patches/fix_max.pat_exporting-0.41.4.patch
new file mode 100644
index 00000000..16b8c0b2
--- /dev/null
+++ b/packages/patches/fix_max.pat_exporting-0.41.4.patch
@@ -0,0 +1,117 @@
+--- branches/pd-extended/0.41/pd/src/m_binbuf.c 2009/02/11 01:28:08 10756
++++ branches/pd-extended/0.41/pd/src/m_binbuf.c 2009/02/11 06:44:40 10757
+@@ -952,8 +952,9 @@
+ t_binbuf *newb = binbuf_new();
+ t_atom *vec = oldb->b_vec;
+ t_int n = oldb->b_n, nextindex, stackdepth = 0, stack[MAXSTACK],
+- nobj = 0, i;
++ nobj = 0, i, gotfontsize = 0;
+ t_atom outmess[MAXSTACK], *nextmess;
++ t_float fontsize = 10;
+ if (!maxtopd)
+ binbuf_addv(newb, "ss;", gensym("max"), gensym("v2"));
+ for (nextindex = 0; nextindex < n; )
+@@ -1179,12 +1180,17 @@
+ stack[stackdepth] = nobj;
+ stackdepth++;
+ nobj = 0;
++ if(!gotfontsize) { /* only the first canvas sets the font size */
++ fontsize = atom_getfloatarg(6, natom, nextmess);
++ gotfontsize = 1;
++ }
++ t_float x = atom_getfloatarg(2, natom, nextmess);
++ t_float y = atom_getfloatarg(3, natom, nextmess);
+ binbuf_addv(newb, "ssffff;",
+ gensym("#N"), gensym("vpatcher"),
+- atom_getfloatarg(2, natom, nextmess),
+- atom_getfloatarg(3, natom, nextmess),
+- atom_getfloatarg(4, natom, nextmess),
+- atom_getfloatarg(5, natom, nextmess));
++ x, y,
++ atom_getfloatarg(4, natom, nextmess) + x,
++ atom_getfloatarg(5, natom, nextmess) + y);
+ }
+ }
+ if (!strcmp(first, "#X"))
+@@ -1193,12 +1199,17 @@
+ && (ISSYMBOL (&nextmess[4], "pd")))
+ {
+ binbuf_addv(newb, "ss;", gensym("#P"), gensym("pop"));
+- binbuf_addv(newb, "ssffffss;",
+- gensym("#P"), gensym("newobj"),
+- atom_getfloatarg(2, natom, nextmess),
+- atom_getfloatarg(3, natom, nextmess), 50., 1.,
+- gensym("patcher"),
+- atom_getsymbolarg(5, natom, nextmess));
++ SETSYMBOL(outmess, gensym("#P"));
++ SETSYMBOL(outmess + 1, gensym("newobj"));
++ outmess[2] = nextmess[2];
++ outmess[3] = nextmess[3];
++ SETFLOAT(outmess + 4, 40.*(natom-5));
++ SETFLOAT(outmess + 5, fontsize);
++ SETSYMBOL(outmess + 6, gensym("p"));
++ for (i = 5; i < natom; i++)
++ outmess[i+2] = nextmess[i];
++ SETSEMI(outmess + natom + 2);
++ binbuf_add(newb, natom + 3, outmess);
+ if (stackdepth) stackdepth--;
+ nobj = stack[stackdepth];
+ nobj++;
+@@ -1212,25 +1223,25 @@
+ gensym("inlet"),
+ atom_getfloatarg(2, natom, nextmess),
+ atom_getfloatarg(3, natom, nextmess),
+- 15.);
++ 10. + fontsize);
+ else if (classname == gensym("inlet~"))
+ binbuf_addv(newb, "ssffff;", gensym("#P"),
+ gensym("inlet"),
+ atom_getfloatarg(2, natom, nextmess),
+ atom_getfloatarg(3, natom, nextmess),
+- 15., 1.);
++ 10. + fontsize, 1.);
+ else if (classname == gensym("outlet"))
+ binbuf_addv(newb, "ssfff;", gensym("#P"),
+ gensym("outlet"),
+ atom_getfloatarg(2, natom, nextmess),
+ atom_getfloatarg(3, natom, nextmess),
+- 15.);
++ 10. + fontsize);
+ else if (classname == gensym("outlet~"))
+ binbuf_addv(newb, "ssffff;", gensym("#P"),
+ gensym("outlet"),
+ atom_getfloatarg(2, natom, nextmess),
+ atom_getfloatarg(3, natom, nextmess),
+- 15., 1.);
++ 10. + fontsize, 1.);
+ else if (classname == gensym("bng"))
+ binbuf_addv(newb, "ssffff;", gensym("#P"),
+ gensym("button"),
+@@ -1261,10 +1272,14 @@
+ SETSYMBOL(outmess + 1, gensym("newex"));
+ outmess[2] = nextmess[2];
+ outmess[3] = nextmess[3];
+- SETFLOAT(outmess + 4, 50);
+- SETFLOAT(outmess + 5, 1);
++ SETFLOAT(outmess + 4, 40.*(natom-4));
++ SETFLOAT(outmess + 5, fontsize);
+ for (i = 4; i < natom; i++)
+ outmess[i+2] = nextmess[i];
++ if (classname == gensym("hsl"))
++ SETSYMBOL(outmess + 6, gensym("hslider"));
++ if (classname == gensym("osc~"))
++ SETSYMBOL(outmess + 6, gensym("cycle~"));
+ SETSEMI(outmess + natom + 2);
+ binbuf_add(newb, natom + 3, outmess);
+ }
+@@ -1279,8 +1294,8 @@
+ (strcmp(second, "msg") ? "comment" : "message")));
+ outmess[2] = nextmess[2];
+ outmess[3] = nextmess[3];
+- SETFLOAT(outmess + 4, 50);
+- SETFLOAT(outmess + 5, 1);
++ SETFLOAT(outmess + 4, 40.*(natom-4));
++ SETFLOAT(outmess + 5, fontsize);
+ for (i = 4; i < natom; i++)
+ outmess[i+2] = nextmess[i];
+ SETSEMI(outmess + natom + 2);