1
0
mirror of git://projects.qi-hardware.com/fped.git synced 2025-01-09 01:00:14 +02:00
Go to file
werner 1613d4bdbc Trying to save arcs would crash fped.
- dump.c (print_obj): removed free(s2) left over from before the reduction of
  allocations



git-svn-id: http://svn.openmoko.org/trunk/eda/fped@5728 99fdad57-331a-0410-800a-d7fa5415bdb3
2009-12-01 01:29:07 +00:00
icons - new visualization option: show all frames or show only current frame 2009-08-22 19:00:55 +00:00
manual - README: added link to the GUI manual 2009-09-13 13:16:39 +00:00
coord.c - added -std=gnu99 so that we can use "round" and M_PI 2009-08-15 20:52:08 +00:00
coord.h - added -std=gnu99 so that we can use "round" and M_PI 2009-08-15 20:52:08 +00:00
cpp.c Moved fped over to /trunk/eda 2009-08-03 16:12:47 +00:00
cpp.h Moved fped over to /trunk/eda 2009-08-03 16:12:47 +00:00
delete.c - destroy_obj: when deleting width expressions, check that they're actually 2009-08-26 14:06:26 +00:00
delete.h - delete.c: added more destructor functions 2009-08-21 08:34:17 +00:00
dump.c Trying to save arcs would crash fped. 2009-12-01 01:29:07 +00:00
dump.h Vector name generation could produce duplicates if vectors were moved or 2009-11-27 19:55:25 +00:00
error.c Added Postscript outout for measurements, plus assorted changes. 2009-08-16 11:21:48 +00:00
error.h Added Postscript outout for measurements, plus assorted changes. 2009-08-16 11:21:48 +00:00
expr.c - delete.c: added more destructor functions 2009-08-21 08:34:17 +00:00
expr.h - when editing a value list, we need to return the values and free them in case 2009-08-16 05:05:12 +00:00
fbga.fpd - postscript.c: always run flattenpath before pathbbox 2009-08-19 22:13:47 +00:00
file.c - added support for string constants to unparse() 2009-08-11 23:26:38 +00:00
file.h - added support for string constants to unparse() 2009-08-11 23:26:38 +00:00
fpd.h - when editing a value list, we need to return the values and free them in case 2009-08-16 05:05:12 +00:00
fpd.l Made life in mil-land a little less painful. 2009-08-22 15:58:58 +00:00
fpd.y - inst.c: cleanup_inst leaked memory when using special pads 2009-09-13 11:11:03 +00:00
fped.c For future extensions. 2009-10-20 23:50:45 +00:00
gui_canvas.c Selection now tries to help us not to get lost. 2009-08-22 12:27:47 +00:00
gui_canvas.h - adjust measurement bbox for projection (still not perfect, but better) 2009-08-16 12:04:01 +00:00
gui_frame.c Vector name generation could produce duplicates if vectors were moved or 2009-11-27 19:55:25 +00:00
gui_frame.h - when selecting an object via the item list, make its frame active 2009-08-12 14:44:17 +00:00
gui_inst.c - gui_inst.c (gui_draw_rpad): when drawing an outline instead of filling, use 2009-10-21 15:04:56 +00:00
gui_inst.h Added Postscript outout for measurements, plus assorted changes. 2009-08-16 11:21:48 +00:00
gui_meas.c Made interactive selection of measurement points a little less inefficient. 2009-08-27 09:01:24 +00:00
gui_meas.h - File>Save now saves to a file if a second name is given on the command line, 2009-08-10 13:51:51 +00:00
gui_over.c - to simplify communication between the various modules, renamed "ctx" to 2009-08-08 14:11:26 +00:00
gui_over.h - to simplify communication between the various modules, renamed "ctx" to 2009-08-08 14:11:26 +00:00
gui_status.c - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui_status.h - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui_style.c Drawing all the pad layers as filled areas can cause confusion. Now we draw 2009-10-19 15:00:30 +00:00
gui_style.h - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui_tool.c Creation of a rounded pad could crash fped. 2009-12-01 01:04:32 +00:00
gui_tool.h - measurement offsets can now use variables. We evaluate the offset during 2009-08-21 18:20:37 +00:00
gui_util.c - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui_util.h - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui.c - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui.h - gui_util.c: make container clean-out globally available as vacate_widget 2009-09-12 23:15:15 +00:00
gui.html - README: added link to the GUI manual 2009-09-13 13:16:39 +00:00
inst.c - inst.c (inst_select): cycle through instances globally, not only within the 2009-11-27 23:31:03 +00:00
inst.h Drawing all the pad layers as filled areas can cause confusion. Now we draw 2009-10-19 15:00:30 +00:00
kicad.c - inst.c: cleanup_inst leaked memory when using special pads 2009-09-13 11:11:03 +00:00
kicad.h - added KiCad output 2009-08-10 21:02:26 +00:00
layer.c - inst.c: cleanup_inst leaked memory when using special pads 2009-09-13 11:11:03 +00:00
layer.h - inst.c: cleanup_inst leaked memory when using special pads 2009-09-13 11:11:03 +00:00
leak.supp - measurement offsets can now use variables. We evaluate the offset during 2009-08-21 18:20:37 +00:00
leakcheck - measurement offsets can now use variables. We evaluate the offset during 2009-08-21 18:20:37 +00:00
Makefile Drawing all the pad layers as filled areas can cause confusion. Now we draw 2009-10-19 15:00:30 +00:00
meas.c - measurement offsets can now use variables. We evaluate the offset during 2009-08-21 18:20:37 +00:00
meas.fpd More work on measurements. Getting there ... 2009-08-09 00:06:54 +00:00
meas.h Finally found a nice way to draw arcs in the GUI. 2009-08-18 20:52:09 +00:00
obj.c - inst.c: cleanup_inst leaked memory when using special pads 2009-09-13 11:11:03 +00:00
obj.h When moving a vector, the list order could get confused, resulting in a 2009-11-27 16:23:35 +00:00
overlap.c - inst.c: cleanup_inst leaked memory when using special pads 2009-09-13 11:11:03 +00:00
overlap.h - the set of layers of a pad is now maintained in the instance, so that we can 2009-09-13 09:58:30 +00:00
postscript.c Creation of a rounded pad could crash fped. 2009-12-01 01:04:32 +00:00
postscript.h - change file save logic to write to a temporary file first, so that we don't 2009-08-11 01:20:15 +00:00
qfn.fpd More work on measurements. Getting there ... 2009-08-09 00:06:54 +00:00
quad.fpd - added menu item "Save" to dump the footprint to stdout 2009-08-06 06:54:41 +00:00
README - README: added link to the GUI manual 2009-09-13 13:16:39 +00:00
sc89.fpd - postscript.c: always run flattenpath before pathbbox 2009-08-19 22:13:47 +00:00
tab.fpd - added menu item "Save" to dump the footprint to stdout 2009-08-06 06:54:41 +00:00
TODO - postscript.c: added some code for frame display, but I'm not happy with it 2009-08-30 06:04:00 +00:00
unparse.c - fixed precedence of unary minus, so that -(a+b) isn't printed as -a+b 2009-08-18 23:49:54 +00:00
unparse.h Moved fped over to /trunk/eda 2009-08-03 16:12:47 +00:00
util.c - delete.c: added more destructor functions 2009-08-21 08:34:17 +00:00
util.h - delete.c: added more destructor functions 2009-08-21 08:34:17 +00:00

