User Tools

Site Tools


geda:file_format_spec

This is an old revision of the document!


Translations of this page are also available in the following languages: Русский.

gEDA/gaf File Format Document

by: Ales V. Hvezda, ahvezda@geda.seul.org

This document is released under GFDL

December 31st, 2003

Overview

This file is the official documentation for the file formats in gEDA/gaf (gschem And Friends). The primary file format used in gEDA/gaf is the schematic/symbol format. Files which end with .sch or .sym are schematics or symbol files. Until there is another file type in gEDA/gaf, then this document will only cover the symbol/schematic file format.
This file format document is current as of gEDA/gaf version 20040111. This document covers file format version 1 and 2.
Note, this file format and any other file formats associated with gEDA are placed under the General Public License (GPL) version 2.0. The gEDA/gaf symbol and schematic file format is Copyright (C) 1998-2004 Ales Hvezda.

Coordinate Space

All coordinates are in mils (1/1000 of an inch). This is an arbitrary decision. Remember in there is no concept of physical lengths/dimensions in schematics and symbols (for schematic capture only).

  • Origin is in lower left hand corner.
  • The size of the coordinate space is unlimited, but it is recommended that all objects stay within (120.0, 90.0) (x, y inches).
  • It is generally advisable to have positive x and y coordinates, however, negative coordinates work too, but not recommended.

The following figure shows how the coordinate space is setup:

:geda:coordinatespace.jpg

X axis increases going to the right. Y axis increase going up. Coordinate system is landscape and corresponds to a sheet of paper turned on its side.

Filenames

Symbols end in .sym. The only symbol filename convention that is used in gEDA/gaf is that if there are multiple instances of a symbol with the same name (like a 7400), then a -1, -2, -3, … -N suffix is added to the end of the filename. Example: 7400-1.sym, 7400-2.sym, 7400-3.sym…
Schematics end in .sch. There used to be a schematic filename convention (adding a -1 .. -N to the end of the basename), but this convention is now obsolete. Schematic filenames can be anything that makes sense to the creator.

Object types

A schematic/symbol file for gEDA/gaf consists of:

  • A version (v) as the first item in the file. This is required.
  • Any number of objects and the correct data. Objects are specified by an “object type”
  • Most objects are a single line, however text objects are two lines long.
  • No blank lines at the end of the file (these are ignored by the tools)
  • For all enumerated types in the gEDA/gaf file formats, the field takes on the numeric value.

The “object type” id is a single letter and this id must start in the first column. The object type id is case sensitive.
The schematic and symbol files share the same file layout. A symbol is nothing more than a collection of primitive objects (lines, boxes, circles, arcs, text, and pins). A schematic is a collection of symbols (components), nets, and buses.
The following sections describe the specifics of each recognized object type. Each section has the name of the object, which file type (sch/sym) the object can appear in, the format of the data, a description of each individual field, details and caveats of the fields, and finally an example with description.
For information on the color index (which is used in practically all objects), see the Color section.

version

Valid in: Schematic and Symbol files
type version fileformat_version

Pos.FieldType/unitDescription
# typecharv
1 versionintversion of gEDA/gaf that wrote this file
2 fileformat_versionintgEDA/gaf file format version number
  • The type is a lower case “v” (as in Victor).
  • This object must be in every file used or created by the gEDA/gaf tools.
  • The format of the first version field is YYYYMMDD.
  • The version number is not an arbitrary timestamp. Do not make up a version number and expect the tools to behave properly.
  • The “version of gEDA/gaf that wrote this file” was used in all versions of gEDA/gaf up to 20030921 as the file formats version. This field should no longer be used to determine the file format. It is used for information purposes only now.
  • Starting at and after gEDA/gaf version 20031004, the fileformat version field is used to determine the file format version. All file format code should key off of this field.
  • fileformat version increases when the file format changes.
  • The starting point for fileformat version was 1. The current fileformat is 2.
  • fileformat version is just an integer with no minor number.
  • Development versions include: 19990601, 19990610, 19990705, 19990829, 19990919, 19991011, 20000220, 20000704, 20001006, 20001217, 20010304, 20010708, 20010722, 20020209, 20020414, 20020527, 20020825, 20021103, 20030223, 20030525, 20030901, 20040111, 20040710, 20041228, 20050313, 20050820, 20060123, 20060824, 20060906, 20061020, 20070216, 20070705, 20070708, 20070818, 20071229, 20080110, 20080127, 20080706, 20081220, 20081221, 20090328, 20090829, 20090830, 20110116, 20110619, 20111231
  • Stable versions include: 20070526, 20070626, 20070902, 20071231, 20080127, 20080929, 20081220, 20081231, 20091004, 20100214, 20110115
  • CVS or test versions (should not be used): 20030921, 20031004, 20031019, 20031231, 20050814
  • Keep in mind that each of the above listed versions might have had file format variations. This document only covers the last version's file format.

