Here is an improved version of the README with a more detailed description of the file formats and the system:
The PADS Layout Parser is a modern TypeScript library designed to parse PADS Layout ASCII files (.asc format), which are widely used in the design and manufacturing of PCBs (Printed Circuit Boards). This library provides an efficient way to transform netlist data from PADS files into structured object representations. These objects can be used for circuit analysis, design automation, or data conversion tasks.
.asc format).*PART*, *NET*, and *SIGNAL*.To install the PADS Layout Parser library via npm, use the following command:
npm install pads-layout-parser
You can use the library to parse PADS Layout ASCII files and extract the design information, including parts and net connections.
import { PADSParser, PADSNetlist } from 'pads-layout-parser';
const padsData = `
*PADS-PCB*
*PART*
U1 MY_FOOTPRINT
R1 RES0805
*NET*
*SIGNAL* NET1
U1.1 R1.1
*SIGNAL* NET2
U1.2 R1.2
*END*
`;
const parser = new PADSParser();
const netlist: PADSNetlist = parser.parse(padsData);
console.log(JSON.stringify(netlist, null, 2));
import * as fs from 'fs';
import { PADSParser } from 'pads-layout-parser';
const filename = 'my_netlist.asc';
const fileContent = fs.readFileSync(filename, 'utf8');
const parser = new PADSParser();
const netlistFromFile = parser.parse(fileContent);
console.log(JSON.stringify(netlistFromFile, null, 2));
The PADS Layout ASCII file format consists of a structured text representation of PCB design data. It uses control statements enclosed in asterisks (*) to demarcate different sections. The key sections and their format are described below:
*PADS-PCB*The file starts with the *PADS-PCB* marker, which indicates that the file is a PADS Layout PCB file. This section does not contain data but signals the start of the file.
*PART*The *PART* section defines the components in the PCB design. Each part consists of a reference designator (e.g., U1) and a footprint (e.g., MY_FOOTPRINT). Optionally, a value (e.g., RES0805) may also be included.
*PART*
U1 MY_FOOTPRINT
R1 RES0805
*NET*The *NET* section defines the nets in the design. This section starts the netlist definition and does not contain net information itself. It indicates that subsequent *SIGNAL* sections will define the connections between pins of parts.
*NET*
*SIGNAL*The *SIGNAL* section defines the actual signal connections between parts in the PCB design. Each signal has a net name (e.g., NET1) and one or more pin connections (e.g., U1.1 R1.1), where each pin pair represents a connection between two parts.
*SIGNAL* NET1
U1.1 R1.1
*SIGNAL* NET2
U1.2 R1.2
*END*The *END* control statement marks the end of the file or the end of a section.
The following data structures are used to represent the parsed PADS data:
PADSNetlistinterface PADSNetlist {
  parts: PADSPart[];
  nets: PADSNet[];
}
PADSPartinterface PADSPart {
  refdes: string; // Reference designator (e.g., U1, R1)
  footprint: string; // Footprint name (e.g., MY_FOOTPRINT, RES0805)
  value?: string; // Optional value (e.g., RES0805)
}
PADSNetinterface PADSNet {
  name: string; // Net name (e.g., NET1, NET2)
  pins: PADSPin[]; // Array of pin pairs
}
PADSPininterface PADSPin {
  refdes: string; // Reference designator (e.g., U1, R1)
  pin: string; // Pin number (e.g., 1, 2)
}
The parser provides detailed error messages when it encounters invalid syntax or unexpected data in the input file. The error messages include line numbers and descriptions of the issue, making it easier to debug PADS Layout ASCII files.
To run the test suite and ensure the parser works correctly, use the following command:
npm test
Code coverage reports are automatically generated and accessible via Coveralls.
We welcome contributions! Please review our Contributing Guidelines before submitting a pull request.
This project is licensed under the MIT License.
To set up the project for development, follow these steps:
git clone git@github.com:firechip/pads-layout-parser.git
cd pads-layout-parser
npm install
npm run build
npm test
For questions or feedback, feel free to open an issue or reach out to the project maintainers.