fped - Footprint editor
=======================

fped is an editor that allows the interactive creation of footprints of
electronic components. Footprint definitions are stored in a text format
that resembles a programming language.

The language is constrained such that anything that can be expressed in
the textual definition also has a straightforward equivalent operation
that can be performed through the GUI.


Building
--------

Prerequisites:

- bash
- flex
- bison
- fig2dev
- ImageMagick
- Gtk+ 2.x development package (libgtk2.0-dev or similar)
- Liberation Fonts (ttf-liberation or similar)

Check out the repository:

  svn co http://svn.openmoko.org/trunk/eda/fped
  cd fped

Get updates:

  svn update

Compile:

  make dep
  make

Run an example:

  ./fped qfp.fpd


Motivation
----------

KiCad already includes a footprint ("module") editor, so why do we need
a new one ? The issue with footprint generation for KiCad is that the
built-in module editor is basically a drawing program that only captures
the result of the module author's interpretation of a footprint drawing,
but does not include the steps that led to this construction.

Furthermore, accurate measuring of dimensions in the drawing can only be
done manually in the module editor, which makes review difficult and
time-consuming.

In fped, the construction process is made explicit and each step can be
expressed in terms of the parameters that appear in the vendor's
drawing. Dimensions can be explicitly measured and the results can be
included in the graphical output generated by fped.

