From 8ae5ce5d99752f92a86337f9b11e987d6d479906 Mon Sep 17 00:00:00 2001 From: Glen Nicholls Date: Thu, 14 Nov 2019 19:49:54 -0700 Subject: [PATCH] moved snippets to seperate files based on logical ordering and updated package.json --- vscode-client/package.json | 14 +- vscode-client/snippets/snippets.generate.json | 47 +++ .../snippets/snippets.vhdl.declaration.json | 164 ++++++++ .../snippets/snippets.vhdl.interface.json | 74 ++++ vscode-client/snippets/snippets.vhdl.json | 371 ------------------ ...raries.json => snippets.vhdl.library.json} | 2 +- .../snippets/snippets.vhdl.logic.json | 118 ++++++ .../snippets/snippets.vhdl.types.json | 37 -- 8 files changed, 415 insertions(+), 412 deletions(-) create mode 100644 vscode-client/snippets/snippets.generate.json create mode 100644 vscode-client/snippets/snippets.vhdl.declaration.json create mode 100644 vscode-client/snippets/snippets.vhdl.interface.json delete mode 100644 vscode-client/snippets/snippets.vhdl.json rename vscode-client/snippets/{snippets.vhdl.libraries.json => snippets.vhdl.library.json} (93%) create mode 100644 vscode-client/snippets/snippets.vhdl.logic.json delete mode 100644 vscode-client/snippets/snippets.vhdl.types.json diff --git a/vscode-client/package.json b/vscode-client/package.json index 38ffab4..6a03749 100644 --- a/vscode-client/package.json +++ b/vscode-client/package.json @@ -45,15 +45,23 @@ "snippets": [ { "language": "vhdl", - "path": "./snippets/snippets.vhdl.json" + "path": "./snippets/snippets.vhdl.generate.json" }, { "language": "vhdl", - "path": "./snippets/snippets.vhdl.libraries.json" + "path": "./snippets/snippets.vhdl.declaration.json" }, { "language": "vhdl", - "path": "./snippets/snippets.vhdl.types.json" + "path": "./snippets/snippets.vhdl.interface.json" + }, + { + "language": "vhdl", + "path": "./snippets/snippets.vhdl.library.json" + }, + { + "language": "vhdl", + "path": "./snippets/snippets.vhdl.locic.json" } ], "commands": [ diff --git a/vscode-client/snippets/snippets.generate.json b/vscode-client/snippets/snippets.generate.json new file mode 100644 index 0000000..aeab149 --- /dev/null +++ b/vscode-client/snippets/snippets.generate.json @@ -0,0 +1,47 @@ +{ + "Generate Case 2008": { + "prefix": "generate_case_2008", + "body": [ + "gen_${1:generateName} : case ${1:select} generate", + "\twhen ${2:others} =>", + "\t\t${3:null;}", + "\t$0", + "end generate;" + ], + "description": "case generate instantiation (vhdl 2008)" + }, + "Generate If": { + "prefix": "generate_if", + "body": [ + "gen_${1:generateName} : if ${2:expression} generate", + "\t$0", + "end generate;" + ], + "description": "if generate instantiation" + }, + "Generate Elsif 2008": { + "prefix": "generate_elsif_2008", + "body": [ + "elsif ${1:expression} generate", + "\t$0" + ], + "description": "elsif generate instantiation (vhdl 2008)" + }, + "Generate Else 2008": { + "prefix": "generate_else_2008", + "body": [ + "\telse generate", + "\t\t$0" + ], + "description": "else generate instantiation (vhdl 2008)" + }, + "Generate For": { + "prefix": "generate_for", + "body": [ + "gen_loop_${1:generateName} : for ${2:i} in ${3:range} generate", + "\t$0", + "end generate;" + ], + "description": "for generate loop instantiation (vhdl 2008)" + } +} diff --git a/vscode-client/snippets/snippets.vhdl.declaration.json b/vscode-client/snippets/snippets.vhdl.declaration.json new file mode 100644 index 0000000..6a10beb --- /dev/null +++ b/vscode-client/snippets/snippets.vhdl.declaration.json @@ -0,0 +1,164 @@ +{ + // TODO: open VSC enhancement to allow for user selections ($x) within or (${1||}) selection + // TODO: open VSC bug about or selection for doing nothing still requires the editor insert a space or character + // TODO: figure out how to column align with snippets such that when new lines are made for things like when/else + // or with select, cursor for next line is aligned with <= + // TODO: all types from ieee fixed/floating point packages + "Alias": { + "prefix": "alias", + "body": [ + "alias ${1:alias_name} : ${2:alias_type} is ${3:object_name};", + "$0" + ], + "description": "alias declaration" + }, + // ? are signal/variable/constant all valid for external names + "Alias External Name 2008": { + "prefix": "alias_external_name_2008", + "body": [ + "alias ${1:name} is", + "\t<< ${2|signal,variable,constant|} ${3:path.to.signal.name} : ${4:type} >>;", + "$0" + ], + "description": "hierarchical signal declaration (vhdl 2008). NOTE: for standard types (SLV, unsighed, signed, etc.), no range needs to be specified" + }, + "Array": { + "prefix": "array", + "body": [ + "type ${1:type_name} is array (${2:natural range<>}) of ${3:element_type};", + "$0" + ], + "description": "synthesizable attributes (high,low,left,right,range,reverse_range,length,event)" + }, + "Assert": { + "prefix": "assert", + "body": [ + "assert ${1:expression}", + "\treport \"${2:string}\"", + "\tseverity ${3|note,warning,error,failure|};", + "$0" + ], + "description": "assert declaration" + }, + "Constant": { + "prefix": "constant", + "body": [ + "constant ${1:name} : ${2:type} := ${3:default_value};", + "$0" + ], + "description": "constant declaration" + }, + "Function": { + "prefix": "function", + "body": [ + "function ${1:name} (${2:params}) return ${3:type} is", + "begin", + "\t$0", + "end function;" + ], + "description": "function body declaration" + }, + "Natural Range": { + "prefix": "natural_range", + "body": [ "natural range<>" ], + "description": "natural range declaration" + }, + "Others": { + "prefix": ["others"], + "body": [ "(others => ${1:})${2| ,;|}$0" ], + "description": "others declaration" + }, + "Procedure": { + "prefix": "procedure", + "body": [ + "procedure ${1:name} (${2:params}) is", + "begin", + "\t$0", + "end procedure;" + ], + "description": "procedure body declaration" + }, + "Record Type": { + "prefix": "record", + "body": [ + "type ${1:name} is record", + "\t${2:signal_name} : ${3:type};", + "\t$0", + "end record;" + ], + "description": "record declaration" + }, + "Signal": { + "prefix": "signal", + "body": [ + "signal ${1:name} : ${2:type} := ${3:default_value};", + "$0" + ], + "description": "signal declaration" + }, + "Signed": { + "prefix": "signed", + "body": [ "signed($1 ${2|downto,to|} $3)${4| := ,;|}$0" ], + "description": "signed declaration" + }, + "Standard Logic": { + "prefix": ["std_logic", "sl"], + "body": [ "std_logic${1| := ,;|}$0" ], + "description": "std_logic declaration" + }, + "Standard ULogic": { + "prefix": ["std_ulogic", "sul"], + "body": [ "std_ulogic${1| := ,;|}$0" ], + "description": "std_ulogic declaration" + }, + "Standard Logic Vector": { + "prefix": ["std_logic_vector", "slv"], + "body": [ "std_logic_vector($1 ${2|downto,to|} $3)${4| := ,;|}$0" ], + "description": "std_logic_vector declaration" + }, + "Standard ULogic Vector": { + "prefix": ["std_ulogic_vector", "sulv"], + "body": [ "std_ulogic_vector($1 ${2|downto,to|} $3)${4| := ,;|}$0" ], + "description": "std_ulogic_vector declaration" + }, + "Unsigned": { + "prefix": "unsigned", + "body": [ "unsigned(${1} ${2|downto,to|} ${3})${4| := ,;|}$0" ], + "description": "unsigned declaration" + }, + "When": { + "prefix": "when", + "body": [ + "when ${1:others} =>", + "\t$0" + ], + "description": "when declaration" + }, + "When Else": { + "prefix": "when_else", + "body": [ + "${1:signal} <= ${2:first_value} when ${3:expression}", + "\telse ${4:final_value};", + "$0" + ], + "description": "concurrent when else declaration" + }, + "With Select": { + "prefix": ["select", "with_select"], + "body": [ + "with ${1:select} select", + "\t${2:signal} <= ${3:first_value} when ${4:select_value},", + "\t\t${5:last_value} when others;", + "$0" + ], + "description": "concurrent with select declaration" + }, + "Variable": { + "prefix": "variable", + "body": [ + "variable ${1:name} : ${2:type} := ${3:default_value};", + "$0" + ], + "description": "variable declaration" + } +} diff --git a/vscode-client/snippets/snippets.vhdl.interface.json b/vscode-client/snippets/snippets.vhdl.interface.json new file mode 100644 index 0000000..3d993d1 --- /dev/null +++ b/vscode-client/snippets/snippets.vhdl.interface.json @@ -0,0 +1,74 @@ +{ + // TODO: package generics + // TODO: configuration + "Architecture Interface": { + "prefix": "architecture", + "body": [ + "architecture ${1:behav} of ${2:$TM_FILENAME_BASE} is", + "\t$0", + "begin", + "end architecture;" + ], + "description": "architecture interface" + }, + "Block Interface": { + "prefix": "block", + "body": [ + "blk_${1:blockName} : block ${2| ,optional_guard_expression|}", + "begin", + "\t$0", + "end block;" + ], + "description": "block interface" + }, + "Component Interface": { + "prefix":"component", + "body": [ + "component ${1:comp_name} is", + "\tgeneric (", + "\t\t${2:generics}", + "\t);", + "\tport (", + "\t\t${3:clk : in std_logic;}", + "\t\t${4:reset : in std_logic;}", + "\t\t$0", + "\t);", + "end component;" + ], + "description": "component interface" + }, + "Entity Interface": { + "prefix": "entity", + "body": [ + "entity ${1:$TM_FILENAME_BASE} is", + "\tgeneric (", + "\t\t${2:generics}", + "\t);", + "\tport (", + "\t\t${3:clk : in std_logic;}", + "\t\t${4:reset : in std_logic;}", + "\t\t$0", + "\t);", + "end entity;" + ], + "description": "entity interface" + }, + "Package Interface": { + "prefix": "package", + "body": [ + "package ${1:$TM_FILENAME_BASE} is", + "\t$0", + "end package;" + ], + "description": "package interface" + }, + "Package Body Interface": { + "prefix": "package_body", + "body": [ + "package body ${1:$TM_FILENAME_BASE} is", + "\t$0", + "end package;" + ], + "description": "package body interface" + } +} diff --git a/vscode-client/snippets/snippets.vhdl.json b/vscode-client/snippets/snippets.vhdl.json deleted file mode 100644 index abe341d..0000000 --- a/vscode-client/snippets/snippets.vhdl.json +++ /dev/null @@ -1,371 +0,0 @@ -{ - // TODO: add examples to anything that isn't obvious - // TODO: configuration (might be too annoying) - // ? alphabetize - // TODO: package generic vhdl 2008 - // TODO: open VSC enhancement to allow for user selections ($x) within or (${1||}) selection - // TODO: open VSC bug about or selection for doing nothing still requires the editor insert a space or character - // TODO: add notes/examples to descriptions - // TODO: figure out how to column align with snippets such that when new lines are made for things like when/else - // or with select, cursor for next line is aligned with <= - - // FIXME: this needs to allow second option with space/; - "Others": { - "prefix": ["others"], - "body": [ "(others => ${1:})${2| ,;|}$0" ], - "description": "others keyword" - }, - "When": { - "prefix": "when", - "body": [ - "when ${1:others} =>", - "\t$0" - ], - "description": "when statement" - }, - "When Else": { - "prefix": "when_else", - "body": [ - "${1:signal} <= ${2:first_value} when ${3:expression}", - "\telse ${4:final_value};", - "$0" - ], - "description": "concurrent when else statement" - }, - "With Select": { - "prefix": ["select", "with_select"], - "body": [ - "with ${1:select} select", - "\t${2:signal} <= ${3:first_value} when ${4:select_value},", - "\t\t${5:last_value} when others;", - "$0" - ], - "description": "concurrent with select statement" - }, - "Alias": { - "prefix": "alias", - "body": [ - "alias ${1:alias_name} : ${2:alias_type} is ${3:object_name};", - "$0" - ], - "description": "alias declaration" - }, - // ? are signal/variable/constant all valid for external names - "Alias External Name 2008": { - "prefix": "alias_external_name_2008", - "body": [ - "alias ${1:name} is", - "\t<< ${2|signal,variable,constant|} ${3:path.to.signal.name} : ${4:type} >>;", - "$0" - ], - "description": "hierarchical signal declaration (vhdl 2008). NOTE: for standard types (SLV, unsighed, signed, etc.), no range needs to be specified" - }, - "Array Type": { - "prefix": "array", - "body": [ - "type ${1:type_name} is array (${2:natural range<>}) of ${3:element_type};", - "$0" - ], - "description": "synthesizable attributes (high,low,left,right,range,reverse_range,length,event)" - }, - "Assert Statement": { - "prefix": "assert", - "body": [ - "assert ${1:expression}", - "\treport \"${2:string}\"", - "\tseverity ${3|note,warning,error,failure|};", - "$0" - ], - "description": "assert statement" - }, - "Constant": { - "prefix": "constant", - "body": [ - "constant ${1:name} : ${2:type} := ${3:default_value};", - "$0" - ], - "description": "constant declaration" - }, - "File": { - "prefix": "file", - "body": [ - "file ${1:name} : text is ${2|in,out|} \"${3:file_name}\";", - "$0" - ], - "description": "constant declaration" - }, - "Signal": { - "prefix": "signal", - "body": [ - "signal ${1:name} : ${2:type} := ${3:default_value};", - "$0" - ], - "description": "signal declaration" - }, - "Variable": { - "prefix": "variable", - "body": [ - "variable ${1:name} : ${2:type} := ${3:default_value};", - "$0" - ], - "description": "variable declaration" - }, - "Record Type": { - "prefix": "record", - "body": [ - "type ${1:name} is record", - "\t${2:signal_name} : ${3:type};", - "\t$0", - "end record;" - ], - "description": "record declaration" - }, - - - "Component": { - "prefix":"component", - "body": [ - "component ${1:comp_name} is", - "\tgeneric (", - "\t\t${2:generics}", - "\t);", - "\tport (", - "\t\t${3:clk : in std_logic;}", - "\t\t${4:reset : in std_logic;}", - "\t\t$0", - "\t);", - "end component;" - ], - "description": "component declaration" - }, - "Entity": { - "prefix": "entity", - "body": [ - "entity ${1:$TM_FILENAME_BASE} is", - "\tgeneric (", - "\t\t${2:generics}", - "\t);", - "\tport (", - "\t\t${3:clk : in std_logic;}", - "\t\t${4:reset : in std_logic;}", - "\t\t$0", - "\t);", - "end entity;" - ], - "description": "entity declaration" - }, - "Architecture": { - "prefix": "architecture", - "body": [ - "architecture ${1:behav} of ${2:$TM_FILENAME_BASE} is", - "\t$0", - "begin", - "end architecture;" - ], - "description": "architecture declaration" - }, - "Block": { - "prefix": "block", - "body": [ - "blk_${1:blockName} : block ${2| ,optional_guard_expression|}", - "begin", - "\t$0", - "end block;" - ], - "description": "block instantiation" - }, - - - "If": { - "prefix": "if", - "body": [ - "if ${1:expression} then", - "\t$0", - "end if;" - ], - "description": "if block" - }, - "Elsif": { - "prefix": "elsif", - "body": [ - "elsif ${1:expression} then", - "\t$0" - ], - "description": "elsif block" - }, - "Else": { - "prefix": "else", - "body": [ - "else", - "\t$0" - ], - "description": "else block" - }, - "If Generate": { - "prefix": "generate_if", - "body": [ - "gen_${1:generateName} : if ${2:expression} generate", - "\t$0", - "end generate;" - ], - "description": "if generate instantiation" - }, - "Elsif Generate 2008": { - "prefix": "generate_elsif_2008", - "body": [ - "elsif ${1:expression} generate", - "\t$0" - ], - "description": "elsif generate instantiation (vhdl 2008)" - }, - "Else Generate 2008": { - "prefix": "generate_else_2008", - "body": [ - "\telse generate", - "\t\t$0" - ], - "description": "else generate instantiation (vhdl 2008)" - }, - "For": { - "prefix": "for", - "body": [ - "for ${1:i} in ${2:range} loop", - "\t$0", - "end loop;" - ], - "description": "for loop block" - }, - "For Generate": { - "prefix": "generate_for", - "body": [ - "gen_loop_${1:generateName} : for ${2:i} in ${3:range} generate", - "\t$0", - "end generate;" - ], - "description": "for generate loop instantiation (vhdl 2008)" - }, - "While": { - "prefix": "while", - "body": [ - "while ${1:expression} loop", - "\t$0", - "end loop;" - ], - "description": "while loop block" - }, - "Case": { - "prefix": "case", - "body": [ - "case ${1:select} is", - "\twhen ${2:others} =>", - "\t\t${3:null;}", - "\t$0", - "end case;" - ], - "description": "case block" - }, - "Case Generate 2008": { - "prefix": "generate_case_2008", - "body": [ - "gen_${1:generateName} : case ${1:select} generate", - "\twhen ${2:others} =>", - "\t\t${3:null;}", - "\t$0", - "end generate;" - ], - "description": "case generate instantiation (vhdl 2008)" - }, - "Process Combinatorial": { - "prefix": "process_combinatorial", - "body": [ - "process (${1:sensitivity_list})", - "begin", - "\t$0", - "end process;" - ], - "description": "combinatorial process block" - }, - "Process Combinatorial 2008": { - "prefix": "process_combinatorial_2008", - "body": [ - "process (all)", - "begin", - "\t$0", - "end process;" - ], - "description": "combinatorial process block (vhdl 2008)" - }, - "Process Asynchronous": { - "prefix": "process_asynchronous", - "body": [ - "process (${1:clk}, ${2:reset})", - "begin", - "\tif $2 = ${3|'1','0'|} then", - "\t\t$4", - "\telsif rising_edge($1) then", - "\t\t$0", - "\tend if;", - "end process;" - ], - "description": "asynchronous process block" - }, - "Process Clocked": { - "prefix": ["process_clocked"], - "body": [ - "process (${1:clk})", - "begin", - "\tif rising_edge($1) then", - "\t\tif ${2:reset} = ${3|'1','0'|} then", - "\t\t\t$4", - "\t\telse", - "\t\t\t$0", - "\t\tend if;", - "\tend if;", - "end process;" - ], - "description": "clocked process block" - }, - "Function": { - "prefix": "function", - "body": [ - "function ${1:name} (${2:params}) return ${3:type} is", - "begin", - "\t$0", - "end function;" - ], - "description": "function body declaration" - }, - "Procedure": { - "prefix": "procedure", - "body": [ - "procedure ${1:name} (${2:params}) is", - "begin", - "\t$0", - "end procedure;" - ], - "description": "procedure body declaration" - }, - "Package": { - "prefix": "package", - "body": [ - "package ${1:$TM_FILENAME_BASE} is", - "\t$0", - "end package;" - ], - "description": "package declaration" - }, - "Package Body": { - "prefix": "package_body", - "body": [ - "package body ${1:$TM_FILENAME_BASE} is", - "\t$0", - "end package;" - ], - "description": "package body declaration" - }, - "Natural Range": { - "prefix": "natural_range", - "body": [ "natural range<>" ], - "description": "natural range statement" - } -} diff --git a/vscode-client/snippets/snippets.vhdl.libraries.json b/vscode-client/snippets/snippets.vhdl.library.json similarity index 93% rename from vscode-client/snippets/snippets.vhdl.libraries.json rename to vscode-client/snippets/snippets.vhdl.library.json index 880560c..a543068 100644 --- a/vscode-client/snippets/snippets.vhdl.libraries.json +++ b/vscode-client/snippets/snippets.vhdl.library.json @@ -48,7 +48,7 @@ "Use IEEE Package": { "prefix": "use_ieee", "body": [ - "use ieee.${1|std_logic_1164,std_logic_textio,numeric_std,math_real,math_complex|}.all;", + "use ieee.${1|std_logic_1164,std_logic_textio,numeric_std,numeric_bit,math_real,math_complex|}.all;", "$0" ], "description": "use clause IEEE standard package (std_logic_1164,std_logic_textio,numeric_std,math_real,math_complex)" diff --git a/vscode-client/snippets/snippets.vhdl.logic.json b/vscode-client/snippets/snippets.vhdl.logic.json new file mode 100644 index 0000000..bc1cd77 --- /dev/null +++ b/vscode-client/snippets/snippets.vhdl.logic.json @@ -0,0 +1,118 @@ +{ + "Case": { + "prefix": "case", + "body": [ + "case ${1:select} is", + "\twhen ${2:others} =>", + "\t\t${3:null;}", + "\t$0", + "end case;" + ], + "description": "case block" + }, + "If": { + "prefix": "if", + "body": [ + "if ${1:expression} then", + "\t$0", + "end if;" + ], + "description": "if block" + }, + "Elsif": { + "prefix": "elsif", + "body": [ + "elsif ${1:expression} then", + "\t$0" + ], + "description": "elsif block" + }, + "Else": { + "prefix": "else", + "body": [ + "else", + "\t$0" + ], + "description": "else block" + }, + "For": { + "prefix": "for", + "body": [ + "for ${1:i} in ${2:range} loop", + "\t$0", + "end loop;" + ], + "description": "for loop block" + }, + "Process Asynchronous": { + "prefix": "process_asynchronous", + "body": [ + "process (${1:clk}, ${2:reset})", + "begin", + "\tif $2 = ${3|'1','0'|} then", + "\t\t$4", + "\telsif rising_edge($1) then", + "\t\t$0", + "\tend if;", + "end process;" + ], + "description": "asynchronous process block" + }, + "Process Synchronous": { + "prefix": ["process_synchronous"], + "body": [ + "process (${1:clk})", + "begin", + "\tif rising_edge($1) then", + "\t\tif ${2:reset} = ${3|'1','0'|} then", + "\t\t\t$4", + "\t\telse", + "\t\t\t$0", + "\t\tend if;", + "\tend if;", + "end process;" + ], + "description": "clocked process block" + }, + "Process Clocked": { + "prefix": ["process_clocked"], + "body": [ + "process (${1:clk})", + "begin", + "\tif rising_edge($1) then", + "\t\t$0", + "\tend if;", + "end process;" + ], + "description": "clocked process block" + }, + "Process Combinatorial": { + "prefix": "process_combinatorial", + "body": [ + "process (${1:sensitivity_list})", + "begin", + "\t$0", + "end process;" + ], + "description": "combinatorial process block" + }, + "Process Combinatorial 2008": { + "prefix": "process_combinatorial_2008", + "body": [ + "process (all)", + "begin", + "\t$0", + "end process;" + ], + "description": "combinatorial process block (vhdl 2008)" + }, + "While": { + "prefix": "while", + "body": [ + "while ${1:expression} loop", + "\t$0", + "end loop;" + ], + "description": "while loop block" + } +} diff --git a/vscode-client/snippets/snippets.vhdl.types.json b/vscode-client/snippets/snippets.vhdl.types.json deleted file mode 100644 index fc9fe75..0000000 --- a/vscode-client/snippets/snippets.vhdl.types.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "Standard Logic": { - "prefix": ["std_logic", "sl"], - "body": [ "std_logic${1| := ,;|}$0" ], - "description": "std_logic type" - }, - "Standard Logic Type": { - "prefix": ["std_logic", "sl"], - "body": [ "std_logic${1| := ,;|}$0" ], - "description": "std_logic type" - }, - "Standard ULogic": { - "prefix": ["std_ulogic", "sul"], - "body": [ "std_ulogic${1| := ,;|}$0" ], - "description": "std_ulogic type" - }, - "Standard Logic Vector": { - "prefix": ["std_logic_vector", "slv"], - "body": [ "std_logic_vector($1 ${2|downto,to|} $3)${4| := ,;|}$0" ], - "description": "std_logic_vector type" - }, - "Standard ULogic Vector": { - "prefix": ["std_ulogic_vector", "sulv"], - "body": [ "std_ulogic_vector($1 ${2|downto,to|} $3)${4| := ,;|}$0" ], - "description": "std_ulogic_vector type" - }, - "Signed": { - "prefix": "signed", - "body": [ "signed($1 ${2|downto,to|} $3)${4| := ,;|}$0" ], - "description": "signed type" - }, - "Unsigned": { - "prefix": "unsigned", - "body": [ "unsigned(${1} ${2|downto,to|} ${3})${4| := ,;|}$0" ], - "description": "unsigned type" - } -}