
Security News
The Changelog Podcast: Practical Steps to Stay Safe on npm
Learn the essential steps every developer should take to stay secure on npm and reduce exposure to supply chain attacks.
@jscad/dxf-deserializer
Advanced tools
Deserializer of DXF data to JSCAD scripts or geometries
This deserializer converts raw DXF formatted data (files) to JSCAD scripts or geometries. When converting unknown DXF data, converting to JSCAD scripts will provide more information on the converted DXF entities.
The DXF(tm) file structure changes continously as AutoDesk releases new features and fixes. So, you can imagine that after 20 years, the contents of DXF files are pretty messed up. Expect the worst.
NOTE: At this time, only ASCII DXF files are supported. BINARY DXF files are not supported.
This deserializer converts only what is supported by JSCAD libraries. Full document conversion is NOT supported, however conversion of the following DXF entities are possible:
| DXF Entity | JSCAD Geometry | Notes |
|---|---|---|
| 3DFACE | to geom3 | |
| ARC | to path2 | |
| CIRCLE | to geom2 | Start and stop angles are ignored |
| ELLIPSE | to geom2 | Start and stop angles are ignored |
| LINE | to path2 | |
| LWPOLYLINE | to path2 or geom2 | Conversion to geom2 if LWPOLYLINE is closed |
| MESH | to geom3 | |
| POLYLINE (line) | to path2 or geom2 | Conversion to geom2 if POLYLINE is closed |
| POLYLINE (mesh) | to geom3 | |
| POLYLINE (face) | to geom3 |
In addition, colors are converted using the AutoCad 2017 standard color index (256 colors).
Finally, there are many applications that can save to DXF formats. All testing is performed with files from AutoCad, period.
npm install @jscad/dxf-deserializer
const dxfDeserializer = require('@jscad/dxf-deserializer')
const rawData = fs.readFileSync('PATH/TO/file.dxf')
const jscadCode = dxfDeserializer.deserialize(rawData, 'file.dxf', {output: 'jscad'})
The various JSCAD packages and all source code are part of the JSCAD Organization, and maintained by a group of volunteers. We welcome and encourage anyone to pitch in but please take a moment to read the following guidelines.
If you want to submit a bug report please make sure to follow the Reporting Issues guide. Bug reports are accepted as Issues via GitHub.
If you want to submit a change or a patch, please read the Contributing Guide. New contributions are accepted as Pull Requests via GitHub.
We only accept bug reports and pull requests on GitHub.
If you have a question about how to use JSCAD, then please start a conversation at the JSCAD User Group. You might find the answer in the JSCAD User Guide.
If you have a change or new feature in mind, please start a conversation with the Core Developers and start contributing changes.
Small Note: If editing this README, please conform to the standard-readme specification.
The MIT License (MIT) (unless specified otherwise)
FAQs
DXF Deserializer for JSCAD
We found that @jscad/dxf-deserializer demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Learn the essential steps every developer should take to stay secure on npm and reduce exposure to supply chain attacks.

Security News
Experts push back on new claims about AI-driven ransomware, warning that hype and sponsored research are distorting how the threat is understood.

Security News
Ruby's creator Matz assumes control of RubyGems and Bundler repositories while former maintainers agree to step back and transfer all rights to end the dispute.