Syntax summary: | FuncmapChange(previous|next|remove, component, port) FuncmapChange(set, component, port, [newfunc]) FuncmapChange(setgrp, component, grpname) |
---|---|
Help text: | Change the alternate function of a component-port. The setgrp command activates a group by setting all affected ports to that group's funcionality. All arguments are case-sensitive. |
Registered by: | funcmap |
Changes the funcmap/name attribute on one or more ports of a given component. The component (and port, when needed), needs to be named and is looked up in the abstract model (the project needs to be compiled). The actual change is always made in concrete terminal object(s) looked up from the abstract port objects. If multiple terminals are contributing to the port (source terminals), the change is done to the terminals that already have the funcmap/name attribute. If none of the source terminals have that attribute, the attribute is created in one of the source terminals randomly chosen.
The first argument is the command to perform.
If the command is previous or next , the selected function of the given port is moved one step back or forward on the function list for the port. The function list has the order of functions as they appear in the li:funcmap/ports section of the funcmap file (this differs from the column ordering in the tabular form, which is deduced from function grouping).
If the command is set and the new function is specified as the 4th argument, the source terminal attribute is changed to that function. The added value of this command compared to the propset() action is that it looks up the terminal object to change and verifies whether the new function is available for the given port.
The setgrp command modifies multiple terminals so that a whole function group is activated (by function group name).
Syntax summary: | FuncmapPrintTable(component, [column]) |
---|---|
Help text: | Print a table of all alternative port functions for a component If column is specified, sort the table by the named column. |
Registered by: | funcmap |
Prints the function mapping of a component in the standard tabular form to the stdout. Each row is a port, each column is a function group. Cells are function names. The function that's active for a port is wrapped in [[]].
If the optional second parameter is specified and is a valid column name, the table is sorted by that column.
Syntax summary: | Quit() |
---|---|
Help text: | Quits sch-rnd after confirming. |
Registered by: | n/a |
If you have unsaved changes, you will be prompted to confirm (or save) before quitting.
Syntax summary: | RtreeList[rtree_name, [x1, y1, x2, y2]) |
---|---|
Help text: | Return a list of idpaths for objects overlapping with the box specified (empty list if no object is found). Error is indicated by returning nil. If coordinates are not specified the whole tree is searched. |
Registered by: | act_read |
Search all objects of the selected layer's named rtree on the current sheet and return a list of idpaths.
The first argument is a layer name with an optional suffix. A layer name is the same as layer names printed by the GUI, e.g. "wire" or "hub & terminal". Suffix may be "-stroke" or "-fill"; when no suffix is appended, "-stroke" is assumed. All normal objects are in the stroke rtree; polygons with fill enabled are also in the fill rtree.
If coordinates of a box is give, smaller coords first, the search is performed only within that box and any object that has overlapping bounding box (on the given layer) is returned. Otherwise the search is performed on the whole rtree, returning all objects on the layer.
Syntax summary: | Zoom() Zoom([+|-|=]factor) Zoom(x1, y1, x2, y2) Zoom(?) Zoom(get) Zoom(selected) |
---|---|
Help text: | GUI zoom |
Registered by: | sch_rnd_gui |
Changes the zoom (magnification) of the view of the sheet. If no arguments are passed, the view is scaled such that the sheet just fits inside the visible window (i.e. "view all"). Otherwise, factor specifies a change in zoom factor. It may be prefixed by + , - , = to change how the zoom factor is modified (relative or absolute). The factor is a floating point number, such as 1.5 or 0.75 .
Alternatively a box can be specified with 4 coordinates and zoom will set the zoom level (and modifies pan) so that the given box of the design is visible and as large as possible in the current window.
Arguments:
(no argument) | Without argments: zoom to sheet extents. |
---|---|
+factor | Values greater than 1.0 cause the sheet to be drawn smaller; more of the sheet will be visible. Values between 0.0 and 1.0 cause the sheet to be drawn bigger; less of the sheet will be visible. |
-factor | Values greater than 1.0 cause the sheet to be drawn bigger; less of the sheet will be visible. Values between 0.0 and 1.0 cause the sheet to be drawn smaller; more of the sheet will be visible. |
=factor | The @var{factor} is an absolute zoom factor; the unit for this value is "PCB units per screen pixel". Since PCB units are nanometer, a factor of 1000 means 1 micrometer per pixel (TODO: test this). |
x1, y1, x2, y2 | Zoom to the specified portion of the design, described as a rectangle (using sheet space coordinates) |
selected | Zoom and pan so that all selected objects are on the screen. |
? | Print the current zoom level in the message log (as an info line). |
get | Return the zoom level as an FGW_DOUBLE (useful for scripts). |
Note that zoom factors of zero are silently ignored.
Syntax summary: | AddTimer(action, period, [repeat], [userdata]) |
---|---|
Help text: | Add a new timer |
Registered by: | script plugin |
This action is intended for scripts to create async timers. Note: timers do not work with the batch HID (no callback issued ever).
Creates a timer that executes an action (by name) periodically. Period is a real number specified in seconds. Internal timer resolution is in the order of 0.1 second.
If repeat is not specified or is less than 1, the timer is repeated indefinitely. If the optional userdata string is specified, it is also passed to the action.
The action is specified only by a name, call arguments are always the following:
Action shall return integer 0 on success. If the action does not exist or returns anything else, the timer is uninstalled.
There can be any number of timers in parallel.
Syntax summary: | AnyLoad([path]) |
---|---|
Help text: | Load "anything" from path (or offer a file selectio dialog if no path specified) |
Registered by: | n/a |
Loads an anyload.lht file or any lihata document that can be handled by the anyload system (mostly settings and setting-like states, e.g. config, vendor drill map, DRC and user scripts).
When called without arguments a file selection dialog is popped up for selecting the file to load.
More info on this mechanism in the knowledge pool node of anyload.
Syntax summary: | Benchmark() |
---|---|
Help text: | Benchmark the GUI speed. |
Registered by: | n/a |
This action is used to speed-test the GUI rendering. It redraws the current screen as many times as possible in ten seconds. It reports the amount of time needed to draw the screen once, in average.
Syntax summary: | Center() |
---|---|
Help text: | Moves the pointer to the center of the window. |
Registered by: | lib_hid_common plugin |
Move the pointer to the center of the window, but only if it's currently within the window already.
Syntax summary: | Cursor(Type,DeltaUp,DeltaRight,Units) |
---|---|
Help text: | Move the cursor. |
Registered by: | n/a |
This action moves the mouse cursor. Unlike other actions which take coordinates, this action's coordinates are always relative to the user's view of the board. Thus, a positive DeltaUp may move the cursor away from the board origin if the board is inverted (flipped, looked from the bottom).
Type is one of Pan or Warp . Pan causes the viewport to move such that the crosshair is under the mouse cursor. Warp causes the mouse cursor to move to be above the crosshair.
Units can be one of the following:
mil
mm | The cursor is moved by that amount, in board units. |
grid | The cursor is moved by that many grid points. |
view | The values are percentages of the viewport's view. Thus, a pan of 100 would scroll the viewport by exactly the width of the current view. |
design | The values are percentages of the board size. Thus, a move of 50,50 moves you halfway across the board. |
board | Same as design (for backward compatibility) |
Syntax summary: | n/a |
---|---|
Help text: | n/a |
Registered by: | n/a |
Argument:
1
Layout | Open the layout window. Since the layout window is always shown anyway, this has no effect. |
---|---|
2
Library | Open the library window. |
3
Log | Open the log window. |
4
Netlist | Open the netlist window. |
5
Preferences | Open the preferences window. |
6
DRC | Open the DRC violations window. |
7
Search | Open the advanced search window. |
Syntax summary: | GetXY([message, [x|y]]) |
---|---|
Help text: | Get a coordinate. If x or y specified, the return value of the action is the x or y coordinate. |
Registered by: | n/a |
Prompts the user for a coordinate, if one is not already selected.
Syntax summary: | ListScripts([pat]) |
---|---|
Help text: | List fungw scripts, optionally filtered wiht regex pat. |
Registered by: | script plugin |
Print one line in the log for each currently loaded script. If pat is specified, filter the list using pat as a case sensitive extended regex on script ID, file name and language (list only scripts that match with any of these fields).
Syntax summary: | LiveScript([new], [name]) LiveScript(load|save, name, [filame]) LiveScript(run|stop|rerun|undo, name) |
---|---|
Help text: | Manage a live script |
Registered by: | script plugin |
The first argument determines what operation the action performs and how subsequent arguments are interpreted:
new, [name] | Create a new live script and open a new live script dialog. name is an unique live script name that identifies the window. If not specified, "default" is used" |
---|---|
load, name, [filename] | Replace the script source in the LiveScript window identified by name with the content loaded from a file. If filename is not specified, open a file selector dialog. |
save, name, [filename] | Save the script source in the LiveScript window identified by name to a file. If filename is not specified, open a file selector dialog. |
run, name | Run the script in the LiveScript window identified by name . |
stop, name | Stop the script in the LiveScript window identified by name , if ti is running in persistent mode. |
undo, name | Undo the "init changes" of the script in the LiveScript window identified by name . Init changes are those board changes the script has done while running its initialization section. Live script undo is possible only if there was no user edit after the script finished. |
rerun, name | Stop, undo and run the script in the LiveScript window identified by name . |
Syntax summary: | LoadScript(id, filename, [language]) |
---|---|
Help text: | Load a fungw script |
Registered by: | script plugin |
id is an arbitrary string assigned by the user. id must be unique per application session per script and may contain alphanumeric characters and undescrore.
fn is the file name of the script, which is a path. Librnd does not do any search, it only opens the path as specified.
lang is the scripting language, as in fungw plugin name . When not specified, the code makes a guess (based on the file name).
Syntax summary: | message([ERROR|WARNING|INFO|DEBUG,] message) |
---|---|
Help text: | Writes a message to the log window. |
Registered by: | n/a |
This action displays a message to the log window. This action is primarily provided for use by scripts and external programs which may interface with the application. If multiple arguments are given, each one is sent to the log window followed by a newline.
If there are 2 or more arguments and the first argument matches, in a case sensitive manner, one of the below keywords, the message is registered on the specified error level. Else the PCB_MSG_INFO error level is used.
first argument | erro level |
---|---|
ERROR | PCB_MSG_ERROR |
WARNING | PCB_MSG_WARNING |
INFO | PCB_MSG_INFO |
DEBUG | PCB_MSG_DEBUG |
Syntax summary: | n/a |
---|---|
Help text: | n/a |
Registered by: | n/a |
The oneliner action is designed for quick execution of short, trivial scripts, such as a for loop for repeating an action. It supports any scripting language currently availabel through fungw. Each oneliner is an independent script context - variables, functions and other global states do not persist.
This group of actions offers three forms:
For example, a simple calculation using awk can be done in three ways:
Syntax summary: | Pan(Mode) |
---|---|
Help text: | Start or stop panning (Mode = 1 to start, 0 to stop) |
Registered by: | lib_hid_common plugin |
Start or stop panning. To start call with Mode = 1, to stop call with Mode = 0.
Syntax summary: | Print() |
---|---|
Help text: | Present the print export dialog for printing the layout from the GUI. |
Registered by: | n/a |
Open an export dialog listing all printing plugins, prompt the user for their options, and print the layout.
Available only with GUI HIDs: it's merely a graphical shorthand that in turn calls the export plugin for printing.
Syntax summary: | PromptFor([message[,default[,title]]]) |
---|---|
Help text: | Prompt for a string. Returns the string (or NULL on cancel) |
Registered by: | n/a |
UI-independent way of asking the user for a string. When GUI is available, it is a dialog box, else it's console input. Return value, unlike with other actions, is a string. The return value is NULL on cancel.
Syntax summary: | ReloadScript(id) |
---|---|
Help text: | Reload a fungw script |
Registered by: | script plugin |
id is the same that was specified for loadscript . If loading the new verison of the script fails, id is released (can be reused for a new LoadScript).
Syntax summary: | ScriptCookie() |
---|---|
Help text: | Return a cookie specific to the current script instance during script initialization |
Registered by: | script plugin |
The script:
The function can not be called outside of script initialization. The cookie string can be used any time between script load and script unload.
Syntax summary: | ScriptPersistency(read|remove) |
---|---|
Help text: | Read or remove script persistency data savd on preunload |
Registered by: | script plugin |
When a script is unloaded, its action preunload is called. The return value is saved as script persistent data. When the script is loaded again later, it can use scriptpersistency ( read ) to read the data saved.
scriptpersistency ( remove ) deletes the data from disk.
Note: the data is per script id, not per script file name.
Syntax summary: | Scroll(up|down|left|right, [pixels]) |
---|---|
Help text: | Scroll the viewport. |
Registered by: | lib_hid_common plugin |
Arguments:
up|down|left|right | Specifies the direction to scroll |
---|---|
pix | Optional. Specifies how many pixels to scroll by. If not specified: default pix is 100. |
Syntax summary: | SetGridOffs(x_offs, y_offs) |
---|---|
Help text: | Change grid offset (alignment) to x_offs and y_offs. Offsets should be specified with units. |
Registered by: | n/a |
Changes the grid offset to relative or absolute x_offs and y_offs. For non-zero values always use units, e.g. SetGrifOffs(0.5mm, 0.1mm).
The final grid offset alues will be scaled down so they are always between 0 and the current grid size. For example with a 25 mil grid, a value of 7mil will be taken as 7mil offset, but a value of 27 mil will be taken as a 2mil offset.
If an offset starts with + or -, it is taken as relative, which means it is added to the current offset value.
Syntax summary: | SetUnits(mm|mil) |
---|---|
Help text: | Set the default measurement units. |
Registered by: | n/a |
mil | Sets the display units to mils (1/1000 inch). |
---|---|
mm | Sets the display units to millimeters. |
Syntax summary: | Tool(Arc|Arrow|Copy|InsertPoint|Line|Lock|Move|None|PasteBuffer) Tool(Poly|Rectangle|Remove|Rotate|Text|Thermal|Via) Tool(Press|Release|Cancel|Stroke) Tool(Save|Restore) |
---|---|
Help text: | Change or use the tool mode. |
Registered by: | n/a |
Selects the tool or changes tool related global states.
<app-specific-tool-name> | Select the indicated tool. Tool names depend on the application and plugins loaded. For example in pcb-rnd one of the valid tool names is Line . |
---|---|
Press | Called when you press the mouse button, or move the mouse. |
Release | Called when you release the mouse button. |
Cancel | Cancels any pending tool activity, allowing you to restart elsewhere. For example, this allows you to start a new line rather than attach a line to the previous line. |
Escape | Similar to Cancel but calling this action a second time will return to the Arrow tool. |
Stroke | If librnd was built with libstroke, this invokes the stroke input method. If not, this will restart a drawing mode if you were drawing, else it will select objects. |
Save | Remembers the current tool. |
Restore | Restores the tool to the last saved tool. |
Syntax summary: | UnloadScript(id) |
---|---|
Help text: | Unload a fungw script |
Registered by: | script plugin |
id is the same that was specified for loadscript . After the call id is released (can be reused for a new LoadScript).