Update NEWS.
[geda-gaf.git] / NEWS
blob87304f5a135ee4ad2e4106050739c3c760fd9a1c
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
24     the control point.
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
36     "Libraries" tab.
38   - When new attributes are attached to a net, they are placed at a 50
39     unit offset.
41   - The text color is now used as the default color for `pinlabel='
42     attributes.
44   - Pin attributes are no longer automatically replaced when rotating
45     or mirroring pins.
47   - It is possible to edit a text object even when other non-text
48     objects are selected.
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
63   messages.
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
70     keybindings).
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
93          print-orientation
95   - `gschem' now generates PDF files rather than PostScript or EPS
96     files.
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
136   executing it.
138 * `gattrib' now has translations for the user interface and various
139   messages.
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
158   output.
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
184     examples.
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
200   tool.
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
206   files.
208 * The `--m4-pcbdir' and `--m4-file' arguments to `gsch2pcb' now work
209   again.
211 * `gsymfix.pl' has been renamed to `gsymfix'.
213 * Man pages are now available for all programs installed as part of
214   gEDA/gaf.
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
228   select them first.
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
243   `gattrib'.
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
258   occurs.
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
273     Scheme load path.
275   - A new `-V' or `--version' option is available, which displays
276     version information.
278 * `gschem' now provides a "Select All" function, which is bound to
279   <Control a> by default, along with a corresponding "Deselect"
280   function.
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
288   "Alignment" menu.
290 * Printed text size now better matches on-screen text size in
291   `gschem'.
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
309     backends.
311   - A new `-L' option is available, which adds a directory to the
312     Scheme load path.
314   - A new `-V' or `--version' option is available, which displays
315     version information.
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
322   files.
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
337    refdes correctly.
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
345 gnetlist.
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
364     this release
366 Notable changes in gEDA/gaf 1.6.0
367 =================================
369 * Fixed the GtkItemEntry code inside of gattrib code so that it builds
370   using gtk+ > 2.16.x.
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
389     line font.
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
416   symbol attributes.
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
436   in 'gschem'.
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
441   'gschem'.
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
448   zoomed in a lot.
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"
458              dialog at quit
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
473   refactoring.
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
486   the X selection).
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
494     `#RRGGBBAA' syntax.
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
511   type...'.
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
536     segments.
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
545   a screen.
547 * A number of improvements were made to the `gschem' component
548   selection dialog.
550   - The dialog now shows a table of top-level attributes in the
551     selected symbol.
553   - It is now possible to expand/collapse a library by clicking
554     anywhere on its row.
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
570     be printed.
572   - Some of the symbols in the component library were updated to use
573     paths.
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
579   PostScript output.
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
587   removed.
589 * The `always-promote-attributes' gafrc parameter now takes a list of
590   strings as an argument.  The space-delimited string syntax is
591   deprecated.
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.
627 Older versions
628 ==============
630 Release notes for older versions of gEDA/gaf are available on the gEDA
631 website.  <http://www.gpleda.org/news/index.html>
634    Local Variables:
635    mode: text
636    End: