1
0
mirror of git://projects.qi-hardware.com/fped.git synced 2025-01-03 20:20:15 +02:00

Made life in mil-land a little less painful.

- .fpd file format: new directive "unit" to set the default unit
- new selection was too aggressive - make it only rearrange settings if we also
  fail the second vector search
- gui_draw_pad_text: calculation of height vs. width lost too much precision,
  causing pad text to be rotated arbitrarily
- drag_new_vec: display distance in mil if unit is mil
- end_new_raw_vec: store distance in mil if unit is mil
- gridify: use a 10 mil grid if unit is mil
- ps_hline: corrected gsave/grestore mismatch
- Makefile: made "all" a prerequisite of "install"
- Postscript output now mentions the default unit (if set)
- ps_package: height and width were swapped, oopsie !



git-svn-id: http://svn.openmoko.org/trunk/eda/fped@5525 99fdad57-331a-0410-800a-d7fa5415bdb3
This commit is contained in:
werner 2009-08-22 15:58:58 +00:00
parent 18be341c2d
commit 5a2eb77629
10 changed files with 170 additions and 45 deletions

View File

@ -118,7 +118,7 @@ clean:
# ----- Install / uninstall --------------------------------------------------- # ----- Install / uninstall ---------------------------------------------------
install: install: all
install -m 755 fped $(PREFIX)/bin/ install -m 755 fped $(PREFIX)/bin/
uninstall: uninstall:

10
README
View File

@ -90,6 +90,7 @@ The file has the following structure:
frame definitions frame definitions
... ...
package name package name
unit
objects objects
... ...
@ -125,6 +126,15 @@ set b = 10*1mm
All values used as dimensions must be either mm or mil. 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
- - - - - - - -

20
dump.c
View File

@ -17,6 +17,7 @@
#include "util.h" #include "util.h"
#include "unparse.h" #include "unparse.h"
#include "obj.h" #include "obj.h"
#include "gui_status.h"
#include "dump.h" #include "dump.h"
@ -491,6 +492,24 @@ static void dump_frame(FILE *file, struct frame *frame, const char *indent)
/* ----- file -------------------------------------------------------------- */ /* ----- file -------------------------------------------------------------- */
static void dump_unit(FILE *file)
{
switch (curr_unit) {
case curr_unit_mm:
fprintf(file, "unit mm\n");
break;
case curr_unit_mil:
fprintf(file, "unit mil\n");
break;
case curr_unit_auto:
fprintf(file, "unit auto\n");
break;
default:
abort();
}
}
int dump(FILE *file) int dump(FILE *file)
{ {
struct frame *frame; struct frame *frame;
@ -501,6 +520,7 @@ int dump(FILE *file)
for (frame = frames; frame; frame = frame->next) { for (frame = frames; frame; frame = frame->next) {
if (!frame->name) { if (!frame->name) {
fprintf(file, "package \"%s\"\n", pkg_name); fprintf(file, "package \"%s\"\n", pkg_name);
dump_unit(file);
dump_frame(file, frame, ""); dump_frame(file, frame, "");
} else { } else {
dump_frame(file, frame, "\t"); dump_frame(file, frame, "\t");

2
fpd.l
View File

@ -118,6 +118,8 @@ SP [\t ]*
return TOK_MEASX; } return TOK_MEASX; }
<INITIAL>"measy" { BEGIN(NOKEYWORD); <INITIAL>"measy" { BEGIN(NOKEYWORD);
return TOK_MEASY; } return TOK_MEASY; }
<INITIAL>"unit" { BEGIN(NOKEYWORD);
return TOK_UNIT; }
<INITIAL>[a-zA-Z_][a-zA-Z_0-9]*: { *strchr(yytext, ':') = 0; <INITIAL>[a-zA-Z_][a-zA-Z_0-9]*: { *strchr(yytext, ':') = 0;
yylval.id = unique(yytext); yylval.id = unique(yytext);

21
fpd.y
View File

@ -19,6 +19,7 @@
#include "expr.h" #include "expr.h"
#include "obj.h" #include "obj.h"
#include "meas.h" #include "meas.h"
#include "gui_status.h"
#include "fpd.h" #include "fpd.h"
@ -156,7 +157,7 @@ static struct obj *new_obj(enum obj_type type)
%token START_FPD START_EXPR START_VAR START_VALUES %token START_FPD START_EXPR START_VAR START_VALUES
%token TOK_SET TOK_LOOP TOK_PACKAGE TOK_FRAME TOK_TABLE TOK_VEC %token TOK_SET TOK_LOOP TOK_PACKAGE TOK_FRAME TOK_TABLE TOK_VEC
%token TOK_PAD TOK_RPAD TOK_RECT TOK_LINE TOK_CIRC TOK_ARC %token TOK_PAD TOK_RPAD TOK_RECT TOK_LINE TOK_CIRC TOK_ARC
%token TOK_MEAS TOK_MEASX TOK_MEASY %token TOK_MEAS TOK_MEASX TOK_MEASY TOK_UNIT
%token TOK_NEXT TOK_NEXT_INVERTED TOK_MAX TOK_MAX_INVERTED %token TOK_NEXT TOK_NEXT_INVERTED TOK_MAX TOK_MAX_INVERTED
%token <num> NUMBER %token <num> NUMBER
@ -206,7 +207,7 @@ all:
; ;
fpd: fpd:
| frame_defs part_name frame_items | frame_defs part_name opt_unit frame_items
; ;
part_name: part_name:
@ -227,6 +228,22 @@ part_name:
} }
; ;
opt_unit:
| TOK_UNIT ID
{
if (!strcmp($2, "mm"))
curr_unit = curr_unit_mm;
else if (!strcmp($2, "mil"))
curr_unit = curr_unit_mil;
else if (!strcmp($2, "auto"))
curr_unit = curr_unit_auto;
else {
yyerrorf("unrecognized unit \"%s\"", $2);
YYABORT;
}
}
;
frame_defs: frame_defs:
| frame_defs frame_def | frame_defs frame_def
; ;

View File

@ -241,13 +241,17 @@ static void gui_draw_pad_text(struct inst *self)
GdkGC *gc; GdkGC *gc;
struct coord c; struct coord c;
unit_type h, w; unit_type h, w;
int rot;
w = self->bbox.max.x-self->bbox.min.x;
h = self->bbox.max.y-self->bbox.min.y;
rot = w/1.1 < h;
gc = gc_ptext[get_mode(self)]; gc = gc_ptext[get_mode(self)];
sort_coord(&min, &max); sort_coord(&min, &max);
c = add_vec(min, max); c = add_vec(min, max);
h = max.y-min.y; h = max.y-min.y;
w = max.x-min.x; w = max.x-min.x;
render_text(DA, gc, c.x/2, c.y/2, w <= h*1.1 ? 0 : 90, render_text(DA, gc, c.x/2, c.y/2, rot ? 0 : 90,
self->u.pad.name, PAD_FONT, 0.5, 0.5, self->u.pad.name, PAD_FONT, 0.5, 0.5,
w-2*PAD_BORDER, h-2*PAD_BORDER); w-2*PAD_BORDER, h-2*PAD_BORDER);
} }

View File

@ -736,25 +736,31 @@ void status_begin_reporting(void)
/* ----- unit selection ---------------------------------------------------- */ /* ----- unit selection ---------------------------------------------------- */
static void show_curr_unit(void)
{
switch (curr_unit) {
case curr_unit_mm:
status_set_unit("mm");
break;
case curr_unit_mil:
status_set_unit("mil");
break;
case curr_unit_auto:
status_set_unit("auto");
break;
default:
abort();
}
}
static gboolean unit_button_press_event(GtkWidget *widget, static gboolean unit_button_press_event(GtkWidget *widget,
GdkEventButton *event, gpointer data) GdkEventButton *event, gpointer data)
{ {
switch (event->button) { switch (event->button) {
case 1: case 1:
curr_unit = (curr_unit+1) % curr_unit_n; curr_unit = (curr_unit+1) % curr_unit_n;
switch (curr_unit) { show_curr_unit();
case curr_unit_mm:
status_set_unit("mm");
break;
case curr_unit_mil:
status_set_unit("mil");
break;
case curr_unit_auto:
status_set_unit("auto");
break;
default:
abort();
}
break; break;
} }
refresh_pos(); refresh_pos();
@ -859,7 +865,7 @@ void make_status_area(GtkWidget *vbox)
/* unit selection */ /* unit selection */
label_in_box_bg(status_unit, COLOR_UNIT_SELECTOR); label_in_box_bg(status_unit, COLOR_UNIT_SELECTOR);
status_set_unit("mm"); show_curr_unit();
g_signal_connect(G_OBJECT(box_of_label(status_unit)), g_signal_connect(G_OBJECT(box_of_label(status_unit)),
"button_press_event", G_CALLBACK(unit_button_press_event), NULL); "button_press_event", G_CALLBACK(unit_button_press_event), NULL);

View File

@ -215,8 +215,19 @@ void tool_selected_inst(struct inst *inst)
static struct coord gridify(struct coord base, struct coord pos) static struct coord gridify(struct coord base, struct coord pos)
{ {
struct coord new; struct coord new;
unit_type unit = mm_to_units(0.1); unit_type unit;
switch (curr_unit) {
case curr_unit_mm:
case curr_unit_auto:
unit = mm_to_units(0.1);
break;
case curr_unit_mil:
unit = mil_to_units(10);
break;
default:
abort();
}
new.x = pos.x-((pos.x-base.x) % unit); new.x = pos.x-((pos.x-base.x) % unit);
new.y = pos.y-((pos.y-base.y) % unit); new.y = pos.y-((pos.y-base.y) % unit);
if (new.x != base.x || new.y != base.y) if (new.x != base.x || new.y != base.y)
@ -238,8 +249,20 @@ static struct pix_buf *drag_new_vec(struct inst *from, struct coord to)
to = gridify(pos, to); to = gridify(pos, to);
status_set_type_x("dX ="); status_set_type_x("dX =");
status_set_type_y("dX ="); status_set_type_y("dX =");
status_set_x("%lg mm", units_to_mm(to.x-pos.x)); /* @@@ use status_set_xy */
status_set_y("%lg mm", units_to_mm(to.y-pos.y)); switch (curr_unit) {
case curr_unit_mm:
case curr_unit_auto:
status_set_x("%lg mm", units_to_mm(to.x-pos.x));
status_set_y("%lg mm", units_to_mm(to.y-pos.y));
break;
case curr_unit_mil:
status_set_x("%lg mil", units_to_mil(to.x-pos.x));
status_set_y("%lg mil", units_to_mil(to.y-pos.y));
break;
default:
abort();
}
pos = translate(pos); pos = translate(pos);
to = translate(to); to = translate(to);
buf = save_pix_buf(DA, pos.x, pos.y, to.x, to.y, 1); buf = save_pix_buf(DA, pos.x, pos.y, to.x, to.y, 1);
@ -270,8 +293,19 @@ static int end_new_raw_vec(struct inst *from, struct coord to)
vec = new_vec(from); vec = new_vec(from);
pos = inst_get_point(from); pos = inst_get_point(from);
to = gridify(pos, to); to = gridify(pos, to);
vec->x = new_num(make_mm(units_to_mm(to.x-pos.x))); switch (curr_unit) {
vec->y = new_num(make_mm(units_to_mm(to.y-pos.y))); case curr_unit_mm:
case curr_unit_auto:
vec->x = new_num(make_mm(units_to_mm(to.x-pos.x)));
vec->y = new_num(make_mm(units_to_mm(to.y-pos.y)));
break;
case curr_unit_mil:
vec->x = new_num(make_mil(units_to_mil(to.x-pos.x)));
vec->y = new_num(make_mil(units_to_mil(to.y-pos.y)));
break;
default:
abort();
}
return 1; return 1;
} }

40
inst.c
View File

@ -208,6 +208,26 @@ int inst_select(struct coord pos)
if (selected_inst) if (selected_inst)
goto selected; goto selected;
} }
/* give vectors a second chance */
if (show_stuff) {
FOR_ALL_INSTS(i, ip_vec, inst) {
if (!inst->active)
continue;
if (!inst_connected(inst))
continue;
dist = gui_dist_vec_fallback(inst, pos, draw_ctx.scale);
if (dist >= 0 && (!selected_inst || best_dist > dist)) {
selected_inst = inst;
best_dist = dist;
}
}
if (selected_inst)
goto selected;
}
if (any_same_frame) { if (any_same_frame) {
if (activate_item(any_same_frame)) if (activate_item(any_same_frame))
return inst_select(pos); return inst_select(pos);
@ -220,25 +240,7 @@ int inst_select(struct coord pos)
} }
} }
if (!show_stuff) return 0;
return 0;
/* give vectors a second chance */
FOR_ALL_INSTS(i, ip_vec, inst) {
if (!inst->active)
continue;
if (!inst_connected(inst))
continue;
dist = gui_dist_vec_fallback(inst, pos, draw_ctx.scale);
if (dist >= 0 && (!selected_inst || best_dist > dist)) {
selected_inst = inst;
best_dist = dist;
}
}
if (!selected_inst)
return 0;
selected: selected:
inst_select_inst(selected_inst); inst_select_inst(selected_inst);

