-# $Id: editor.tcl,v 1.62.2.10 2007/07/20 17:08:39 miljenko Exp $
+# $Id: editor.tcl,v 1.62.2.11 2007/08/11 08:57:29 ana Exp $
#
# Copyright 2004, 2005 University of Zagreb, Croatia. All rights reserved.
#
set x [expr {[lindex $coords 0] * $zoom}]
set y [expr {[lindex $coords 1] * $zoom}]
if { [nodeType $node] != "pseudo" } {
+ set labelstr1 [getNodeName $node];
+ set labelstr2 [getNodePartition $node];
+ set l [format "%s\n%s" $labelstr1 $labelstr2];
set label [.c create text $x $y -fill blue \
- -text "[getNodeName $node]" \
+ -text "$l" \
-tags "nodelabel $node"]
} else {
set pnode [getNodeName $node]
# actually we should check if curobj==bkgImage
} elseif { $activetool == "oval" && \
( $curobj == $newoval || $curobj == $background || $curtype == "background" || $curtype == "grid")} {
- # Draw a new oval
+ # Draw a new oval
if {$newoval == ""} {
set newoval [$c create oval $lastX $lastY $x $y \
-dash {10 4} -width 1 -tags "newoval"]
button $wi.custom.cfg.edit -text "Edit" \
-command "editStartupCfg $target 0"
button $wi.custom.cfg.clear -text "Clear" \
- -command "setCustomConfig $target {} {} {} 0"
+ -command "setCustomConfig $target {} {} {} 0 0"
pack $wi.custom.cfg.generate $wi.custom.cfg.edit \
$wi.custom.cfg.clear -side left
set id "generic"
set cmd [[typemodel $node].bootcmd $node]
set cfg [[typemodel $node].cfggen $node]
- setCustomConfig $node $id $cmd $cfg 0
+ setCustomConfig $node $id $cmd $cfg 0 0
}
frame $w.buttons
pack $w.buttons -side bottom
+ button $w.buttons.addccfg -text "Add new" \
+ -command "customConfigApply $w $node 1"
button $w.buttons.apply -text "Apply" \
- -command "customConfigApply $w $node"
- button $w.buttons.close -text Close -command "destroy $w"
+ -command "customConfigApply $w $node 0"
button $w.buttons.delete -text Delete -command \
"deleteCustomConfig $w $node $viewcustomid {} {} 1"
- pack $w.buttons.apply $w.buttons.close $w.buttons.delete -side left
+ button $w.buttons.close -text Close -command "destroy $w"
+ pack $w.buttons.addccfg $w.buttons.apply $w.buttons.delete \
+ $w.buttons.close -side left
pack $w.scroll -side right -fill y
pack $w.text -expand yes -fill both
# * w -- widget
# * node_id -- node id
#****
-proc customConfigApply { w node } {
+proc customConfigApply { w node addccfg } {
global changed
set newcmd [$w.ftop.cmd get]
[getCustomConfig $node] != $newconf } {
set changed 1
}
- setCustomConfig $node $newid $newcmd $newconf 0
+ setCustomConfig $node $newid $newcmd $newconf 0 $addccfg
destroy $w
- editStartupCfg $node 0
}
#****f* editor.tcl/popupConfigApply
-# $Id: nodecfg.tcl,v 1.16.2.3 2007/07/19 03:31:22 marko Exp $
+# $Id: nodecfg.tcl,v 1.16.2.4 2007/08/11 08:57:29 ana Exp $
#
# Copyright 2004, 2005 University of Zagreb, Croatia. All rights reserved.
#
# *
#****
-proc setCustomConfig { node id cmd cfg delete } {
+proc setCustomConfig { node id cmd cfg delete addccfg } {
global viewcustomid
global $node
set $node [lreplace [set $node] $j $j]
}
+ set cnt 0
set indices [lsearch -all [set $node] "custom-config *"]
foreach i $indices {
+ set i [expr $i-$cnt]
+ set cnt [expr $cnt+1]
set tmp [lindex [set $node] $i]
set customCfg [lindex $tmp 1]
set cid [lindex [lsearch -inline $customCfg "custom-config-id *"] 1]
- if { $cid == $id } {
+
+ if { $addccfg == 0 && $delete == 0 } {
set $node [lreplace [set $node] $i $i]
- }
+ } elseif { $addccfg == 0 && $delete == 1 } {
+ if { $cid == $id } {
+ set $node [lreplace [set $node] $i $i]
+ }
+ } else {
+ if { $cid == $id } {
+ set warning "Choose another custom config id!"
+ tk_messageBox -message $warning -type ok -icon warning \
+ -title "Custom configuration id warning"
+ set $node [lreplace [set $node] $i $i]
+ }
+ }
+
}
if { $delete == 0 } {
proc deleteCustomConfig { w node id cmd cfg delete } {
global viewcustomid
- setCustomConfig $node $viewcustomid {} {} 1
+ setCustomConfig $node $viewcustomid {} {} 1 0
destroy $w
editStartupCfg $node 1
}