Directly using parameters and construction steps from the reference
drawing reduces the risk of mistakes. Visualizing the construction
process and verificative measurements helps efficient and accurate
review.


Footprint definition file format
--------------------------------

Footprint definitions are stored in text files. The program "fped" reads
and (soon) writes such files, visualizes their content, and provides a
graphical editor for them.

The syntax is unique and draws from elements of a variety of languages
commonly found on unix systems. One specialty is that there are no
reserved words - the language keywords appear only at the beginning of
a line and can thus be recognized as such without restricting their use
for identifiers. This reduces the risk of creating incompatibilities
with existing designs when introduction future language features.

fped uses the C preprocessor for comments, conditional compilation,
and - to a limited extent - also macros. Long lines can be split by
ending them with a backslash. If multiple items need to be placed in a
single line, e.g., in a macro, they can be separated with semicolons.

The file has the following structure:

frame definitions
...
package name
unit
objects
...


Geometry model
--------------

The geometry model consists of frames, vectors, and objects. The shape of
objects is defined by a number of points. These points are produced by
concatenating vectors.

E.g., to draw a line from (1mm, 1mm) to (2mm, 2mm), one would make a
vector from the origin to (1mm, 1mm) and one either from the origin or
from the previous vector to (2mm, 2mm), and then make a line connecting
the two points.


Units
- - -

fped can calculate in mm and mil. Units are specified by following a
number with "mm" or "mil", separated by zero or more spaces or tabs.

Examples:

1mm
2 mil

Units can be mixed in calculations, e.g.,

set a = 1mm+20mil
set b = 10*1mm

All values used as dimensions must be either mm or mil.

The default unit can be set with one of the following directives:

unit mm
unit mil
unit auto

When saving a footprint definition, the default unit is set to the
unit set in the GUI.


Vectors
- - - -

Vectors can be anonymous or they can be named for future reference:

vec <base> ( <x-expr>, <y-expr> )
<identifier>: vec <base>  ( <x-expr>, <y-expr> )

The base can be one of the following items:

- @ is the origin of the frame containing the vector
- . is the end of the previous vector in this frame
- <identifier> is the name of a previous vector in the same frame

The following example would draw the line described in the previous
section:

a: vec @(1mm, 1mm)
b: vec .(1mm, 1mm)
line a b


Silk screen objects
- - - - - - - - - -

The output of fped is a footprint definition that contains pads and silk
screen drawings (we may add more layers in the future). These items are
called "objects". Their geometry is defined through points obtained with
vectors.

A line connects two points:

line <point-a> <point-b> [<width>]

The points can be specified with @, ., and an identifier, just like
a vector base. The option width specifies the thickness of the silk
screen line. If omitted, a hard-coded default of 15 mil is used.

A rectangle has sides parallel to the x and y axis and is defined
by two diagonally opposite corners:

rect <point-a> <point-b> [<width>]

A circle is defined by its center and a point on the circle:

circ <center> <point> [<width>]

This example draws a unit circle:

