FreeCalypso > hg > ueda-linux
diff netdiff/match/rdpass.c @ 140:d3eb3790386d
netdiff: donl-netmatch put together
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 07 Sep 2020 04:57:37 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/netdiff/match/rdpass.c Mon Sep 07 04:57:37 2020 +0000 @@ -0,0 +1,123 @@ +#include <ctype.h> +#include <string.h> +#include <strings.h> +#include <stdio.h> +#include <stdlib.h> +#include "struct.h" + +extern char *infnames[2]; +extern struct pin_info *database; + +#define MAX_FIELDS 2 + +static int pass; +static FILE *inf; +static char linebuf[512]; +static int lineno; +static char *fields[MAX_FIELDS]; +static unsigned nfields; + +static void +parse_into_fields() +{ + char *cp; + + nfields = 0; + for (cp = linebuf; ; ) { + while (isspace(*cp)) + cp++; + if (*cp == '\0' || *cp == '#') + break; + if (nfields >= MAX_FIELDS) { + fprintf(stderr, "%s line %d: too many fields\n", + infnames[pass], lineno); + exit(1); + } + fields[nfields++] = cp; + while (*cp && !isspace(*cp)) + cp++; + if (*cp) + *cp++ = '\0'; + } +} + +static void +existing_pin(p, netname) + struct pin_info *p; + char *netname; +{ + char *dp; + + if (p->netnames[pass]) { + fprintf(stderr, "%s line %d: multiple nets to pin %s\n", + infnames[pass], lineno, p->pin_name); + exit(1); + } + dp = malloc(strlen(netname) + 1); + if (!dp) { + perror("malloc"); + exit(1); + } + strcpy(dp, netname); + p->netnames[pass] = dp; +} + +static void +process_connect(netname, pinname) + char *netname, *pinname; +{ + struct pin_info *p, **pp; + char *dp; + + for (pp = &database; p = *pp; pp = &p->next) { + if (!strcmp(p->pin_name, pinname)) { + existing_pin(p, netname); + return; + } + } + p = malloc(sizeof(struct pin_info) + strlen(netname) + strlen(pinname) + + 2); + if (!p) { + perror("malloc"); + exit(1); + } + bzero(p, sizeof(struct pin_info)); + dp = (char *)(p + 1); + p->pin_name = dp; + strcpy(dp, pinname); + dp += strlen(pinname) + 1; + p->netnames[pass] = dp; + strcpy(dp, netname); + *pp = p; +} + +static void +process_line() +{ + parse_into_fields(); + if (!nfields) + return; + if (nfields != 2) { + fprintf(stderr, "%s line %d: expected 2 fields\n", + infnames[pass], lineno); + exit(1); + } + process_connect(fields[0], fields[1]); +} + +read_pass(pass_no) +{ + pass = pass_no; + inf = fopen(infnames[pass], "r"); + if (!inf) { + perror(infnames[pass]); + exit(1); + } + lineno = 0; + while (fgets(linebuf, sizeof linebuf, inf)) { + lineno++; + process_line(); + } + fclose(inf); + return 0; +}