Example:

v 20040111 1

line

Valid in: Schematic and Symbol files
type x1 y1 x2 y2 color width capstyle dashstyle dashlength dashspace

Pos.FieldType/unitDescription
# typecharL
1 x1int/milsFirst X coordinate
2 y1int/milsFirst Y coordinate
3 x2int/milsSecond X coordinate
4 y2int/milsSecond Y coordinate
5 colorintColor index
6 widthint/milsWidth of line
7 capstyleintLine cap style
8 dashstyleintType of dash style
9 dashlengthint/milsLength of dash
10 dashspaceint/milsSpace inbetween dashes
  • The capstyle is an enumerated type:
    • END NONE = 0
    • END SQUARE = 1
    • END ROUND = 2
  • The dashstyle is an enumerated type:
    • TYPE SOLID = 0
    • TYPE DOTTED = 1
    • TYPE DASHED = 2
    • TYPE CENTER = 3
    • TYPE PHANTOM = 4
  • The dashlength parameter is not used for TYPE SOLID and TYPE DOTTED. This parameter should take on a value of -1 in these cases.
  • The dashspace parameter is not used for TYPE SOLID. This parameter should take on a value of -1 in these case.

Example:

L 23000 69000 28000 69000 3 40 0 1 -1 75

A line segment from (23000, 69000) to (28000, 69000) with color index 3, 40 mils thick, no cap, dotted line style, and with a spacing of 75 mils in between each dot.

picture

Valid in: Schematic and Symbol files
type x1 y1 width height angle mirrored embedded
filename
[encoded picture data
encoded picture end]

Pos.FieldType/unitDescription
# typecharG
1 xint/milsLower left X coordinate
2 yint/milsLower left Y coordinate
3 widthint/milsWidth of the picture
4 heightint/milsHeight of the picture
5 angleint/degreesAngle of the picture
6 mirroredcharMirrored or normal picture
7 embeddedcharEmbedded or link to the picture file
8 filenamestringpath and filename of a not embedded picture
9 encoded picture datastringSerialized picture encoded using base64
10 encoded picture endstringA line containing only a dot character
  • This object is a picture object. The first line contains all the picture parameters, and the second line is the path and filename of the picture. The filename is not used if the picture is embedded.
  • The angle of the picture can only take on one of the following values: 0, 90, 180, 270.
  • The mirrored field is an enumerated type:
    • NOT MIRRORED = 0
    • MIRRORED = 1
  • The embedded field is an enumerated type:
    • NOT EMBEDDED = 0
    • EMBEDDED = 1 (not yet supported)
  • The encoded picture and encoded picture end fields are only in the file if the picture is embedded in the schematic:
    • encoded picture data: This is a multiple line field. The picture is serialized and then encoded using base64. This way the encoded data uses only printable characters. This field is the result of these two operations.
    • encoded picture end : A line containing only a single dot '.' character marks the end of the encoded picture data.

Example 1:

G 16900 35800 1400 2175 0 0 0
../bitmaps/logo.jpg

A picture object with the lower left corner at (16900, 35800). The width of the image is 1400 mils, and its height is 2175 mils. The picture rotation is 0 degrees and the picture is not mirrored, neither embedded.
The picture path and filename is showed in the second line.

Example 2:

G 16900 35800 1400 2175 0 0 1
../bitmaps/logo.jpg
AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB
.

A picture object with the lower left corner at (16900, 35800). The width of the image is 1400 mils, and its height is 2175 mils.
The picture rotation is 0 degrees, it is not mirrored, and it is embedded.
The picture path and filename is showed in the second line. Since this is an embedded picture, the filename and path are not used.
The encoded picture data is only an example (it is not real data). The last line containing a single dot '.' character marks the end of the encoded picture data.

box

Valid in: Schematic and Symbol files
type x y width height color width capstyle dashstyle dashlength dashspace filltype fillwidth angle1 pitch1 angle2 pitch2

Pos.FieldType/unitDescription
# typecharB
1 xint/milsLower left hand X coordinate
2 yint/milsLower left hand Y coordinate
3 widthint/milsWidth of the box (x direction)
4 heightint/milsHeight of the box (y direction)
5 colorintColor index
6 widthint/milsWidth of lines
7 capstyleint/milsLine cap style
8 dashstyleintType of dash style
9 dashlengthint/milsLength of dash
10 dashspaceint/milsSpace inbetween dashes
11 filltypeintType of fill
12 fillwidthint/milsWidth of the fill lines
13 angle1int/degreesFirst angle of fill
14 pitch1int/milsFirst pitch/spacing of fill
15 angle2int/degreesSecond angle of fill
16 pitch2int/milsSecond pitch/spacing of fill
  • The capstyle is an enumerated type:
    • END NONE = 0
    • END SQUARE = 1
    • END ROUND = 2
  • The dashstyle is an enumerated type:
    • TYPE SOLID = 0
    • TYPE DOTTED = 1
    • TYPE DASHED = 2
    • TYPE CENTER = 3
    • TYPE PHANTOM = 4
  • The dashlength parameter is not used for TYPE SOLID and TYPE DOTTED. This parameter should take on a value of -1 in these cases.
  • The dashspace parameter is not used for TYPE SOLID. This parameter should take on a value of -1 in these case.
  • The filltype parameter is an enumerated type:
    • FILLING HOLLOW = 0
    • FILLING FILL = 1
    • FILLING MESH = 2
    • FILLING HATCH = 3
    • FILLING VOID = 4 unused
  • If the filltype is 0 (FILLING HOLLOW), then all the fill parameters should take on a value of -1.
  • The fill type FILLING FILL is a solid color fill.
  • The two pairs of pitch and spacing control the fill or hatch if the fill type is FILLING MESH.
  • Only the first pair of pitch and spacing are used if the fill type is FILLING HATCH.

Example:

B 33000 67300 2000 2000 3 60 0 2 75 50 0 -1 -1 -1 -1 -1

A box with the lower left hand corner at (33000, 67300) and a width and height of (2000, 2000), color index 3, line width of 60 mils, no cap, dashed line type, dash length of 75 mils, dash spacing of 50 mils, no fill, rest parameters unset.

circle

Valid in: Schematic and Symbol files
type x y radius color width capstyle dashstyle dashlength dashspace filltype fillwidth angle1 pitch1 angle2 pitch2

Pos.FieldType/unitDescription
# typecharV
1 xint/milsCenter X coordinate
2 yint/milsCenter Y coordinate
3 radiusint/milsRadius of the circle
4 colorintColor index
5 widthint/milsWidth of circle line
6 capstyleint/mils0 unused
7 dashstyleintType of dash style
8 dashlengthint/milsLength of dash
9 dashspaceint/milsSpace inbetween dashes
10 filltypeintType of fill
11 fillwidthint/milsWidth of the fill lines
12 angle1int/degreesFirst angle of fill
13 pitch1int/milsFirst pitch/spacing of fill
14 angle2int/degreesSecond angle of fill
15 pitch2int/milsSecond pitch/spacing of fill
  • The dashstyle is an enumerated type:
    • TYPE SOLID = 0
    • TYPE DOTTED = 1
    • TYPE DASHED = 2
    • TYPE CENTER = 3
    • TYPE PHANTOM = 4
  • The dashlength parameter is not used for TYPE SOLID and TYPE DOTTED. This parameter should take on a value of -1 in these cases.
  • The dashspace parameter is not used for TYPE SOLID. This parameter should take on a value of -1 in these case.
  • The filltype parameter is an enumerated type:
    • FILLING HOLLOW = 0
    • FILLING FILL = 1
    • FILLING MESH = 2
    • FILLING HATCH = 3
    • FILLING VOID = 4 unused
  • If the filltype is 0 (FILLING HOLLOW), then all the fill parameters should take on a value of -1.
  • The fill type FILLING FILL is a solid color fill.
  • The two pairs of pitch and spacing control the fill or hatch if the fill type is FILLING MESH.
  • Only the first pair of pitch and spacing are used if the fill type is FILLING HATCH.

Example:

V 38000 67000 900 3 0 0 2 75 50 2 10 20 30 90 50

A circle with the center at (38000, 67000) and a radius of 900 mils, color index 3, line width of 0 mils (smallest size), no cap, dashed line type, dash length of 75 mils, dash spacing of 50 mils, mesh fill, 10 mils thick mesh lines, first mesh line: 20 degrees, with a spacing of 30 mils, second mesh line: 90 degrees, with a spacing of 50 mils.

arc

Valid in: Schematic and Symbol files
type x y radius startangle sweepangle color width capstyle dashstyle dashlength dashspace

Pos.FieldType/unitDescription
# typecharA
1 xint/milsCenter X coordinate
2 yint/milsCenter Y coordinate
3 radiusint/milsRadius of the arc
4 startangleint/degreesStarting angle of the arc
5 sweepangleint/degreesAmount the arc sweeps
6 colorintColor index
7 widthint/milsWidth of circle line
8 capstyleintCap style
9 dashstyleintType of dash style
10 dashlengthint/milsLength of dash
11 dashspaceint/milsSpace inbetween dashes
  • The startangle can be negative, but not recommended.
  • The sweepangle can be negative, but not recommended.
  • The capstyle is an enumerated type:
    • END NONE = 0
    • END SQUARE = 1
    • END ROUND = 2
  • The dashstyle is an enumerated type:
    • TYPE SOLID = 0
    • TYPE DOTTED = 1
    • TYPE DASHED = 2
    • TYPE CENTER = 3
    • TYPE PHANTOM = 4
  • The dashlength parameter is not used for TYPE SOLID and TYPE DOTTED. This parameter should take on a value of -1 in these cases.
  • The dashspace parameter is not used for TYPE SOLID. This parameter should take on a value of -1 in these case.

Example:

A 30600 75000 2000 0 45 3 0 0 3 75 50

An arc with the center at (30600, 75000) and a radius of 2000 mils, a starting angle of 0, sweeping 45 degrees, color index 3, line width of 0 mils (smallest size), no cap, center line type, dash length of 75 mils, dash spacing of 50 mils.

text and attributes

Depending on context, text objects can play different roles. Outside any environment, they represent informative lines of text. When enclosed by curly braces, they are interpreted as attributes. See the attributes section.

Valid in: Schematic and Symbol files
type x y color size visibility show_name_value angle alignment num_lines
string line 1
string line 2
string line 3

string line N

Pos.FieldType/unitDescription
# typecharT
1 xint/milsFirst X coordinate
2 yint/milsFirst Y coordinate
3 colorintColor index
4 sizeint/pointsSize of text
5 visibilityintVisibility of text
6 show_name_valueintAttribute visibility control
7 angleint/degreesAngle of the text
8 alignmentintAlignment/origin of the text
9 num_linesintNumber of lines of text (1 based)
10 string line 1 … NstringThe text strings, on a separate line
  • This object is a multi line object. The first line contains all the text parameters and the subsequent lines are the text strings.
  • There must be exactly num lines of text following the T … string.
  • The maximum length of any single text string is 1024, however there is no limit to the number of text string lines.
  • The minimum size is 2 points (1/72 of an inch).
  • There is no maximum size.
  • The coordinate pair is the origin of the text item.
  • The visibility field is an enumerated type:
    • INVISIBLE = 0
    • VISIBLE = 1
  • The show_name_value is an enumerated type:
    • SHOW NAME VALUE = 0 (show both name and value of an attribute)
    • SHOW VALUE = 1 (show only the value of an attribute)
    • SHOW NAME = 2 (show only the name of an attribute)
  • The show_name_value field is only valid if the string is an attribute (string has to be in the form: name=value to be considered an attribute).
  • The angle of the text can only take on one of the following values: 0, 90, 180, 270. A value of 270 will always generate upright text.
  • The alignment/origin field controls the relative location of the origin.
  • The alignment field can take a value from 0 to 8.
    The following diagram shows what the values for the alignment field mean:

fileformat_textgraphic.jpg

  • The num_lines field always starts at 1.
    The num_lines field was added starting with file format version 1. Past versions (0 or earlier) only supported single line text objects.
  • The text strings of the string line(s) can have overbars if the text is embedded in two overbar markers “\_”. A single backslash needs to be written as “\\”.

Example 1:

T 16900 35800 3 10 1 0 0 0 1
Text string!

A text object with the origin at (16900, 35800), color index 3, 10 points in size, visible, attribute flags not valid (not an attribute), origin at lower left, not rotated, string: Text string!

Example 2:

T 16900 35800 3 10 1 0 0 0 5
Text string line 1
Text string line 2
Text string line 3
Text string line 4
Text string line 5

This is a similar text object as the above example, however here there are five lines of text.

Example 3:

T 10000 20000 3 10 1 1 8 90 1
pinlabel=R/\_W\_

A text object with the origin at (10000, 20000), color index 3, 10 points in size, visible, only the value of the attribute is visible, text origin at upper right, the text is rotated by 90 degree, the string: “R/W” has an overbar over the “W”.

net

Valid in: Schematic files ONLY
type x1 y1 x2 y2 color

Pos.FieldType/unitDescription
# typecharN
1 x1int/milsFirst X coordinate
2 y1int/milsFirst Y coordinate
3 x2int/milsSecond X coordinate
4 y2int/milsSecond Y coordinate
5 colorintColor index
  • Nets can only appear in schematic files.
  • You cannot have a zero length net (the tools will throw them away).

Example:

N 12700 29400 32900 29400 4

A net segment from (12700, 29400) to (32900, 29400) with color index 4.

bus

Valid in: Schematic files ONLY
type x1 y1 x2 y2 color ripperdir

Pos.FieldType/unitDescription
# typecharU
1 x1int/milsFirst X coordinate
2 y1int/milsFirst Y coordinate
3 x2int/milsSecond X coordinate
4 y2int/milsSecond Y coordinate
5 colorintColor index
6 ripperdirintDirection of bus rippers
  • The ripperdir field for an brand new bus is 0.
  • The ripperdir field takes on a value of 1 or -1 when a net is connected to the bus for the first time. This value indicates the direction of the ripper symbol. The ripper direction is set to the same value for the entire life of the bus object.
  • Buses can only appear in schematic files.
  • You cannot have a zero length bus (the tools will throw them away).

Example:

U 27300 37400 27300 35300 3 0

A bus segment from (27300, 37400) to (27300, 35300) with color index 3 and no nets have been connected to this bus segment.

pin

Valid in: Symbol files ONLY
type x1 y1 x2 y2 color pintype whichend

Pos.FieldType/unitDescription
# typecharP
1 x1int/milsFirst X coordinate
2 y1int/milsFirst Y coordinate
3 x2int/milsSecond X coordinate
4 y2int/milsSecond Y coordinate
5 colorintColor index
6 pintypeintType of pin
7 whichendintSpecifies the active end
  • The pintype is an enumerated type:
    • NORMAL PIN = 0
    • BUS PIN = 1 unused
  • The whichend specifies which end point of the pin is the active connection port. Only this end point can have other pins or nets connected to it.
  • To make the first end point active, whichend should be 0, else to specify the other end, whichend should be 1.
  • Pins can only appear in symbol files.
  • Zero length pins are allowed

Example:

P 0 200 200 200 1 0 0

A pin from (0, 200) to (200, 200) with color index 1, a regular pin, and the first point being the active connection end.

component

Valid in: Schematic files ONLY
type x y selectable angle mirror basename

Pos.FieldType/unitDescription
# typecharC
1 xint/milsOrigin X coordinate
2 yint/milsOrigin Y coordinate
3 selectableintSelectable flag
4 angleint/degreesAngle of the component
5 mirrorintMirror around Y axis
6 basenamestringThe filename of the component
  • The selectable field is either 1 for selectable or 0 if not selectable.
  • The angle field can only take on the following values: 0, 90, 180, 270.
  • The angle field can only be positive.
  • The mirror flag is 0 if the component is not mirrored (around the Y axis).
  • The mirror flag is 1 if the component is mirrored (around the Y axis).
  • The just basename is the filename of the component. This filename is not the full path.

Example:

C 18600 19900 1 0 0 7400-1.sym

A component who's origin is at (18600,19900), is selectable, not rotated, not mirrored, and the basename of the component is 7400-1.sym.

path

Valid in: Schematic and Symbol files
Valid since: Fileformat version 2 (release 1.5.1)
type color width capstyle dashstyle dashlength dashspace filltype fillwidth angle1 pitch1 angle2 pitch2 numlines
path data line 1
path data line 2
path data line 3

path data line N

Pos.FieldType/unitDescription
# typecharH
1 colorintColor index
2 widthint/milsWidth of line
3 capstyleintLine cap style
4 dashstyleintType of dash style
5 dashlengthint/milsLength of dash
6 dashspaceint/milsSpace inbetween dashes
7 filltypeintType of fill
8 fillwidthint/milsWidth of the fill lines
9 angle1int/degreesFirst angle of fill
10 pitch1int/milsFirst pitch/spacing of fill
11 angle2int/degreesSecond angle of fill
12 pitch2int/milsSecond pitch/spacing of fill
13 num_linesintNumber of lines of path data (1 based)
14 path data line 1 … Npath dataThe path data, on separate lines
  • The capstyle is an enumerated type:
    • END NONE = 0
    • END SQUARE = 1
    • END ROUND = 2
  • The dashstyle is an enumerated type:
    • TYPE SOLID = 0
    • TYPE DOTTED = 1
    • TYPE DASHED = 2
    • TYPE CENTER = 3
    • TYPE PHANTOM = 4
  • The dashlength parameter is not used for TYPE SOLID and TYPE DOTTED. This parameter should take on a value of -1 in these cases.
  • The dashspace parameter is not used for TYPE SOLID. This parameter should take on a value of -1 in these case.
  • The filltype parameter is an enumerated type:
    • FILLING HOLLOW = 0
    • FILLING FILL = 1
    • FILLING MESH = 2
    • FILLING HATCH = 3
    • FILLING VOID = 4 unused
  • If the filltype is 0 (FILLING HOLLOW), then all the fill parameters should take on a value of -1.
  • The fill type FILLING FILL is a solid color fill.
  • The two pairs of pitch and spacing control the fill or hatch if the fill type is FILLING MESH.
  • Only the first pair of pitch and spacing are used if the fill type is FILLING HATCH.
  • The format of path data is deliberately similar to that of paths in the W3C SVG standard.
  • The subset of the SVG path syntax emitted by gEDA is documented below in section Path Data.
  • As an implementation detail; libgeda takes code from librsvg, an SVG parsing library. As a result, the majority of SVG path syntax is read correctly, however this is always normalised to absolute move, line, Bézier curve and close-path commands internally (and is saved as such).
  • Coordinates along the path are specified in the standard gschem coordinate space.

Example:

H 3 10 0 0 -1 -1 0 -1 -1 -1 -1 -1 5
M 410,240
L 501,200
L 455,295
L 435,265
z

A path starting at (410,240) with lines drawn from there, and joining points (501,200), (455,295), (435,265), closing back to its origin. It has color index 3, is 10 mils thick, no cap, solid style. There are 5 lines of path data.

font

Valid in: Special font files ONLY
type character width flag

Pos.FieldType/unitDescription
# typecharF
1 charactercharThe character being defined
2 widthint/milsWidth of the character (mils)
3 flagintSpecial space flag
  • This is a special tag and should ONLY show up in font definition files.
  • If the font character being defined is the space character (32) then flag should be 1, otherwise 0.

Example:

F 11 1

The above font definition is for the space character.

Colors

In the gEDA/gaf schematic and symbol file format colors are specified via an integer index. The relationship between integer and color is based on object type. Each object type typically has one or more colors. Here is a table of color index to object type:

IndexObject type
0BACKGROUND_COLOR
1PIN_COLOR
2NET_ENDPOINT_COLOR
3GRAPHIC_COLOR
4NET_COLOR
5ATTRIBUTE_COLOR
6LOGIC_BUBBLE_COLOR
7DOTS_GRID_COLOR
8DETACHED_ATTRIBUTE_COLOR
9TEXT_COLOR
10BUS_COLOR
11SELECT_COLOR
12BOUNDINGBOX_COLOR
13ZOOM_BOX_COLOR
14STROKE_COLOR
15LOCK_COLOR
16OUTPUT_BACKGROUND_COLOR
17FREESTYLE1_COLOR
18FREESTYLE2_COLOR
19FREESTYLE3_COLOR
20FREESTYLE4_COLOR
21JUNCTION_COLOR
22MESH_GRID_MAJOR_COLOR
23MESH_GRID_MINOR_COLOR

The actual color associated with the color index is defined on a per tool bases. Objects are typically assigned their corresponding color index, but it is permissible (sometimes) to assign other color index values to different object types.

Attributes

Attributes are enclosed in braces {} and can only be text. Attributes are text items which take on the form name=value. If it doesn't have name=value, it's not an attribute. Attributes are attached to the previous object. Here's an example:

P 300 700 0 700 1 0 1
{
T 200 750 5 8 1 1 0 6 1
pinnumber=1
T 200 650 5 8 0 1 0 8 1
pinseq=1
}

The object is a pin which has an attribute pinnumber=3 and pinseq=3 (name=value). You can have multiple text objects (both the T … and text string are required) in between the braces {}. As of 20021103, you can only attached text items as attributes. Attaching other object types as attributes is unsupported.
You can also have “toplevel” attributes. These attributes are not attached to any object, but instead are just text objects that take on the form name=value.
These attributes are useful when you need to convey some info about a schematic page or symbol and need the netlister to have access to this info.

Embedded Components

Embedded components are components which have all of their definition stored within the schematic file. When a users place a component onto a schematic page, they have the option of making the component embedded. Other than storing all the symbol information inside of the schematic, an embedded component is just any other component. Embedded components are defined as:

C 18600 21500 1 0 0 EMBEDDED555-1.sym
[
...
... Embedded primitive objects
...
]

In the example above, 555-1.sym is the component. The EMBEDDED tag and the [ ] are the distinguishing characteristics of embedded components. componentname.sym must exist in one of the specified component-libraries if you want to unembed the component.

Path data

The gEDA/gaf path data format has been deliberately specified to match a subset of that in the W3C SVG standard..

  • As an implementation detail; libgeda takes code from librsvg, an SVG parsing library. As a result, the majority of SVG path syntax is read correctly, however this is always normalised to absolute move, line, Bézier curve and close-path commands internally (and is saved as such).
  • Coordinates along the path are specified in the standard gschem coordinate space.
  • Those path commands which gEDA emits, and will guarantee to parse, are listed in the table below:
    (Text taken from the above SVG specification).
  • In the table below, the following notation is used:
    • (): grouping of parameters
    • +: 1 or more of the given parameter(s) is required
CommandNameParametersDescription
M (absolute)moveto(x,y)+Start a new sub-path at the given (x,y) coordinate. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands.
L (absolute)lineto(x,y)+Draw a line from the current point to the given (x,y) coordinate which becomes the new current point. L (uppercase) indicates that absolute coordinates will follow; l (lowercase) indicates that relative coordinates will follow. A number of coordinates pairs may be specified to draw a polyline. At the end of the command, the new current point is set to the final set of coordinates provided.
C (absolute)curveto(x1,y1 x2,y2 x,y)+Draws a cubic Bézier curve from the current point to (x,y) using (x1,y1) as the control point at the beginning of the curve and (x2,y2) as the control point at the end of the curve. C (uppercase) indicates that absolute coordinates will follow; c (lowercase) indicates that relative coordinates will follow. Multiple sets of coordinates may be specified to draw a polybézier. At the end of the command, the new current point becomes the final (x,y) coordinate pair used in the polybézier.
Z or zclosepath(none)Close the current subpath by drawing a straight line from the current point to current subpath's initial point.
  • gEDA's output currently emits only the absolute coordinate versions of the above commands.
  • gEDA's output currently emits the commands, M, L, C before every set of coordinates, even where they could be omitted according to the SVG specification.
  • gEDA's output places commas between x,y coordinates. These may be replaced with whitespace according to the SVG specification.
  • gEDA's does not currently support more than one sub-path.
  • gEDA currently emits one path data line per command + coordinate set.

As example, lets draw the outline of an AND gate. The path data is:

M 100,100 L 500,100 C 700,100 800,275 800,400
C 800,525 700,700 500,700 L 100,700 z

And a complete schematic:

v 20080706 1
H 3 0 0 0 -1 -1 0 2 20 100 -1 -1 6
M 100,100
L 500,100
C 700,100 800,275 800,400
C 800,525 700,700 500,700
L 100,700
z

The resulting path (with control points drawn on to illustrate their positions) is shown here:

Document Revision History

November 30th, 2002Created fleformats.tex from fleformats.html.
December 1st, 2002Continued work on this document.
October 4th, 2003Added new file format version flag info.
October 19th, 2003Added num lines text field.
November 2nd, 2008Added path object, bumping file format version to 2
May 26th, 2011Added a column for the position of parameters in the tables
geda/file_format_spec.1449050024.txt.gz · Last modified: 2015/12/02 04:53 by vzh