vec @(1mm, 0mm)
circ @ .

An arc is like a circle, but the part of the circle drawn is determined
by two points. The first point determines the radius and the starting
angle. The second point only determines the end angle but its distance
from the center is ignored.

arc <center> <radius> <end> [<width>]

The arc is drawn in a counter-clockwise direction. The following example
draws an arc of the unit circle in the x > 0, y > 0 quadrant:

from: vec @(1mm, 0mm)
to: vec @(0mm, 1mm)
arc @ from to


Pads
- -

Pads are similar to rectangles, but they also have a name.

pad "<name>" <point-a> <point-b> [<type>]

Variables can be expanded in a pad's name by prefixing their name with
a dollar sign. The ${name} syntax is also available.

Example:

vec @(1mm, 1mm)
pad "1" @ .

Pads normally affect the surface copper layer, the solder mask layer,
and the solder paste layer. This can be modified with the optional
type argument:

Type		Layers
---------	-------------------------------------
(default)	copper, solder mask, and solder paste
bare		copper and solder mask
paste		solder paste
mask		solder mask


Rounded pads
- - - - - -

Rounded pads are like rectangular pads except that they end with a
semi-circle at each of the smaller sides of the enclosing rectangle.
If enclosed in a square, rounded pads form a circle.

rpad "<name>" <point-a> <point-b> [<type>]


Measurements
- - - - - -

*** This is obsolete - see the section on new-style mesurements at the end. ***

Measurements show the distance between two points:

meas <point-a> <point-b> <offset>

The offset is the distance from the imaginary line connecting points A
and B the measurement line is draw:

- if the offset is 0mm, the line will connect A and B
- if the offset is positive, the line would be on the left-hand side when
  traveling from A to B
- if the offset is negative , the line would be on the right-hand side when
  traveling from A to B

Example:

a: vec @(-1mm, 1mm)
b: vec @(1mm, 1mm)
meas a b 0.2 mm


Package name
- - - - - -

The package name is a string of printable ASCII characters, including
spaces.

package "<name>"

Examples:

package "48-SSOP"
package "0603"

Like in pad names, variables are expanded in package names. This allows
the generation of multiple packages from a single definition.


Frames
- - -

Frames are used to group things and to reuse them multiple times. Frames
must be defined before they can be used:

frame <name> {
    ... items ...
}

Once defined, a frame is placed at a given location with

frame <name> <point>

The frame definitions must precede all other items in a footprint
description. Frames cannot be defined inside other frames, but frames
can invoke each other recursively.

For example, this puts two unity squares, one centered at (0 mm, 0 mm),
the other at (2 mm, 0 mm):

frame unit_square {
	a: vec @(-0.5mm, -0.5mm)
	b: vec .(1mm, 1mm)
	rect a b
}

frame unit_square @
vec @(2mm, 0mm)
frame unit_square .


Names and variables
-------------------

fped uses several name spaces:

- frame names occupy one global name space

- vector names occupy name spaces delimited by the frame they're
  contained in. A vector name is only visible inside the frame in which
  it is defined.
  
- variable names occupy name spaces delimited by the frame they're
  contained in. A variable lookup starts in the frame in which the
  corresponding expression appears and propagates to outer frames
  until the variable is found.

- pads occupy one global name space (this is currently not enforced)

Note that names cannot be redefined. E.g., this does not work:

set a = 1
set a = a+1

The names spaces of frames, vectors, variables, and pads are separate
from each other.


Simple variables
- - - - - - - -

A variable with a single value is defined with the following
assignment syntax:

set <identifier> = <expression>

Example:

set a = b+2


Loops
- - -

A loop is a variable with a range of values:

loop <identifier> = <from>, <to>

The variable assumes all the values i for <from> <= i <= <to>, in
increments of one. E.g.,

loop n = 1, 3

and

loop n = 1, 3.5

both assign the values 1, 2, and 3 to the variable "n". The
following loop would not execute at all:

