{"id":15489791,"url":"https://github.com/theonekevin/icarusext","last_synced_at":"2025-04-22T19:03:50.729Z","repository":{"id":42805017,"uuid":"270742513","full_name":"TheOneKevin/icarusext","owner":"TheOneKevin","description":"iverilog extension for Visual Studio Code to satisfy the needs for an easy testbench runner. Includes builtin GTKWave support.","archived":false,"fork":false,"pushed_at":"2023-03-04T23:10:54.000Z","size":600,"stargazers_count":11,"open_issues_count":8,"forks_count":3,"subscribers_count":2,"default_branch":"master","last_synced_at":"2024-10-19T09:00:03.618Z","etag":null,"topics":["gtkwave","icarus-verilog","verilog","verilog-testbenches","vscode-extension"],"latest_commit_sha":null,"homepage":"https://marketplace.visualstudio.com/items?itemName=theonekevin.icarusext","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/TheOneKevin.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2020-06-08T16:31:28.000Z","updated_at":"2024-10-02T11:31:50.000Z","dependencies_parsed_at":"2023-01-31T16:00:23.669Z","dependency_job_id":"1f6ed5f0-6efc-4b8f-b724-69e9db3fb5ff","html_url":"https://github.com/TheOneKevin/icarusext","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TheOneKevin%2Ficarusext","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TheOneKevin%2Ficarusext/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TheOneKevin%2Ficarusext/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TheOneKevin%2Ficarusext/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/TheOneKevin","download_url":"https://codeload.github.com/TheOneKevin/icarusext/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":250306611,"owners_count":21408925,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["gtkwave","icarus-verilog","verilog","verilog-testbenches","vscode-extension"],"created_at":"2024-10-02T07:07:59.519Z","updated_at":"2025-04-22T19:03:50.707Z","avatar_url":"https://github.com/TheOneKevin.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Verilog Testbench Runner\n[![](https://img.shields.io/badge/license-MIT-orange.svg?style=flat-square)](http://opensource.org/licenses/MIT)\n[![](https://img.shields.io/static/v1?label=Icarus\u0026message=Verilog\u0026color=f368e0\u0026style=flat-square)](https://github.com/steveicarus/iverilog)\n\n**Currently, only `iverilog` is supported.**\n\nA simple extension to run single file Verilog testbenches with GTKWave integration. Hassle-free, portable, easy to configure. Combines the best bits of everything out there.\n\n## Usage\n\nThis extension adds two buttons, which will appear in the titlebar of any Verilog file, and a status item positioned in the lower-right corner.\n\nBe sure you have `iverilog` and `gtkwave` added to your environment PATH variable. If you need help, check out the installation guide [here](https://iverilog.fandom.com/wiki/Installation_Guide) (and for [Windows](http://bleyer.org/icarus/)).\n\n## Features\n\n### 1. Simple to use buttons:\n\n\u003cimg src=\"https://raw.githubusercontent.com/TheOneKevin/icarusext/master/images/screen1.PNG\"\u003e\u003c/img\u003e\n\n### 2. Live rough logic gate estimates:\n\n\u003cimg src=\"https://raw.githubusercontent.com/TheOneKevin/icarusext/master/images/screen2.PNG\"\u003e\u003c/img\u003e\n\n\u003cimg src=\"https://raw.githubusercontent.com/TheOneKevin/icarusext/master/images/screen3.PNG\"\u003e\u003c/img\u003e\n\n### 3. Simple GTKWave integration:\n\n\u003cimg src=\"https://raw.githubusercontent.com/TheOneKevin/icarusext/master/images/screen4.PNG\"\u003e\u003c/img\u003e\n\n## Configuration\n\n- `verilog.gtkwaveWatchGlob`: GTKWave will be summoned when a file satisfying the glob is created (glob is relative to the build directory).\n- `verilog.icarusCompileArguments`: Arguments passed to Verilog compiler.\n- `verilog.icarusBuildDirectory`: Build folder path relative to workspace root.\n- `verilog.icarusPersistentBuild`: True if build folder should not be cleared before each compilation.\n\n## Commands\n\n- `icarusext.run` : Compiles and runs current file\n- `icarusext.stop` : Stops and kills any running processes.\n- `icarusext.tsizer` : Obtains **very rough** estimates for logic components. Will run on these events:\n    - `window.onDidChangeActiveTextEditor`\n    - `workspace.onDidSaveTextDocument`\n    - Status item click (will show modal in this case)\n    - When command `icarusext.run` is run\n\n## License\n\nCode is licensed under MIT.\n\n\u003e \"Logo made by Freepik from www.flaticon.com (Flaticon license with attribution)\"\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftheonekevin%2Ficarusext","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ftheonekevin%2Ficarusext","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftheonekevin%2Ficarusext/lists"}