aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--composer/track_proxy.c5
-rw-r--r--composer/window.tk112
2 files changed, 50 insertions, 67 deletions
diff --git a/composer/track_proxy.c b/composer/track_proxy.c
index 53fcb12..41a2994 100644
--- a/composer/track_proxy.c
+++ b/composer/track_proxy.c
@@ -154,12 +154,13 @@ static void track_proxy_save(t_gobj* z, t_binbuf* b) {
for(j = 0; j < pat->x_rows_count; j++) {
for(k = 0; k < t->x_ncolumns; k++) {
switch(pat->x_rows[j][k].a_type) {
- case A_FLOAT: binbuf_addv(b, "i", pat->x_rows[j][k].a_w.w_float); break;
+ case A_FLOAT: binbuf_addv(b, "f", pat->x_rows[j][k].a_w.w_float); break;
case A_SYMBOL: binbuf_addv(b, "s", pat->x_rows[j][k].a_w.w_symbol); break;
case A_NULL: binbuf_addv(b, "s", gensym("empty")); break;
- default: binbuf_addv(b, "s", gensym("?")); break;
+ default: binbuf_addv(b, "s", gensym("unknown")); break;
}
}
+ //binbuf_add(b, t->x_ncolumns, &pat->x_rows[j]);
}
}
diff --git a/composer/window.tk b/composer/window.tk
index ddda6ae..bd98ca4 100644
--- a/composer/window.tk
+++ b/composer/window.tk
@@ -46,6 +46,12 @@ namespace eval pd::composer {
array set patterns {}
variable quirks_fix_int_floats 0
+ # set to 1 until startup, for getting soon a pattern list
+ # affects the behavior of dispatcher::patterns branch
+ variable startup
+ array set startup {}
+ variable showpattern
+ array set showpattern {}
proc debugPrint {args} {
variable debug
@@ -75,9 +81,6 @@ namespace eval pd::composer {
}
sendGui [concat $id EDIT addpattern $name $len]
- #lappend patterns($id) $name
- #dict set length($id) $name $len
- #$w($id).f.p configure -values $patterns($id)
}
proc removePattern {id name} {
@@ -86,25 +89,13 @@ namespace eval pd::composer {
variable patterns;
sendGui [concat $id EDIT removepattern $name]
-
- #set oldidx [lsearch -exact $patterns($id) $name]
- #set length($id) [dict remove $length($id) $name]
- #set patterns($id) [lsearch -all -inline -not -exact $patterns($id) $name]
- #while {$oldidx >= [llength $patterns($id)]} {incr oldidx -1}
- #if {$oldidx < 0} {set oldidx 0}
- #displayPattern $id [lindex $patterns($id) $oldidx]
}
proc copyPattern {id src dst} {
debugPrint [info level 0]
variable length;
- #upvar 0 $::datavar($w)_$src SRC
- #upvar 0 $::datavar($w)_$dst DST
sendGui [concat $id EDIT copypattern $src $dst]
-
- #createPattern $w $dst [dict get $length($id) $src]
- #array set DST [array get SRC]
}
proc resizePattern {id name newSize} {
@@ -120,20 +111,12 @@ namespace eval pd::composer {
}
sendGui [concat $id EDIT resizepattern $name $len]
-
- #dict set length($id) $name $len
- #if {$name == $currentpattern($id)} {
- # refresh stuff
- # displayPattern $id $name
- #}
}
proc renamePattern {id name newName} {
debugPrint [info level 0]
variable length;
variable patterns;
- #upvar 0 $::datavar($w)_$name SRC
- #upvar 0 $::datavar($w)_$newName DST
if {$name == $newName} return
if {$newName in $patterns($id)} {
@@ -145,15 +128,6 @@ namespace eval pd::composer {
}
sendGui [concat $id EDIT renamepattern $name $newName]
-
- #lset patterns($id) $idx $newName
- #array set DST [array get SRC]
- #array unset SRC
-
- #dict set length($id) $newName [dict get $length($id) $name]
- #set length($id) [dict remove $length($id) $name]
-
- #displayPattern $id $newName
}
proc generateNewPatternName {id} {
@@ -168,9 +142,23 @@ namespace eval pd::composer {
proc displayPattern {id name} {
debugPrint "request-pattern-length"
+ variable showpattern
+ set showpattern($id) 1
sendGui [concat $id EDIT getpatternlength $name]
}
+ proc updateTitle {id} {
+ variable w
+ variable songname
+ variable trackname
+ variable currentpattern
+ set t "Song: $songname($id) Track: $trackname($id)"
+ if {$currentpattern($id) != {}} {
+ append t " Pattern: $currentpattern($id)"
+ }
+ wm title $w($id) $t
+ }
+
proc displayPattern_async {id name} {
debugPrint [info level 0]
variable currentpattern
@@ -182,27 +170,21 @@ namespace eval pd::composer {
variable trackname
variable [getDataVar $id]
- wm title $w($id) "Song: $songname($id) Track: $trackname($id)"
- debugPrint "checkExit"
- if {$name == {}} {return}
- if {$name ni $patterns($id)} {
- debugPrint "Pattern '$name' does not exist"
- return -code error "Pattern '$name' does not exist"
+ set currentpattern($id) $name
+ updateTitle $id
+
+ if {$currentpattern($id) == {}} {
+ grid forget $w($id).t
+ return
}
- debugPrint "s1"
+
set rows [dict get $length($id) $name]
set cols $columns($id)
debugPrint "resizing tktable widget to ${rows}x${cols}"
grid $w($id).t -row 10 -column 0 -sticky news
$w($id).t configure -state normal -variable [getDataVar $id] -rows $rows -cols [expr {1+$cols}]
- debugPrint "s2"
$w($id).f.p configure -values $patterns($id)
- debugPrint "s3"
$w($id).f.p current [lsearch -exact $patterns($id) $name]
- debugPrint "setCurPattern"
- set currentpattern($id) $name
- debugPrint "setTitle"
- wm title $w($id) "Song: $songname($id) Track: $trackname($id) Pattern: $name"
}
proc displayCurrentPattern {id} {
@@ -214,7 +196,6 @@ namespace eval pd::composer {
}
proc rowTag {id r} {
- #debugPrint [info level 0]
if {$r % $::div1 == 0} {return "alt0"}
if {$r % $::div2 == 0} {return "alt1"}
}
@@ -252,6 +233,8 @@ namespace eval pd::composer {
variable songname
variable trackname
variable patterns
+ variable startup
+ variable showpattern
variable [getDataVar $id]
catch {destroy $w($id)}
@@ -282,16 +265,10 @@ namespace eval pd::composer {
debugPrint "step2"
$w($id).f.p state readonly
- # movet to async counterpart
- #$w($id).f.p configure -values $patterns($id)
-
- debugPrint "request-patterns"
- sendGui [concat $id EDIT getpatterns]
-
debugPrint "bindevent"
bind $w($id).f.p <<ComboboxSelected>> "[namespace current]::displayCurrentPattern $id"
debugPrint "table"
- #grid [
+
table $w($id).t -state disabled \
-insertofftime 0 \
-bordercursor sb_h_double_arrow \
@@ -310,10 +287,7 @@ namespace eval pd::composer {
-variable [getDataVar $id] -exportselection 1 \
-xscrollcommand "$w($id).hscroll set" \
-yscrollcommand "$w($id).vscroll set" \
- -rowtagcommand "[namespace current]::rowTag $id" \
-
- #] -row 10 -column 0 -sticky news
-
+ -rowtagcommand "[namespace current]::rowTag $id"
#grid $w($id).t -row 10 -column 0 -sticky news
debugPrint "scrollbars"
@@ -364,6 +338,11 @@ namespace eval pd::composer {
bind $w($id).t <ButtonPress-3> "$w($id).t activate @%x,%y; tk_popup $w($id).m %X %Y"
bind $w($id).t <Control-t> "switchColumnType $id"
+ set startup($id) 1
+ set showpattern($id) 0
+ debugPrint "request-patterns"
+ sendGui [concat $id EDIT getpatterns]
+
return $w($id)
}
@@ -470,7 +449,6 @@ namespace eval pd::composer {
dict set options vlength [dict get $length($id) $currentpattern($id)]
dict set options action_ok {
%ns::copyPattern %id %old_name [%w.ename get]
- %ns::displayPattern %id [%w.ename get]
destroy %w
}
patternPropertiesDialog_common $id $options
@@ -495,7 +473,6 @@ namespace eval pd::composer {
%ns::createPattern %id [%w.ename get] [%w.elength get]
destroy %w
}
- # %ns::displayPattern %id [%w.ename get]
dict set options vname [generateNewPatternName $id]
dict set options vlength 16
patternPropertiesDialog_common $id $options
@@ -542,16 +519,19 @@ namespace eval pd::composer {
variable patterns
variable length
variable currentpattern
+ variable startup
+ variable showpattern
variable quirks_fix_int_floats
switch -exact [lindex $args 0] {
patterns {
set patterns($id) [lrange $args 1 end]
debugPrint "tk::patterns <- $patterns($id)"
$w($id).f.p configure -values $patterns($id)
- if {0 && [llength $patterns($id)] > 0 && $currentpattern($id) == {}} {
- set firstpat [lindex $patterns($id) 0]
- debugPrint "showing pattern '$firstpat'"
- displayPattern $id $firstpat
+ if {$startup($id)} {
+ set startup($id) 0
+ if {[llength $patterns($id)] > 0} {
+ displayPattern $id [lindex $patterns($id) 0]
+ }
}
}
patternlength {
@@ -564,7 +544,6 @@ namespace eval pd::composer {
sendGui [concat $id EDIT getrow $pat_name $i]
}
}
- displayPattern_async $id $pat_name
}
row {
set pat_name [lindex $args 1]
@@ -580,7 +559,10 @@ namespace eval pd::composer {
setCellValueUI $id $pat_name $row_num $i [lindex $row $i]
}
if {$row_num + 1 == [dict get $length($id) $pat_name]} {
- #refreshGrid $id
+ if {$showpattern($id)} {
+ set showpattern($id) 0
+ displayPattern_async $id $pat_name
+ }
}
}
cell {