Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/newdefectus/defasm
Incremental x86-64 assembler written in JavaScript
https://github.com/newdefectus/defasm
assembler assembly incremental npm x86
Last synced: 3 months ago
JSON representation
Incremental x86-64 assembler written in JavaScript
- Host: GitHub
- URL: https://github.com/newdefectus/defasm
- Owner: NewDefectus
- License: isc
- Created: 2021-02-21T13:32:26.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-04-27T11:19:21.000Z (9 months ago)
- Last Synced: 2024-05-29T10:37:42.760Z (7 months ago)
- Topics: assembler, assembly, incremental, npm, x86
- Language: JavaScript
- Homepage:
- Size: 13.9 MB
- Stars: 9
- Watchers: 3
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# DefAssembler
DefAssembler is an incremental x86-64 assembler written in JavaScript. It aims to be relatively lightweight, easy to use, and efficient. For a quick demonstration, I recommend checking out the [GitHub Pages site](https://newdefectus.github.io/defasm/). DefAssembler is also the assembler used by [Code Golf](https://code.golf/fizz-buzz#assembly).DefAssembler is currently available in the following npm packages, all of which are developed under this repository:
* `@defasm/core` - this is the main package of the assembler; it exports the functionality required to assemble code.
* `@defasm/cli` - a command-line utility allowing you to assemble code and output ELF object files. It also provides an option to link and execute the code immediately, which displays register contents, flags, and signal information upon the program's crash.
* `@defasm/codemirror` - a collection of [CodeMirror 6](https://codemirror.net/6/) plugins which demonstrate the assembler's real-time assembly capabilities.See each package's respective README file for more information.
For development, clone this repository and run `npm install`. Run `npm run dev` to open the demo on port 8000 (uses esbuild's watch feature, so you should refresh after making changes in the code). `npm test` runs the test suite (currently quite small; contributions are very much welcome!).