loop n = 1, 0

This can be used to implement conditional execution. For example,
the items in the following frame would be instantiated if the
variable "enable" is set to 1 but not it is set to 0:

frame ... {
    loop dummy = 1, enable
    ...
}

When a loop is executed, the objects contained in the body of the
enclosing frame are generated for each value of the variable. If
a frame contains multiple loops, all possible combinations of the
values are generated.

The following example draws three concentric circles around the
origin, with radii 1, 2, and 3:

loop x = 1, 3
vec @(x*1mm, 0mm)
circ @ .


Tables
- - -

Tables combine values for multiple variables. Like loops, they are
used to iteratively generate objects. A table begins with a row of
variable names, followed by one or more rows with values. Rows are
enclosed in curly braces and their elements are separated by commas.

table
    { <identifier>, ... }
    { <expression>, ... }
    ...

Like loops, tables are iterated to generate objects. The following
example is equivalent to the one in the previous section:

table
    { x }
    { 1mm }
    { 2mm }
    { 3mm }
vec @(x, 0mm)
circ @ .

Note that we can set the unit of the values directly in this case.

Iteration is performed over rows. All variables of the table are set
to the value in the respective row at the same time. For example, in

table
    { x, y }
    { 1, 2 }
    { 3, 4 }

(x, y) assume the values (1, 2) and (3, 4).


Expressions
-----------

Expressions can contain numeric constants (in non-exponential notation),
variable names, the arithmetic operations +, -, *, /, and unary -.
Parentheses can be used to change precedence.


GUI
---

Part of the GUI is described in
http://people.openmoko.org/werner/fped/gui.html


Keyboard shortcuts
- - - - - - - - -

Space	reset user coordinates
+, =	zoom in (like mouse wheel forward)
-	zoom out (like mouse wheel backward)
.	cursor position to screen center (like middle click)
*	zoom and center to extents
#	zoom and center to currently active frame instance
U	undelete the previously deleted object
/	Switch between variable and item display.


Canvas
- - -

To create a new object, click on the corresponding tool icon, move the
mouse to the base point of the new object, then drag to the object's
second point.

Frame references are created as follows:

- select the frame you want to add
- click on the frame icon. A black dot should appear on the icon.
- select the frame on which you want to add the new reference.
  The black dot should change to a green dot. If the current frame
  is a child of the selected frame, the dot remains black.
- click on the desired base location

To change a point of an object, select the object, then drag the point
to its new location. To edit the object's parameters, select it and
make the changes in the input area at the bottom.

To delete an object, select the delete tool and click on the object.
Deleted objects can be undeleted by pressing "u". If any other changes
have been made since deletion, fped may misbehave. If deleting a vector,
all items that reference it are deleted as well.


Experimental: new-style measurements
------------------------------------

New-style measurements can measure the distance between various pairs
of points, not only between points in the same instance and the same
frame. They operate on the set of points produced during instantiation.

New-style measurements are placed in the root frame after all other
items.

Known issues:
- they currently can't be edited through the GUI
- tie-breaking heuristics don't always do what one expects

Syntax:

<type> [<label>] <from> <op> <to> [<offset>]

Types:
- meas: measure diagonally
- measx: measure along the X axis
- measy: measure along the y axis

Note that the type also affects the selection of the points. E.g.,
measx will select maximum x values.

Operators:
- A -> B: smallest value of A and smallest B greater than A
- A <- B: like A -> B, but normal (for offset and text) is inverted
- A >> B: smallest value of A and greatest value of B
- A << B: like A -> B, but normal (for offset and text) is inverted

Operands are qualified vector names. Vectors in the root frame are
referenced by their name. Vectors in other frames are prefixed with
the name of the frame followed by a dot.

Example:

measx pad.sw -> pad.se 1mm

The optional label is printed directly before the distance. Example:

a: vec @(0mm, 0mm)
b: vec @(1mm, 0mm)
measx "width = " a >> b 0mm

would print "width = 1mm"