chiark / gitweb /
where-vessels: much better docs re ui; auto switch to "These:"
[ypp-sc-tools.db-test.git] / yarrg / where-vessels
index 0aa7290669881a22fc12e60ea08f38690907ff71..9005a7f9032c9dadd15e5d1da71d39e6ad140634 100755 (executable)
@@ -541,16 +541,16 @@ proc make-control-grid-elem {cw kind ix ekind args} {
     return $ew
 }
 
-proc control-tickbox-flip {varsvn values} {
+proc control-tickbox-flip {varsvn values onflip} {
     upvar #0 $varsvn vars
     foreach val $values {
        set vars($val) [expr {!$vars($val)}]
     }
-    redraw-needed c.-tickbox-flip $varsvn $values
+    $onflip c.-tickbox-flip $varsvn $values
 }
 
 proc populate-control-grid-tickboxes {cw rows inrow varsvn values flipvalues
-                                   label_kind valvn default_get label_get} {
+                           label_kind valvn default_get label_get onflip} {
     debug "POPULATE-CONTROL-GRID-TICKBOXES $cw $rows $inrow $varsvn\
              [list $values] $label_kind $valvn"
 
@@ -566,7 +566,7 @@ proc populate-control-grid-tickboxes {cw rows inrow varsvn values flipvalues
        set ew [make-control-grid-elem $cw ix $ix checkbutton \
                    -variable ${varsvn}($val) \
                    -font fixed \
-                   -command [list redraw-needed c.-g.-tickbox $cw $val]]
+                   -command [list $onflip c.-g.-tickbox $cw $val]]
        $ew configure -$label_kind [uplevel 1 $label_get]
        switch -exact $label_kind {
            image { $ew configure -height 16 }
@@ -574,8 +574,8 @@ proc populate-control-grid-tickboxes {cw rows inrow varsvn values flipvalues
     }
     [make-control-grid-elem $cw final invert button] \
        configure \
-       -text flip -command [list control-tickbox-flip $varsvn $flipvalues] \
-       -padx 0 -pady 0
+       -text flip -padx 0 -pady 0 \
+       -command [list control-tickbox-flip $varsvn $flipvalues $onflip]
 }
 
 #---------- smashing ----------
@@ -650,7 +650,8 @@ proc make-radio-smasher {sma label variable descs rows inrow} {
     for {set i 0} {$i < [llength $descs]} {incr i} {
        make-control-grid-elem $w ix $i \
            radiobutton \
-           -variable $variable -value $i -command redraw-needed \
+           -variable $variable -value $i \
+           -command [list redraw-needed radio-smasher $sma] \
            -text [lindex $descs $i]
     }
 }
@@ -660,7 +661,8 @@ proc make-smashers {} {
     set cw [make-smasher size "Size\n round\n down" frame]
     populate-control-grid-tickboxes $cw 2 0 smash_size \
        $vc_codes [lrange $vc_codes 1 end] \
-       image val { expr 0 } { expr {"icon/$vc_code2abbrev($val)"} }
+       image val { expr 0 } { expr {"icon/$vc_code2abbrev($val)"} } \
+       redraw-needed
     $cw.0 configure -state disabled
 
     glset smash_subclass 0
@@ -668,7 +670,7 @@ proc make-smashers {} {
        {Show Normal/LE Hide} 1 0
 
     glset smash_owner [expr {[have-notes] ? 0 : 3}]
-    make-radio-smasher owner Owner smash_owner \
+    make-radio-smasher owner "Lock/\nowner" smash_owner \
        {Show Yours? {For you} Lock Hide} 2 3
 
     set cw [make-smasher xabbrev "Flags" frame]
@@ -770,7 +772,8 @@ proc make-tickbox-filter {fil label rows inrow} {
 
     populate-control-grid-tickboxes $fw $rows $inrow filter_$fil \
        $values $values \
-       $label_kind val { filter-default/$fil $val } $label_get
+       $label_kind val { filter-default/$fil $val } $label_get \
+       specific-filter-adjusted
 }
 
 proc entry-filter-changed {fw fil n1 n2 op} {
@@ -786,7 +789,7 @@ proc entry-filter-changed {fw fil n1 n2 op} {
        } else {
            $fw.error configure -text { } -background $def_background
            set realvar $entryvar
-           redraw-needed
+           specific-filter-adjusted entry-filter-changed $fw
        }
     } emsg]} {
        puts stderr "FILTER CHECK ERROR $emsg $errorInfo"
@@ -826,10 +829,15 @@ proc make-filters {} {
     make-entry-filter xabbre "Flags\n regexp" {}
 }
 
+proc specific-filter-adjusted {args} {
+    glset filterstyle 3
+    eval redraw-needed $args
+}
+
 proc filterstyle-changed {n1 n2 op} {
     global filterstyle
-    debug "filterstyle-changed $filterstyle"
-    redraw-needed
+    debug "FILTERSTYLE-CHANGED $filterstyle"
+    redraw-needed filterstyle-changed
 }
 
 proc filters-say-yes {code} {