1 ==============================================
2 'gschem and Friends' Electronic Design Suite
3 ==============================================
5 Copyright (C) 1998-2013 gEDA Developers
7 This file documents important user-visible changes in gEDA/gaf. For
8 more information, please consult the `ChangeLog' file.
10 Notable changes in gEDA/gaf 1.9.1
11 =================================
13 * Unbalanced overbar markers are now rendered correctly.
15 * Most tools now no longer set the GEDADATA or GEDADATARC environment
16 variables (they still obey them though).
18 * `gschem' now provides a path drawing tool, accessed using <A H> or
19 the "Add Path" menu item.
21 - Add a cusp node by left-clicking.
23 - Add a Bezier curve node by left-dragging from the node point to
26 - End the path by clicking on the same node point twice, or clicking
27 on the start node to close the path.
29 * On desktops that reparent menu bars (e.g. Ubuntu Unity) it is once
30 again possible to paste the clipboard using the menus.
32 * A number of `gschem' editing behaviour changes were made:
34 - Double-clicking on an entry in the "In Use" tab of the component
35 selector now behaves the same way as double-clicking in the
38 - When new attributes are attached to a net, they are placed at a 50
41 - The text color is now used as the default color for `pinlabel='
44 - Pin attributes are no longer automatically replaced when rotating
47 - It is possible to edit a text object even when other non-text
50 - Control grips are now always drawn at the same on-screen size.
52 * `gschem' has new icons for many editing commands.
54 * `gaf export' now accepts a `--scale' option.
56 * The `--size', `--margins' and `--align' options to `gaf export' can
57 now accept their multiple arguments separated with a space ` ', a
58 colon `:' or a semicolon `;'.
60 * `gaf config' now handles the -p option properly.
62 * `gnetlist', `gsymcheck' and `gaf' now output internationalised
65 * New Scheme procedures were added. Please see the "geda-scheme" info
66 manual for more details.
68 - The (gschem action) module contains procedures for working with
69 user editing actions (i.e. commands accessed via the menus or
72 - Two new hooks were added: `bind-keys-hook' is called whenever
73 keymap bindings are changed; `action-property-hook' is called when
74 action properties are changed.
76 Notable changes in gEDA/gaf 1.9.0
77 =================================
79 * A new schematic renderer library, `libgedacairo' has been added, and
80 all tools have been updated to use it. Related changes:
82 - The following configuration functions have been removed:
84 output-capstyle paper-sizes
85 output-color postscript-prolog
86 output-orientation print-command
87 output-type setpagedevice-orientation
88 paper-size setpagedevice-pagesize
90 - The following `gschem' configuration items have been added:
92 print-paper print-color
95 - `gschem' now generates PDF files rather than PostScript or EPS
98 - `gschem' now uses a standard GTK print dialog (with printer
99 selection, print preview, etc.)
101 * A new `gaf' command-line utility has been added. It provides a
102 number of subcommands:
104 - `gaf export' can be used to convert schematic files to PNG, SVG,
105 PDF, PS and EPS, with detailed control of paper size and margins.
106 It supports multi-page PDF and PS output.
108 - `gaf config' can be used to manipulate the project, user, and
109 system configuration stores (see below).
111 - `gaf shell' provides a Scheme REPL for batch manipulation of
112 schematic and symbol files.
114 * New project, user and system configuration stores have been added,
115 using a format similar to .desktop files. They can be manipulated
116 using the `gaf config' tool. Configuration parameters for most
117 tools will be converted to use this mechanism in future releases.
119 * The changes to highlighting of dangling net ends in gEDA/gaf 1.8.0
120 have been reverted. All dangling ends are once again flagged with a
121 brightly-coloured square.
123 * When editing a component with the `gschem' multi-attribute editor,
124 the dialog will now show the symbol name in its title.
126 * When using "Down Schematic" command in `gschem', an error message
127 will now be displayed if the subcircuit schematic cannot be loaded.
129 * Printing now uses a light background color map by default.
131 * Objects can now have the line end "cap style" adjusted in `gschem'.
133 * `gnetlist' now accepts the `-i' and `-g' command-line arguments
134 together. If you specify both `-i' and `-g', `gnetlist' will enter
135 the Scheme REPL after loading the requested backend but before
138 * `gattrib' now has translations for the user interface and various
141 Notable changes in gEDA/gaf 1.8.0
142 =================================
144 * `gschem' and `gnetlist' have updated and rewritten user guides.
146 * All tools now give more informative error messages if they are
147 unable to load schematic or symbol files due to syntax errors.
149 * All tools now correctly handle schematic and symbol files with `\r',
150 `\n', or `\r\n` line endings, or a mixture.
152 * Unconnected pin ends and net ends are now all drawn with the same
153 box marker in `gschem' and printed output.
155 * Net segments with at least two connections (including indirect
156 connections via `netname=' attributes) are now drawn with arrowheads
157 rather than box markers on dangling ends in `gschem' and printed
160 Notable changes in gEDA/gaf 1.7.2
161 =================================
163 * `geda-gaf' now requires GTK+ 2.16.0 or later.
165 * A greatly expanded Scheme API has been added to gEDA/gaf for use by
166 extension authors. See the `geda-scheme' Info manual for more
167 details. Existing extensions may need to be modified to load the
168 `(geda deprecated)' or `(gschem deprecated)' modules.
170 * The `component-library-search' function for `gafrc' files now skips
171 directories without symbols, and searches for libraries recursively.
173 * `gschem' keybinding improvements:
175 - Keybindings are now unaffected by Caps Lock.
177 - Keystrokes are displayed using the same characters as on keycaps
178 (e.g. `:' instead of `colon').
180 - Keystrokes may use extended modifiers (Super, Hyper and Meta).
182 - Key bindings can be modified in any rc file or interactively using
183 the `global-set-key' function. See notes in `system-gschemrc' for
186 * `gschem' now displays help files and component documentation on all
187 platforms, including Windows. The `locate' tool is no longer used
188 to search for component documentation files.
190 * The `schdiff' tool for generating visual diffs of schematics and
191 symbols has been added. It can be used with most version control
192 systems. See `man schdiff' for more details.
194 * The `bom' and `bom2' backends to `gnetlist' now give error messages
195 if no attribute file can be found. The `-O attrib_file=FILE' and
196 `-O attribs=ATTRIB,ATTRIB...' options have also been added.
198 * A new `ewnet' backend has been added to `gnetlist'. This outputs
199 netlists for use with the National Instruments ULTIboard layout
202 * The `verilog' backend to `gnetlist' now supports concatenated net
203 naming like "{a,b,c[3:0]}".
205 * `gsch2pcb' no longer supports the `m4_command' parameter in project
208 * The `--m4-pcbdir' and `--m4-file' arguments to `gsch2pcb' now work
211 * `gsymfix.pl' has been renamed to `gsymfix'.
213 * Man pages are now available for all programs installed as part of
216 * The undocumented programs `gnet_hier_verilog', `gsymupdate', `gschupdate'
217 and `sch2eaglepos.sh' are no longer installed to ${prefix}/bin.
219 Notable changes in gEDA/gaf 1.7.1
220 =================================
222 * gEDA is now compatible with Guile 2.0.
224 * gEDA/gaf applications no longer complain when trying to load an rc
225 file twice, or when an rc file doesn't exist.
227 * `gschem' allows objects to be moved by dragging without having to
230 * `gschem' now supports keybindings with more than one modifier key,
231 and "Deselect" is bound to <Control Shift A> by default.
233 * `gnetlist' correctly handles multiple renames of the same net. This
234 resolves some long-standing bugs with multipage schematics.
236 * The `spice-sdb' backend for `gnetlist' now has built-in support for
237 `SUBCKT_NMOS' and `SUBCKT_PMOS' devices.
239 * A new `makedepend' backend has been added to `gnetlist'. It
240 generates Makefile code for SPICE simulation dependencies.
242 * Visibility of embedded component attributes are now preserved by
245 * `gsch2pcb' correctly handles footprint names with hyphens (`-').
247 * `gsch2pcb' project files support quoting and escaping in
248 `schematics' entries.
250 * Considerable enhancements to Unicode support when printing
251 schematics or exporting PostScript.
253 Notable changes in gEDA/gaf 1.7.0
254 =================================
256 * All gEDA/gaf applications now handle configuration files much more
257 strictly, and provide much more useful feedback when an error
260 * Several changes to `gschem' command-line options:
262 - The `-t' option is no longer supported.
264 - Several command-line options now support a long-form alternative.
266 - The `-s' option can now be used to run multiple Scheme scripts
267 during `gschem' startup.
269 - A new `-c' option is available, which runs a Scheme expression
270 during `gschem' startup.
272 - A new `-L' option is available, which adds a directory to the
275 - A new `-V' or `--version' option is available, which displays
278 * `gschem' now provides a "Select All" function, which is bound to
279 <Control a> by default, along with a corresponding "Deselect"
282 * In the `gschem' "Add component" dialog, filtering the component
283 library will expand matching libraries. If the filter is cancelled,
284 all libraries are collapsed. Components can now be selected by
285 double-clicking on them in the component list.
287 * The `gschem' "Edit Text Properties" dialog now has an easier to use
290 * Printed text size now better matches on-screen text size in
293 * Special characters, including commas, are now escaped or quoted
294 appropriately in `gattrib' CSV output.
296 * Several changes to `gnetlist' command-line options:
298 - Four command-line options specific to the `spice-sdb' backend have
299 been removed. They can be replaced with `-O <option>' according
300 to the following table:
302 -e, --embedd -O embedd_mode
303 -I, --include -O include_mode
304 -n, --nomunge -O nomunge_mode
305 -s, --sort -O sort_mode
307 - The list of available backends is now obtained using a new
308 `--list-backends' option. `-g help' no longer outputs a list of
311 - A new `-L' option is available, which adds a directory to the
314 - A new `-V' or `--version' option is available, which displays
317 - When run with invalid command-line arguments, `gnetlist' now exits
318 with non-zero exit status.
320 * Several `gnetlist' backends have now been fixed so that it should no
321 longer be necessary to set an expanded Guile stack in gEDA's config
324 * The `spice-sdb' backend for `gnetlist' now supports probes
325 (`TESTPOINT' devices).
327 * The undocumented `mk_verilog_syms' program is no longer installed.
328 The symbols it creates are still installed to
329 `${prefix}/share/gEDA/sym/verilog'.
331 Notable changes in gEDA/gaf 1.6.2
332 =================================
334 * PNG export from `gschem' will now be cropped correctly.
336 * The `partlist' backends for `gnetlist' now handle hierarchical
339 * On Windows, `gschem' and `gattrib' will no longer launch with a
340 command window visible.
342 * `gnetlist-arg' is no longer valid in `gsch2pcb' project files.
344 Several other bugs were fixed, including a major crash bug in
347 Notable changes in gEDA/gaf 1.6.1
348 =================================
350 * Added accelerator mnemonics for root menus in gschem
352 * Lots of updated and new language translations in libgeda, gschem, and
353 gattrib. (Courtesy of language translators and Launchpad)
355 * Updated the shipped documentation from the official gEDA wiki
357 * Fixed the following bugs:
359 - 2876373: Fix rendering with zoomed out dashed lines
360 - 2901183: Fix for some manpage issues
361 - 2904715: Don't update page connectivity from o_place_rotate()
362 - 2949232: Fix slot editing routines to not edit inherited attributes
363 - Cherry picked some other bug fixes from master that should be in
366 Notable changes in gEDA/gaf 1.6.0
367 =================================
369 * Fixed the GtkItemEntry code inside of gattrib code so that it builds
372 * In gschem, rubberband pin to pin connections by adding nets.
374 * Cleanup of the slot handling code in libgeda.
376 * Fixes/updates to the MinGW port.
378 * Updated the shipped documentation from the online wiki.
380 Notable changes in gEDA/gaf 1.5.3/1.5.4
381 =======================================
383 * NOTE: gEDA/gaf 1.5.3 was released with some critical bugs, so
384 it was withdrawn before it was widely distributed.
386 * Text rendering using native system fonts:
388 - The various programs in gEDA/gaf no longer uses its own built-in
391 - Native system fonts are used for rendering, giving support for a
392 wider range of symbols, and better looking schematics.
394 * Always use PostScript fonts in gschem's PostScript output. The
395 "output-text", "text-output" and "output-vector-threshold" config
396 functions have been removed.
398 * Image rendering in 'gschem' uses cairo instead of GDK.
400 * Numerous build system changes:
402 - gEDA/gaf is now distributed as a single source archive, called
403 gEDA-<version>.tar.gz.
405 - GTK+ 2.10 or newer and Guile 1.8 or newer are now required.
407 - `intltool' is no longer required.
409 - Documentation is now installed to ${docdir} (usually
410 ${prefix}/share/doc/gEDA).
412 * The attribute edit dialog in `gschem' now has completion of most
413 common attribute names.
415 * The multi-attribute edit dialog in `gschem' now shows unpromoted
418 * Menu items in `gschem' now have icons and properly aligned key
419 bindings. They also support accelerator keys.
421 * The `gschem2pcb' and `PCBboard' netlist backends have been removed.
422 It is recommended to use `gsch2pcb' instead.
424 * Check for and reject non-footprint PCB files in 'gsch2pcb'.
426 * Removed unimplemented "File->Open" feature in 'gattrib'.
428 * Added --disable-gattrib command line flag to ./configure to disable the
429 building of 'gattrib'. This is useful if you are building against
430 gtk+ 2.17.x which breaks 'gattrib'.
432 * 'gnetlist' does not recommend drc2 every time it runs. The drc2
433 backend is only useful in certain circumstances.
435 * Assign shortcuts "vd" and "vl" for changing between color schemes
438 * Fix problem with attached net attribute not being honored in 'gnetlist'.
440 * Focus the "save" button in the close confirmation dialog in 'gattrib' and
443 * Accept empty attributes in the src file in 'tragesym'.
445 * Cleaned up the slot dialog box in 'gschem'.
447 * Changed the grip size rendering in 'gschem' to be reasonably sized when
450 * Introduction of a new attribute searching API in 'libgeda' and 'gschem'.
452 * Improvements and cleanup to the 'gnetlist' and 'gsymcheck' test suites.
454 * Fixed the following bugs:
456 - 1758673: Combine source tarballs
457 - 2058707: gschem, gattrib: Dangerous button focus in "Save changes"
459 - 2430369: gschem: Deselect invisible attribs with their parent object.
460 - 2449060: Graphic state left inconsistent cancelling from net mode
461 - 2460301: libgeda: Make o_complex_promote_attribs() respect keep_invisible
462 and libgeda: Make o_complex_copy() actually copy.
463 - 2455061: Gnetlist output changed, and tests fail with recent GLib
464 - 2655088: autogen.sh: Make sure to exit if autopoint fails.
465 - 2823703: gnet-pcbpins.scm: Quote pins names if they contain comma
466 or close parenthesis.
467 - 2823755: gnetlist: Fix DEBUG builds.
468 - 2836109: build-sys: Add check for groff html driver.
470 * Spanish translation were updated.
472 * Lots of code, infrastructure, and doxygen documentation cleanup and
475 Notable changes in gEDA/gaf 1.5.2
476 =================================
478 * `gschem' now uses Cairo for all rendering. This allows for
479 everything to be rendered anti-aliased.
481 * `gschem' now uses a mesh grid instead of dots by default.
483 * Net junction cues in `gschem' are drawn smaller now.
485 * Copy and paste now works between different `gschem' instances (using
488 * Recent files are no longer opened in a new `gschem' window.
490 * Major, *backwards-incompatible* changes to color handling in
491 `libgeda' and `gschem'.
493 - All colors are specified using hexadecimal `#RRGGBB' or
496 - The print and display color maps are now separate.
498 - A new Scheme syntax is used to inspect and modify color maps.
500 - If you wish to use a light background in `gschem', add the line:
502 (load (build-path geda-rc-path "gschem-colormap-lightbg"))
504 to your personal or project gschemrc file.
506 * Attributes of embedded objects are now shown in the right color.
508 * Bus pins are now supported by `gschem' and `libgeda', but are *not*
509 properly supported by the netlister. The pin type can be modified
510 by selecting a pin, then right-clicking it and selecting `Edit pin
513 * All of the symbols were modified to use overbar markup tags ("like
514 \_this\_") instead of separate lines.
516 * Log files are now saved to $HOME/.gEDA/logs rather than being
517 dropped in the current directory.
519 Notable changes in gEDA/gaf 1.5.1
520 =================================
522 * GTK+ version 2.8.x or later is now required.
524 * The selection behaviour in `gschem' was changed.
526 - Lines, unfilled boxes, unfilled circles, arcs, pins, nets, and
527 buses must be selected by clicking on the drawn path itself.
529 - Filled boxes, circles, text, and components, may be selected by
530 clicking anywhere in the bounding box.
532 - The default mouse click distance required to select an element was
533 increased to 10 pixels.
535 - Double-clicking on a net segment selects all connected net
538 * The percentage step in or out while zooming the display in `gschem'
539 is now configurable with the `zoom-gain' gschemrc parameter. The
540 default value is 20%.
542 * The size of steps when panning with the mouse wheel or with a
543 trackpad in `gschem' is now adjustable with the `scrollpan-steps'
544 gschemrc parameter. The default setting scrolls in steps of 1/8 of
547 * A number of improvements were made to the `gschem' component
550 - The dialog now shows a table of top-level attributes in the
553 - It is now possible to expand/collapse a library by clicking
556 * Changes to fill- and line-styles in `gschem' can now be undone.
558 * Arcs can now be adjusted in `gschem' using an arc angle dialog. It
559 can be accessed by selecting an arc and selecting Edit->Edit.
561 * It is now possible to rotate objects while placing them in `gschem'.
563 * Support for arbitrary filled and unfilled paths, using a subset of
564 the SVG path syntax. For more information, please see the file
565 format specification.
566 <http://wiki.geda-project.org/geda:file_format_spec>
568 - `gschem' does not yet provide a GUI for creating or editing path
569 elements. However, it does support rendering them. They can also
572 - Some of the symbols in the component library were updated to use
575 * A Scheme evaluation prompt was added to `gschem'. It can be
576 accessed by typing `:'.
578 * Improved algorithm for drawing hatched fills both on screen and in
581 * Color selection dialogs and menus in `gschem' now show the actual
582 color as well as the description. Color names are now translatable.
584 * `gattrib' now prompts to save changes.
586 * All of the unimplemented menu items and pages in `gattrib' were
589 * The `always-promote-attributes' gafrc parameter now takes a list of
590 strings as an argument. The space-delimited string syntax is
593 * Some optimisations were made to the `gnetlist' connection traversal
594 algorithm to speed up netlisting large designs.
596 * A new netlist backend was added to support Liquid PCB.
597 <http://www.liquidpcb.org/>
599 * The `bom2' netlist backend now generates a `qty' column.
601 * Several improvements and fixes were made to the `systemc' backend.
603 * The `--gnetlist-arg' option to gsch2pcb can now be used to pass
604 extra `gnetlist' arguments.
606 * `gsch2pcb' now emits files with the latest `pcb' file format.
608 * The `gxyrs' pick-and-place tool was added.
610 Notable changes in gEDA/gaf 1.5.0
611 =================================
613 * Magnetic net mode in `gschem'. Magnetic mode lets you draw nets and
614 automatically connect to valid end points (such as pins and other
615 nets). The `magnetic-net-mode' gschemrc parameter can be used to
616 enable/disable this feature.
618 * Rotating a component while moving it in `gschem' now rotates around
619 the current mouse location.
621 * The `verilog' and `vhdl' backends now work again.
623 * Embedded components can now be mirrored.
625 * The `pads' netlist backend now uses CRLF line endings.
630 Release notes for older versions of gEDA/gaf are available on the gEDA
631 website. <http://www.gpleda.org/news/index.html>