mirror of
				https://github.com/SpinalHDL/SpinalTemplateSbt.git
				synced 2025-10-25 16:58:45 +08:00 
			
		
		
		
	Merge 789f0f18d5 into 1629b51311
				
					
				
			This commit is contained in:
		| @@ -1,5 +1,40 @@ | |||||||
| version = 3.6.0 | version = 3.6.0 | ||||||
| runner.dialect = scala212 | runner.dialect = scala212 | ||||||
| align.preset = some | align.preset = some | ||||||
| maxColumn = 120 | align.tokens."+" = [ | ||||||
|  |     { | ||||||
|  |         code = "=" | ||||||
|  |         owners = [{ | ||||||
|  |             regex = "Defn\\.Val" | ||||||
|  |         }] | ||||||
|  |     } | ||||||
|  |     { | ||||||
|  |         code = ":=" | ||||||
|  |         owners = [{ | ||||||
|  |             regex = "Term\\.ApplyInfix" | ||||||
|  |             parents = ["Term\\.Block|Template"] | ||||||
|  |         }] | ||||||
|  |     } | ||||||
|  |     { | ||||||
|  |         code = "#=" | ||||||
|  |         owners = [{ | ||||||
|  |             regex = "Term\\.ApplyInfix" | ||||||
|  |             parents = ["Term\\.Block|Template"] | ||||||
|  |         }] | ||||||
|  |     } | ||||||
|  |     { | ||||||
|  |         code = "port" | ||||||
|  |         owners = [{ | ||||||
|  |             regex = "Term\\.ApplyInfix" | ||||||
|  |             parents = ["Defn\\.Val"] | ||||||
|  |         }] | ||||||
|  |     } | ||||||
|  |     { | ||||||
|  |         code = "->" | ||||||
|  |         owners = [{ | ||||||
|  |             regex = "Term\\.ApplyInfix" | ||||||
|  |         }] | ||||||
|  |     } | ||||||
|  | ] | ||||||
| docstrings.wrap = no | docstrings.wrap = no | ||||||
|  | docstrings.oneline = fold | ||||||
|   | |||||||
							
								
								
									
										190
									
								
								.vscode/SpinalHDL.code-snippets
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										190
									
								
								.vscode/SpinalHDL.code-snippets
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,190 @@ | |||||||
|  | { | ||||||
|  | 	"Import spinal.core": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "importcore", | ||||||
|  | 		"body": ["import spinal.core._", ""] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"Import spinal.lib": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "importlib", | ||||||
|  | 		"body": ["import spinal.lib.${1:_}", ""] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"Import spinal.core.sim": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "importsim", | ||||||
|  | 		"body": ["import spinal.core.sim._", ""] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New component": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "component", | ||||||
|  | 		"body": [ | ||||||
|  | 			"case class $1($2) extends Component {", | ||||||
|  | 			"  val io = new Bundle {", | ||||||
|  | 			"    $0", | ||||||
|  | 			"  }", | ||||||
|  | 			"", | ||||||
|  | 			"  ", | ||||||
|  | 			"}" | ||||||
|  | 		], | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"Component to function": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "fncomp", | ||||||
|  | 		"body": [ | ||||||
|  | 			"object ${1/\\(.*//} {", | ||||||
|  | 			"  def apply($2: $3): $4 = {", | ||||||
|  | 			"    val ${1/([^(]*).*/${1:/camelcase}/} = $1($6)", | ||||||
|  | 			"    ${1/([^(]*).*/${1:/camelcase}/}.io.$2 := $2", | ||||||
|  | 			"    ${1/([^(]*).*/${1:/camelcase}/}.io.$5", | ||||||
|  | 			"  }", | ||||||
|  | 			"}" | ||||||
|  | 		], | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"Component to function2": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "fncomp2", | ||||||
|  | 		"body": [ | ||||||
|  | 			"object ${1/\\(.*//} {", | ||||||
|  | 			"  def apply($2: $3, $4: $5): $6 = {", | ||||||
|  | 			"    val ${1/([^(]*).*/${1:/camelcase}/} = $1($8)", | ||||||
|  | 			"    ${1/([^(]*).*/${1:/camelcase}/}.io.$2 := $2", | ||||||
|  | 			"    ${1/([^(]*).*/${1:/camelcase}/}.io.$4 := $4", | ||||||
|  | 			"    ${1/([^(]*).*/${1:/camelcase}/}.io.$7", | ||||||
|  | 			"  }", | ||||||
|  | 			"}" | ||||||
|  | 		], | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New configurable component": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "compcfg", | ||||||
|  | 		"body": [ | ||||||
|  | 			"case class ${2:${1}Cfg} (", | ||||||
|  | 			"  $3", | ||||||
|  | 			")", | ||||||
|  | 			"", | ||||||
|  | 			"class $1(cfg: $2) extends Component {", | ||||||
|  | 			"  val io = new Bundle {", | ||||||
|  | 			"    $0", | ||||||
|  | 			"  }", | ||||||
|  | 			"", | ||||||
|  | 			"  ", | ||||||
|  | 			"}" | ||||||
|  | 		], | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New entity/architecture-like": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "entarch", | ||||||
|  | 		"body": [ | ||||||
|  | 			"abstract class $1$2 extends Component {", | ||||||
|  | 			"  val io = new Bundle {", | ||||||
|  | 			"    $0", | ||||||
|  | 			"  }", | ||||||
|  | 			"}", | ||||||
|  | 			"", | ||||||
|  | 			"class $1$3 extends $1$4 {", | ||||||
|  | 			"  ", | ||||||
|  | 			"}", | ||||||
|  | 		], | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New input": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "pin", | ||||||
|  | 		"body": "val $1 = in port ", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New output": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "pout", | ||||||
|  | 		"body": "val $1 = out port ", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New master port": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "pmaster", | ||||||
|  | 		"body": "val $1 = master port ", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"New slave port": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "pslave", | ||||||
|  | 		"body": "val $1 = slave port ", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"Bits": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "nbits", | ||||||
|  | 		"body": "Bits($1 bits)", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"UInt": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "nuint", | ||||||
|  | 		"body": "UInt($1 bits)", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"SInt": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "nsint", | ||||||
|  | 		"body": "SInt($1 bits)", | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"...ing flag": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "doing", | ||||||
|  | 		"body": ["val ${2:${1}ing} = False", "def $1(): Unit = $2 := True", ""] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"...Flag flag": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "flag", | ||||||
|  | 		"body": ["val ${2:${1}Flag} = False", "def $1(): Unit = $2 := True", ""] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"'def' function mux": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "fnmux", | ||||||
|  | 		"body": ["$1 := $2", "def $3(): Unit = $1 := $0"] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"BlackBox wrapper": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "blackboxwrapper", | ||||||
|  | 		"body": [ | ||||||
|  | 			"class $1 extends Area {", | ||||||
|  | 			"  val io = new Bundle {", | ||||||
|  | 			"    ${0:// Direction-less Spinal ports}", | ||||||
|  | 			"  }", | ||||||
|  | 			"", | ||||||
|  | 			"  class $1 extends BlackBox {", | ||||||
|  | 			"    // Ports of the blackboxed item", | ||||||
|  | 			"  }", | ||||||
|  | 			"", | ||||||
|  | 			"  val bb = new $1", | ||||||
|  | 			"  bb.setPartialName(\"\")", | ||||||
|  | 			"", | ||||||
|  | 			"  // Connection logic", | ||||||
|  | 			"}" | ||||||
|  | 		] | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	"State machine": { | ||||||
|  | 		"scope": "scala", | ||||||
|  | 		"prefix": "fsm", | ||||||
|  | 		"body": [ | ||||||
|  | 			"val $1 = new StateMachine {", | ||||||
|  | 			"  val $2, $3 = new State", | ||||||
|  | 			"  setEntry($2)", | ||||||
|  | 			"", | ||||||
|  | 			"  $0", | ||||||
|  | 			"}" | ||||||
|  | 		] | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -10,6 +10,7 @@ val spinalIdslPlugin = compilerPlugin("com.github.spinalhdl" %% "spinalhdl-idsl- | |||||||
| lazy val projectname = (project in file(".")) | lazy val projectname = (project in file(".")) | ||||||
|   .settings( |   .settings( | ||||||
|     Compile / scalaSource := baseDirectory.value / "hw" / "spinal", |     Compile / scalaSource := baseDirectory.value / "hw" / "spinal", | ||||||
|  |     Test / scalaSource := baseDirectory.value / "tb" / "spinal", | ||||||
|     libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin) |     libraryDependencies ++= Seq(spinalCore, spinalLib, spinalIdslPlugin) | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								build.sc
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								build.sc
									
									
									
									
									
								
							| @@ -6,7 +6,8 @@ object projectname extends SbtModule { | |||||||
|   def scalaVersion = "2.13.14" |   def scalaVersion = "2.13.14" | ||||||
|   override def millSourcePath = os.pwd |   override def millSourcePath = os.pwd | ||||||
|   def sources = T.sources( |   def sources = T.sources( | ||||||
|     millSourcePath / "hw" / "spinal" |     millSourcePath / "hw" / "spinal", | ||||||
|  |     millSourcePath / "tb" / "spinal" | ||||||
|   ) |   ) | ||||||
|   def ivyDeps = Agg( |   def ivyDeps = Agg( | ||||||
|     ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion", |     ivy"com.github.spinalhdl::spinalhdl-core:$spinalVersion", | ||||||
|   | |||||||
							
								
								
									
										0
									
								
								tb/verilog/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tb/verilog/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
								
								
									
										0
									
								
								tb/vhdl/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tb/vhdl/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
		Reference in New Issue
	
	Block a user
	 Côme
					Côme