Verilog Automatic
Automatically generate verilog module ports,instance and instance connections ,for sublime text 2&3
Details
Installs
- Total 25K
- Win 19K
- Mac 3K
- Linux 4K
Nov 23 | Nov 22 | Nov 21 | Nov 20 | Nov 19 | Nov 18 | Nov 17 | Nov 16 | Nov 15 | Nov 14 | Nov 13 | Nov 12 | Nov 11 | Nov 10 | Nov 9 | Nov 8 | Nov 7 | Nov 6 | Nov 5 | Nov 4 | Nov 3 | Nov 2 | Nov 1 | Oct 31 | Oct 30 | Oct 29 | Oct 28 | Oct 27 | Oct 26 | Oct 25 | Oct 24 | Oct 23 | Oct 22 | Oct 21 | Oct 20 | Oct 19 | Oct 18 | Oct 17 | Oct 16 | Oct 15 | Oct 14 | Oct 13 | Oct 12 | Oct 11 | Oct 10 | Oct 9 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Windows | 1 | 2 | 2 | 1 | 1 | 1 | 4 | 6 | 4 | 0 | 0 | 5 | 4 | 1 | 2 | 2 | 7 | 2 | 4 | 5 | 0 | 2 | 2 | 2 | 2 | 6 | 2 | 4 | 2 | 3 | 3 | 6 | 3 | 7 | 10 | 3 | 5 | 5 | 7 | 6 | 2 | 3 | 4 | 6 | 4 | 11 |
Mac | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Linux | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 2 | 1 | 0 | 1 | 2 | 2 | 0 | 0 | 2 | 1 | 0 | 1 | 0 | 1 | 0 | 2 | 2 | 1 | 1 | 0 | 0 | 0 | 0 | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
Readme
- Source
- raw.githubusercontent.com
Verilog Automatic
This plugin can automatically add ports to the current editing file, generate module instances (need ctags),add instance connections ,add file header for verilog code. Both verilog-1995 and verilog-2001 style are supported. I borrowed the idea from automatic.vim which is a similar plugin for VIM, I just rewrote one for sublime text2&3.
Features
- AutoPort
- AutoInst
- AutoDef
- AddFileHeader
Description
AutoPort:(shift+f6)
Automatically add ports to the current editing file after the “/autoport/” mark.
NOTE: NOT SUPPORTED STYLE:
input clk,output single_out, //multiple input/output/inout keywords in the same line input clk,rst, chip_en; //multiple signals separated by comma written in different lines
NOTE: Do not use this function when there are multiple modules in the same file.
Example:
Before
(verilog-1995 style):
module test(/*autoport*/);
input [1:0]a;
input b;
output [2:0]c,d;
inout e;
(verilog-2001 style):
module test(/*autoport*/);
input wire[1:0]a;
input wire b;
output reg [2:0]c,d;
inout wire e;
After:
module test(/*autoport*/
//inout
e,
//output
c,
d,
//input
a,
b);
AutoInst:(shift+f7)
Automatically generate module instances after the “/autoinst/” mark (need ctags).
- NOTE:Need to place the cursor on the module name, multiple-cursor supported to generate multiple instances.
Example:
Before:
test test_instance(/*autoinst*/);
After:
Place the cursor on the module name “test”
test test_instance(/*autoinst*/ .e(e), .c(c), .d(d[2:0]), .a(a[1:0]), .b(b));
AutoDef:(shift+f8)
Automatically add instance connections after the /autodef/ mark.
Example:
before:
/*autodef*/
test test_instance(/*autoinst*/
.e(e),
.c(c),
.d(d[2:0]),
.a(a[1:0]),
.b(b));
after:
/*autodef*/
wire e;
wire [2:0]d;
wire c;
wire b;
wire [1:0]a;
//assign e=
//assign d=
//assign c=
//assign b=
//assign a=
test test_instance(/*autoinst*/
.e(e),
.c(c),
.d(d[2:0]),
.a(a[1:0]),
.b(b));
AddFileHeader:(shift+f9)
Add your personal information in the setting file(the user's setting file is better),like below or leave any of them empty:
{
"Author":"Mike",
"Company":"Microsoft",
"Email":"whatever@yahoo.com"
}
thus generates the file header like this:
//==================================================================================================
// Filename : test.v
// Created On : 2013-04-01 21:37:31
// Last Modified :
// Revision :
// Author : Mike
// Company : Microsoft
// Email : whatever@yahoo.com
//
// Description :
//
//
//==================================================================================================
Change log
05/08/2013
Add verilog-2001 style port declaration support.
Add comments support, single line commneted-out code will be ignored.