You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
173 lines
5.0 KiB
Plaintext
173 lines
5.0 KiB
Plaintext
#
|
|
# Cadence-compatibility bindings except where marked.
|
|
#
|
|
macro f "view" ;# zoom to fit window
|
|
macro ^z "zoom 0.5" ;# zoom in
|
|
macro Z "zoom 2" ;# zoom out
|
|
macro B "popstack" ;# up hierarchy
|
|
macro X {pushstack [cellname list self]} ;# down hierarchy
|
|
macro x "edit" ;# down hierarchy, edit-in-place
|
|
macro b "select top cell ; edit" ;# up hierarchy from edit-in-place
|
|
macro p "tool wire; magic::trackwire %W pick" ;# path
|
|
macro ^r "redraw"
|
|
macro ^f "unexpand"
|
|
macro F "expand"
|
|
macro ^a "select area"
|
|
macro ^d "select clear"
|
|
macro k "magic::measure"
|
|
macro K "magic::unmeasure"
|
|
macro i "magic::promptload getcell"
|
|
macro l "magic::update_texthelper ; wm deiconify .texthelper ; raise .texthelper"
|
|
macro O "magic::clock"
|
|
macro <del> "magic::delete"
|
|
|
|
# Toolkit parameter dialog
|
|
macro q "magic::gencell {} ; raise .params"
|
|
#
|
|
# The following should be already implemented as existing Magic bindings
|
|
#
|
|
macro u "undo"
|
|
macro U "redo"
|
|
macro m "move"
|
|
macro c "copy"
|
|
#
|
|
# Compatibility with Electric; Cadence bindings are on function keys and
|
|
# do not work through the VNC.
|
|
macro ^s "magic::promptsave magic" ;# save dialog menu
|
|
|
|
#
|
|
# Bertrand's bindings follow except where marked.
|
|
#
|
|
macro < sideways
|
|
macro ^ upsidedown
|
|
#
|
|
# Set grid at 1 micron
|
|
#
|
|
macro 0 "grid on ; grid 1l" ;# Grid at 0.5um (1 lambda)
|
|
# macro ^f "feedback clear" ;# conflicts with Cadence binding
|
|
#
|
|
# Paint/Erase macros
|
|
#
|
|
macro 1 "paint m1"
|
|
macro ! "erase m1"
|
|
macro 2 "paint m2"
|
|
macro @ "erase m2"
|
|
macro 3 "paint m3"
|
|
macro # "erase m3"
|
|
macro 4 "paint m4"
|
|
macro $ "erase m4"
|
|
macro 5 "paint mtp"
|
|
macro % "erase mtp"
|
|
|
|
macro 7 "paint poly"
|
|
# macro & "erase poly"
|
|
# macro p "paint pdiff"
|
|
macro n "paint ndiff"
|
|
# macro l "erase labels"
|
|
macro P "erase pdiff"
|
|
macro N "erase ndiff"
|
|
macro y "drc check; drc why"
|
|
macro ? "select area; what"
|
|
|
|
macro / "expand toggle"
|
|
macro ^w "writeall force"
|
|
macro ^e "edit"
|
|
# macro ^x "quit"
|
|
|
|
macro z "findbox zoom"
|
|
# "f" conflicts with Cadence "full view", so use control-i to select cells.
|
|
# macro f "select cell"
|
|
macro ^i "select cell"
|
|
|
|
# Leave keypad bindings as-is, further down. However, keypad
|
|
# keys generally don't translate through the VNC session, so
|
|
# use the following arrow key bindings:
|
|
#
|
|
# no shift shift
|
|
# arrows only -> Pan 10% 100%
|
|
# with alt -> Move 1 lambda 1 grid
|
|
# with ctrl -> Stretch 1 lambda 1 grid
|
|
#
|
|
# Pan 10 percent of the window size with arrows
|
|
# macro XK_Left "scroll l .1 w"
|
|
# macro XK_Up "scroll u .1 w"
|
|
# macro XK_Right "scroll r .1 w"
|
|
# macro XK_Down "scroll d .1 w"
|
|
|
|
# Pan 100 percent of the window size with arrows
|
|
# macro Shift_XK_Left "scroll l 1 w"
|
|
# macro Shift_XK_Up "scroll u 1 w"
|
|
# macro Shift_XK_Right "scroll r 1 w"
|
|
# macro Shift_XK_Down "scroll d 1 w"
|
|
|
|
# move 0.05um with arrows
|
|
# macro Alt_XK_Left "move l 1l"
|
|
# macro Alt_XK_Right "move r 1l"
|
|
# macro Alt_XK_Up "move u 1l"
|
|
# macro Alt_XK_Down "move d 1l"
|
|
|
|
# move 1 grid unit with arrows
|
|
# macro Alt_Shift_XK_Left "move l 1g"
|
|
# macro Alt_Shift_XK_Right "move r 1g"
|
|
# macro Alt_Shift_XK_Up "move u 1g"
|
|
# macro Alt_Shift_XK_Down "move d 1g"
|
|
|
|
# stretch 0.05um with arrows
|
|
# macro Control_XK_Left "stretch l 1l"
|
|
# macro Control_XK_Right "stretch r 1l"
|
|
# macro Control_XK_Up "stretch u 1l"
|
|
# macro Control_XK_Down "stretch d 1l"
|
|
|
|
# stretch 1 grid unit with arrows
|
|
# macro Control_Shift_XK_Left "stretch l 1g"
|
|
# macro Control_Shift_XK_Right "stretch r 1g"
|
|
# macro Control_Shift_XK_Up "stretch u 1g"
|
|
# macro Control_Shift_XK_Down "stretch d 1g"
|
|
|
|
# shift mouse wheel bindings for right-left shift
|
|
macro Shift_XK_Pointer_Button4 "scroll r .05 w"
|
|
macro Shift_XK_Pointer_Button5 "scroll l .05 w"
|
|
|
|
# control mouse wheel bindings for zoom in/out
|
|
macro Control_XK_Pointer_Button4 "zoom 0.70711"
|
|
macro Control_XK_Pointer_Button5 "zoom 1.41421"
|
|
|
|
# Bertrand's original arrow macros
|
|
# move 1 grid unit with arrows
|
|
macro XK_Left "move l 1g"
|
|
macro XK_Right "move r 1g"
|
|
macro XK_Up "move u 1g"
|
|
macro XK_Down "move d 1g"
|
|
|
|
# move 0.05um with arrows
|
|
macro Control_XK_Left "move l 1l"
|
|
macro Control_XK_Right "move r 1l"
|
|
macro Control_XK_Up "move u 1l"
|
|
macro Control_XK_Down "move d 1l"
|
|
|
|
# stretch 1 grid unit with arrows
|
|
macro Shift_XK_Left "stretch l 1g"
|
|
macro Shift_XK_Right "stretch r 1g"
|
|
macro Shift_XK_Up "stretch u 1g"
|
|
macro Shift_XK_Down "stretch d 1g"
|
|
|
|
# stretch 0.05um with arrows
|
|
macro Control_Shift_XK_Left "stretch l 1l"
|
|
macro Control_Shift_XK_Right "stretch r 1l"
|
|
macro Control_Shift_XK_Up "stretch u 1l"
|
|
macro Control_Shift_XK_Down "stretch d 1l"
|
|
|
|
# Restore pan function on Alt-key
|
|
# Pan 10 percent of the window size with arrows
|
|
macro Alt_XK_Left "scroll l .1 w"
|
|
macro Alt_XK_Up "scroll u .1 w"
|
|
macro Alt_XK_Right "scroll r .1 w"
|
|
macro Alt_XK_Down "scroll d .1 w"
|
|
|
|
# Pan 100 percent of the window size with arrows
|
|
macro Alt_Shift_XK_Left "scroll l 1 w"
|
|
macro Alt_Shift_XK_Up "scroll u 1 w"
|
|
macro Alt_Shift_XK_Right "scroll r 1 w"
|
|
macro Alt_Shift_XK_Down "scroll d 1 w"
|
|
|