View File

@ -53,6 +53,8 @@
#define PS_DIVIDER_BORDER mm_to_units(2) #define PS_DIVIDER_BORDER mm_to_units(2)
#define PS_DIVIDER_WIDTH mm_to_units(0.5) #define PS_DIVIDER_WIDTH mm_to_units(0.5)
#define PS_MISC_TEXT_HEIGHT mm_to_units(3)
#define PS_DOT_DIST mm_to_units(0.03) #define PS_DOT_DIST mm_to_units(0.03)
#define PS_DOT_DIAM mm_to_units(0.01) #define PS_DOT_DIAM mm_to_units(0.01)
#define PS_HATCH mm_to_units(0.1) #define PS_HATCH mm_to_units(0.1)
@ -454,7 +456,7 @@ static void ps_hline(FILE *file, int y)
{ {
fprintf(file, "gsave %d setlinewidth\n", PS_DIVIDER_WIDTH); fprintf(file, "gsave %d setlinewidth\n", PS_DIVIDER_WIDTH);
fprintf(file, " %d %d moveto\n", -PAGE_HALF_WIDTH, y); fprintf(file, " %d %d moveto\n", -PAGE_HALF_WIDTH, y);
fprintf(file, " %d 0 rlineto stroke gsave\n", PAGE_HALF_WIDTH*2); fprintf(file, " %d 0 rlineto stroke grestore\n", PAGE_HALF_WIDTH*2);
} }
@ -488,6 +490,32 @@ static void ps_page(FILE *file, int page)
} }
static void ps_unit(FILE *file,
unit_type x, unit_type y, unit_type w, unit_type h)
{
const char *s;
switch (curr_unit) {
case curr_unit_mm:
s = "Dimensions in mm";
break;
case curr_unit_mil:
s = "Dimensions in mil";
break;
case curr_unit_auto:
return;
default:
abort();
}
fprintf(file, "gsave %d %d moveto\n", x, y);
fprintf(file, " /Helvetica findfont dup\n");
fprintf(file, " (%s) %d %d\n", s, w, h);
fprintf(file, " 4 copy 1000 maxfont maxfont scalefont setfont\n");
fprintf(file, " (%s) show grestore\n", s);
}
static void ps_package(FILE *file, const struct pkg *pkg, int page) static void ps_package(FILE *file, const struct pkg *pkg, int page)
{ {
struct bbox bbox; struct bbox bbox;
@ -504,8 +532,8 @@ static void ps_package(FILE *file, const struct pkg *pkg, int page)
y = PAGE_HALF_HEIGHT-PS_HEADER_HEIGHT-3*PS_DIVIDER_BORDER; y = PAGE_HALF_HEIGHT-PS_HEADER_HEIGHT-3*PS_DIVIDER_BORDER;
bbox = inst_get_bbox(); bbox = inst_get_bbox();
w = 2*(-bbox.min.y > bbox.max.y ? -bbox.min.y : bbox.max.y); w = 2*(-bbox.min.x > bbox.max.x ? -bbox.min.x : bbox.max.x);
h = 2*(-bbox.min.x > bbox.max.x ? -bbox.min.x : bbox.max.x); h = 2*(-bbox.min.y > bbox.max.y ? -bbox.min.y : bbox.max.y);
/* /*
* Zoom such that we can fit at least one drawing * Zoom such that we can fit at least one drawing
@ -574,6 +602,8 @@ static void ps_package(FILE *file, const struct pkg *pkg, int page)
} }
fprintf(file, "grestore\n"); fprintf(file, "grestore\n");
ps_unit(file, -PAGE_HALF_WIDTH, PS_DIVIDER_BORDER, PAGE_HALF_WIDTH,
PS_MISC_TEXT_HEIGHT);
ps_hline(file, 0); ps_hline(file, 0);
/* /*