aboutsummaryrefslogtreecommitdiff
path: root/externals/grill/flext/source
diff options
context:
space:
mode:
Diffstat (limited to 'externals/grill/flext/source')
-rw-r--r--externals/grill/flext/source/flattr.cpp8
-rw-r--r--externals/grill/flext/source/flattr_ed.cpp178
-rw-r--r--externals/grill/flext/source/flext.cpp5
3 files changed, 104 insertions, 87 deletions
diff --git a/externals/grill/flext/source/flattr.cpp b/externals/grill/flext/source/flattr.cpp
index 30b8fea1..b40a5807 100644
--- a/externals/grill/flext/source/flattr.cpp
+++ b/externals/grill/flext/source/flattr.cpp
@@ -48,6 +48,8 @@ void flext_base::AddAttrib(ItemCont *aa,ItemCont *ma,const char *attr,metharg tp
const t_symbol *asym = MakeSymbol(attr);
AttrItem *a,*b;
+ FLEXT_ASSERT(asym != sym__ && asym != sym_list && asym != sym_float && asym != sym_symbol && asym != sym_anything);
+
if(sfun) // if commented out, there will be a warning at run-time (more user-friendly)
{
a = new AttrItem(asym,tp,sfun,AttrItem::afl_set);
@@ -238,9 +240,9 @@ bool flext_base::SetAttrib(const t_symbol *tag,AttrItem *a,int argc,const t_atom
break;
case a_symbol:
if(argc == 1 && IsSymbol(argv[0])) {
- // \todo shall we analyze the patcher args????
-// any.st = const_cast<t_symbol *>(GetParamSym(GetSymbol(argv[0]),thisCanvas()));
- any.st = GetSymbol(argv[0]);
+ t_atom at;
+ GetParamSym(at,GetSymbol(argv[0]),thisCanvas());
+ any.st = const_cast<t_symbol *>(GetSymbol(at));
((methfun_1)a->fun)(this,any);
}
else ok = false;
diff --git a/externals/grill/flext/source/flattr_ed.cpp b/externals/grill/flext/source/flattr_ed.cpp
index 8a4b98f5..ff922897 100644
--- a/externals/grill/flext/source/flattr_ed.cpp
+++ b/externals/grill/flext/source/flattr_ed.cpp
@@ -78,72 +78,75 @@ void flext_base::SetAttrEditor(t_classid c)
// generate the script for the property dialog
sys_gui(
- "proc flext_apply {id alen} {\n"
+ "proc flext_escatoms {lst} {\n"
+ "set tmp {}\n"
+ "foreach a $lst {\n"
+ "set a [regsub {\\$} $a \\\\$]\n" // replace $ with \$
+ "set a [regsub {,} $a \\\\,]\n" // replace , with \,
+ "set a [regsub {;} $a \\\\\\;]\n" // replace ; with \;
+ "lappend tmp $a\n"
+ "}\n"
+ "return $tmp\n"
+ "}\n"
+
+ "proc flext_makevalue {id ix} {\n"
// strip "." from the TK id to make a variable name suffix
"set vid [string trimleft $id .]\n"
- // make a list of the attribute values (including save flags)
+ "set var_attr_name [concat [concat var_name_$ix]_$vid ]\n"
+ "set var_attr_init [concat [concat var_init_$ix]_$vid ]\n"
+ "set var_attr_val [concat [concat var_val_$ix]_$vid ]\n"
+ "set var_attr_save [concat [concat var_save_$ix]_$vid ]\n"
+ "set var_attr_type [concat [concat var_type_$ix]_$vid ]\n"
+
+ "global $var_attr_name $var_attr_init $var_attr_val $var_attr_save $var_attr_type\n"
"set lst {}\n"
- "for {set ix 1} {$ix <= $alen} {incr ix} {\n"
- "set var_attr_name [concat [concat var_name_$ix]_$vid ]\n"
- "set var_attr_init [concat [concat var_init_$ix]_$vid ]\n"
- "set var_attr_val [concat [concat var_val_$ix]_$vid ]\n"
- "set var_attr_save [concat [concat var_save_$ix]_$vid ]\n"
- "set var_attr_type [concat [concat var_type_$ix]_$vid ]\n"
-
- "global $var_attr_name $var_attr_init $var_attr_val $var_attr_save $var_attr_type\n"
-
- "if { [expr $$var_attr_type] != 0 } {\n"
- // attribute is puttable
-
- "lappend lst [eval concat $$var_attr_name]\n"
-
- // process current value
- "set tmp [eval concat $$var_attr_val]\n"
- "set len [llength $tmp]\n"
- "if { $len == 1 } {\n"
- // it's an atom
- // if atom starts with $, replace it by # ($ can't be passed by TCL)
- "if { [string index $tmp 0] == \"$\" } {\n"
- "set tmp [string replace $tmp 0 0 #]\n"
- "}\n"
- "lappend lst $tmp\n"
- "} else {\n"
- // it's a list
- "set lst [concat $lst {list} $len $tmp]\n"
- "}\n"
- // process init value
- "set tmp [eval concat $$var_attr_init]\n"
- "set len [llength $tmp]\n"
- "if { $len == 1 } {\n"
- // it's an atom
- // if atom starts with $, replace it by # ($ can't be passed by TCL)
- "if { [string index $tmp 0] == \"$\" } {\n"
- "set tmp [string replace $tmp 0 0 #]\n"
- "}\n"
- "lappend lst $tmp\n"
- "} else {\n"
- // it's a list
- "set lst [concat $lst {list} $len $tmp]\n"
- "}\n"
+ "if { [expr $$var_attr_type] != 0 } {\n"
+ // attribute is puttable
- "lappend lst [eval concat $$var_attr_save]\n"
- "}\n"
+ "lappend lst [eval concat $$var_attr_name]\n"
+
+ // process current value
+ "set tmp [flext_escatoms [eval concat $$var_attr_val]]\n"
+ "set lst [concat $lst [llength $tmp] $tmp]\n"
+
+ // process init value
+ "set tmp [flext_escatoms [eval concat $$var_attr_init]]\n"
+ "set lst [concat $lst [llength $tmp] $tmp]\n"
+
+ "lappend lst [eval concat $$var_attr_save]\n"
"}\n"
- "set cmd [concat $id attributedialog $lst \\;]\n"
- "pd $cmd\n"
+ // return list
+ "return $lst\n"
+ "}\n"
+
+ "proc flext_apply {id ix} {\n"
+ "set lst [flext_makevalue $id $ix]\n"
+ "set lst [eval concat $lst]\n" // remove curly braces from character escaping
+ "pd [concat $id attributedialog $lst \\;]\n"
+ "}\n"
+
+ "proc flext_applyall {id alen} {\n"
+ // make a list of the attribute values (including save flags)
+
+ "set lst {}\n"
+ "for {set ix 1} {$ix <= $alen} {incr ix} {\n"
+ "set lst [concat $lst [flext_makevalue $id $ix]]\n"
+ "}\n"
+ "set lst [eval concat $lst]\n" // remove curly braces from character escaping
+
+ "pd [concat $id attributedialog $lst \\;]\n"
"}\n"
"proc flext_cancel {id} {\n"
- "set cmd [concat $id cancel \\;]\n"
- "pd $cmd\n"
+ "pd [concat $id cancel \\;]\n"
"}\n"
"proc flext_ok {id alen} {\n"
- "flext_apply $id $alen\n"
+ "flext_applyall $id $alen\n"
"flext_cancel $id\n"
"}\n"
@@ -181,7 +184,11 @@ void flext_base::SetAttrEditor(t_classid c)
"proc flext_textcopy {id idtxt var} {\n"
"global $var\n"
- "set $var [eval $idtxt get 0.0 end]\n"
+ "set txt [eval $idtxt get 0.0 end]\n"
+ // strip newline characters
+ "set tmp {}\n"
+ "foreach t $txt { lappend tmp [string trim $t] }\n"
+ "set $var $tmp\n"
"destroy $id\n"
"}\n"
@@ -200,7 +207,15 @@ void flext_base::SetAttrEditor(t_classid c)
"pack $id.w.scroll -side right -fill y\n"
"pack $id.w.text -expand yes -fill both\n"
- "$id.w.text insert 0.0 [expr $$var]\n"
+ // insert text with newlines
+ "set txt [split [expr $$var] ,]\n"
+ "set lines [llength $txt]\n"
+ "for {set ix 0} {$ix < ($lines-1)} {incr ix} {\n"
+ "$id.w.text insert end [string trim [lindex $txt $ix] ]\n"
+ "$id.w.text insert end \" ,\\n\"\n"
+ "}\n"
+ "$id.w.text insert end [string trim [lindex $txt end] ]\n"
+
"$id.w.text mark set insert 0.0\n"
"if { $edit != 0 } then {\n"
@@ -229,7 +244,8 @@ void flext_base::SetAttrEditor(t_classid c)
"grid columnconfigure $id 0 -weight 1\n" // label
"grid columnconfigure $id {1 4} -weight 3\n" // value entry
"grid columnconfigure $id {2 3} -weight 0\n" // copy buttons
- "grid columnconfigure $id {5 6 7} -weight 0\n" // radio buttons
+ "grid columnconfigure $id 5 -weight 1\n" // apply button
+ "grid columnconfigure $id {6 7 8} -weight 0\n" // radio buttons
// "grid rowconfigure $id {0 1 2} -weight 0\n"
@@ -238,6 +254,7 @@ void flext_base::SetAttrEditor(t_classid c)
"label $id.init -text {initial value} -height 2 -font {Helvetica 9 bold}\n"
"label $id.copy -text {copy} -height 2 -font {Helvetica 9 bold}\n"
"label $id.val -text {current value} -height 2 -font {Helvetica 9 bold}\n"
+ "label $id.apply -text {} -height 2 -font {Helvetica 9 bold}\n" // why must this be empty?
"foreach {i txt} {0 {don't\rsave} 1 {do\rinit} 2 {always\rsave} } {\n"
"label $id.b$i -text $txt -height 2 -font {Helvetica 9 bold}\n"
"}\n"
@@ -247,13 +264,14 @@ void flext_base::SetAttrEditor(t_classid c)
"grid config $id.init -column 1 -row $row \n"
"grid config $id.copy -column 2 -columnspan 2 -row $row \n"
"grid config $id.val -column 4 -row $row \n"
- "foreach i {0 1 2} { grid config $id.b$i -column [expr $i + 5] -row $row }\n"
+ "grid config $id.apply -column 5 -row $row \n"
+ "foreach i {0 1 2} { grid config $id.b$i -column [expr $i + 6] -row $row }\n"
// "grid config $id.options -column 3 -row 0 \n"
"incr row\n"
// Separator
"frame $id.sep -relief ridge -bd 1 -height 2\n"
- "grid config $id.sep -column 0 -columnspan 8 -row $row -pady 2 -sticky {snew}\n"
+ "grid config $id.sep -column 0 -columnspan 9 -row $row -pady 2 -sticky {snew}\n"
"incr row\n"
"set ix 1\n"
@@ -322,18 +340,23 @@ void flext_base::SetAttrEditor(t_classid c)
"grid config $id.init-$ix -column 1 -row $row -padx 5 -sticky {ew}\n"
"grid config $id.val-$ix -column 4 -row $row -padx 5 -sticky {ew}\n"
+ // copy buttons
"button $id.b2i-$ix -text {<-} -height 1 -command \" flext_copyval $var_attr_init $var_attr_val \"\n"
"grid config $id.b2i-$ix -column 2 -row $row -sticky {ew}\n"
"button $id.b2c-$ix -text {->} -height 1 -command \" flext_copyval $var_attr_val $var_attr_init \"\n"
"grid config $id.b2c-$ix -column 3 -row $row -sticky {ew}\n"
+ // apply button
+ "button $id.apply-$ix -text {Apply} -height 1 -command \" flext_apply $id $ix \"\n"
+ "grid config $id.apply-$ix -column 5 -row $row -sticky {ew}\n"
+
// "tk_optionMenu $id.opt-$ix $var_attr_save {don't save} {initialize} {always save}\n"
// "grid config $id.opt-$ix -column 5 -row $ix \n"
// radiobuttons
"foreach {i c} {0 black 1 blue 2 red} {\n"
"radiobutton $id.b$i-$ix -value $i -foreground $c -variable $var_attr_save \n"
- "grid config $id.b$i-$ix -column [expr $i + 5] -row $row \n"
+ "grid config $id.b$i-$ix -column [expr $i + 6] -row $row \n"
"}\n"
"} else {\n"
// attribute is gettable only
@@ -361,7 +384,7 @@ void flext_base::SetAttrEditor(t_classid c)
"grid config $id.val-$ix -column 4 -row $row -padx 5 -sticky {ew}\n"
"label $id.readonly-$ix -text \"read-only\"\n"
- "grid config $id.readonly-$ix -column 5 -columnspan 3 -row $row -padx 5 -sticky {ew}\n"
+ "grid config $id.readonly-$ix -column 6 -columnspan 3 -row $row -padx 5 -sticky {ew}\n"
"}\n"
// increase counter
@@ -372,16 +395,16 @@ void flext_base::SetAttrEditor(t_classid c)
// Separator
"frame $id.sep2 -relief ridge -bd 1 -height 2\n"
// "grid rowconfigure $id $row -weight 0\n"
- "grid config $id.sep2 -column 0 -columnspan 8 -row $row -pady 5 -sticky {snew}\n"
+ "grid config $id.sep2 -column 0 -columnspan 9 -row $row -pady 5 -sticky {snew}\n"
"incr row\n"
// Buttons
"frame $id.buttonframe\n"
"pack $id.buttonframe -side bottom -fill x\n"
- "button $id.buttonframe.cancel -text {Cancel} -width 20 -command \" flext_cancel $id \"\n"
- "button $id.buttonframe.apply -text {Apply} -width 20 -command \" flext_apply $id $alen \"\n"
- "button $id.buttonframe.ok -text {OK} -width 20 -command \" flext_ok $id $alen \"\n"
+ "button $id.buttonframe.cancel -text {Leave} -width 20 -command \" flext_cancel $id \"\n"
+ "button $id.buttonframe.apply -text {Apply all} -width 20 -command \" flext_applyall $id $alen \"\n"
+ "button $id.buttonframe.ok -text {Apply & Leave} -width 20 -command \" flext_ok $id $alen \"\n"
"button $id.buttonframe.help -text {Help} -width 10 -command \" flext_help $id \"\n"
"pack $id.buttonframe.cancel -side left -expand 1\n"
@@ -390,12 +413,12 @@ void flext_base::SetAttrEditor(t_classid c)
"pack $id.buttonframe.help -side left -expand 1\n"
// "grid rowconfigure $id $row -weight 0\n"
- "grid config $id.buttonframe -column 0 -columnspan 8 -row $row -pady 5 -sticky {ew}\n"
+ "grid config $id.buttonframe -column 0 -columnspan 9 -row $row -pady 5 -sticky {ew}\n"
// Key bindings
"bind $id {<KeyPress-Escape>} \" flext_cancel $id \"\n"
"bind $id {<KeyPress-Return>} \" flext_ok $id $alen \"\n"
- "bind $id {<Shift-KeyPress-Return>} \" flext_apply $id $alen \"\n"
+ "bind $id {<Shift-KeyPress-Return>} \" flext_applyall $id $alen \"\n"
"}\n"
);
}
@@ -621,10 +644,7 @@ void flext_base::cb_GfxSave(t_gobj *c, t_binbuf *b)
bool flext_base::cb_AttrDialog(flext_base *th,int argc,const t_atom *argv)
{
- int i = 0;
- if(IsSymbol(argv[i]) && GetSymbol(argv[i]) == sym_list) ++i;
-
- for(; i < argc; ) {
+ for(int i = 0; i < argc; ) {
FLEXT_ASSERT(IsSymbol(argv[i]));
// get name
@@ -632,27 +652,17 @@ bool flext_base::cb_AttrDialog(flext_base *th,int argc,const t_atom *argv)
i++;
// get current value
+ FLEXT_ASSERT(CanbeInt(argv[i]));
int ccnt,coffs;
- if(IsSymbol(argv[i]) && GetSymbol(argv[i]) == sym_list) {
- i++;
- FLEXT_ASSERT(CanbeInt(argv[i]));
- ccnt = GetAInt(argv[i]);
- coffs = ++i;
- }
- else
- coffs = i,ccnt = 1;
+ ccnt = GetAInt(argv[i]);
+ coffs = ++i;
i += ccnt;
// get init value
+ FLEXT_ASSERT(CanbeInt(argv[i]));
int icnt,ioffs;
- if(IsSymbol(argv[i]) && GetSymbol(argv[i]) == sym_list) {
- i++;
- FLEXT_ASSERT(CanbeInt(argv[i]));
- icnt = GetAInt(argv[i]);
- ioffs = ++i;
- }
- else
- ioffs = i,icnt = 1;
+ icnt = GetAInt(argv[i]);
+ ioffs = ++i;
i += icnt;
FLEXT_ASSERT(i < argc);
diff --git a/externals/grill/flext/source/flext.cpp b/externals/grill/flext/source/flext.cpp
index eb3f2a35..e2ace494 100644
--- a/externals/grill/flext/source/flext.cpp
+++ b/externals/grill/flext/source/flext.cpp
@@ -54,6 +54,11 @@ flext_base::FLEXT_CLASSDEF(flext_base)():
flext_base::~FLEXT_CLASSDEF(flext_base)()
{
+#if FLEXT_SYS == FLEXT_SYS_PD && !defined(FLEXT_NOATTREDIT)
+ // attribute editor window may still be open -> close it
+ gfxstub_deleteforkey(thisHdr());
+#endif
+
#if FLEXT_SYS == FLEXT_SYS_MAX
// according to David Z. one should do that first...
// if(insigs) dsp_free(thisHdr());