Zachary Snow
0a65abd614
full support for package and class subroutine invocations
2021-05-29 22:34:03 -04:00
Zachary Snow
c0282862ea
error if procedural block has a decl after a stmt
2021-05-29 21:55:50 -04:00
Zachary Snow
7ffea36ddd
improved handling of string parameters
...
- variable-size string parameter conversion restricted to modules which
depend on the size of the string parameter
- string localparams are typed as appropriately sized vectors
- remove ordered parameter binding logic from string param conversion
2021-05-28 20:27:14 -04:00
Zachary Snow
280d3dc5a6
fix codegen for generic interface types
2021-05-25 22:10:33 -04:00
Zachary Snow
315733f293
output unpacked localparam types as typedefs
2021-05-24 23:06:07 -04:00
Zachary Snow
74a10a8e13
fix else branch association in verbose mode
2021-05-23 15:54:49 -04:00
Zachary Snow
fbde7aaca6
faster test runner pattern matching
2021-05-22 22:00:32 -04:00
Zachary Snow
801955ffab
support for empty port connections
2021-05-21 14:08:12 -04:00
Zachary Snow
eae46b7ad2
improved interface modport type checking
2021-05-12 22:00:22 -04:00
Zachary Snow
68fa8290c0
interface instantiation checks for errant name resolution
2021-05-09 19:32:39 -04:00
Zachary Snow
a6ebc0e3ff
fix elaboration of struct array fields referenced hierarchically
...
- `expr.name[idx]` considers `expr.name` could be a struct array
- remove fallback struct type lookups which were guaranteed to fail
2021-05-09 19:24:23 -04:00
Zachary Snow
f71accb3c8
fix simple delayed multi-pack conversion within interface
2021-05-09 18:06:46 -04:00
Zachary Snow
12c57ecc24
preprocessor cleanup and extended test coverage
2021-05-06 16:14:41 -04:00
Zachary Snow
2885e21cdd
fix handling of preproc conditionals within macros
...
- preproc reads identifiers unconditionally
- drop leading whitespace for default macro args
- very minor preproc cleanup
2021-05-04 16:19:07 -04:00
Zachary Snow
c59334ceb8
allow preproc idents to begin with macro arguments
2021-05-03 17:53:41 -04:00
Zachary Snow
10b30d7d1e
detect infinite include loops
2021-05-01 21:12:00 -04:00
Zachary Snow
5cc4dce01f
refactor positional binding checking and resolution
2021-04-30 14:10:09 -04:00
Zachary Snow
ba270acb0e
forbid mixing ordered and named port or param bindings
2021-04-29 15:32:54 -04:00
Zachary Snow
b0b7962529
additional dimension query coverage
2021-04-27 21:25:44 -04:00
Zachary Snow
e6263d6caa
support function calls within type parameters
2021-04-26 18:13:36 -04:00
Zachary Snow
5a8801a45f
allow trailing commas in parameter and port lists and bindings
2021-04-23 16:17:18 -04:00
Zachary Snow
bdc7b5ad69
replace some invariant errors with pattern matching
2021-04-21 19:50:03 -04:00
Zachary Snow
cfff359b51
isolate parse state abstraction
2021-04-20 19:47:55 -04:00
Zachary Snow
499bd5873e
fall back to lower-precedence multipack transformations
2021-04-16 17:46:40 -04:00
Zachary Snow
dc19b5f944
use cabal package version as fallback when repo is missing
2021-04-15 13:47:45 -04:00
Zachary Snow
ecee8b3358
support for interface based typedefs
2021-04-15 11:35:20 -04:00
Zachary Snow
1ba5ab2739
size using lhs for reg continuous assignment indirection
2021-04-14 14:31:31 -04:00
Zachary Snow
44afcf5b29
improved handling of break statement
...
- fix preservation of loop variables when breaking
- extend Yosys-compatible constant loop conversion to support loop
variables declared outside of the looop
2021-04-14 13:16:27 -04:00
Zachary Snow
04d6fa6199
fix additional type parameter instantiation issues
...
- avoid premature conversion of default struct type parameters
- allow use of $clog2, $signed, and $unsigned in type parameters
- more thorough and efficient top reference ident renaming
- precede type param conversion with hier const pass
2021-04-13 22:22:33 -04:00
Zachary Snow
623f0a2d39
fix missing top reference renames in param type instantiation
...
- renaming applies to nodes within generate blocks
- renaming applies to LHSs
2021-04-13 16:47:00 -04:00
Zachary Snow
4ddbff9b97
keep enum localparam types for later resolution
2021-04-13 15:08:38 -04:00
Zachary Snow
eeeade3e19
allow packages to reference their own items explicitly
2021-04-13 14:44:42 -04:00
Zachary Snow
c0b8ba17de
simplify interface port type representation
2021-04-13 10:45:26 -04:00
Zachary Snow
7f79147c7b
initial parameterized class data type support
2021-04-12 21:22:14 -04:00
Zachary Snow
5f26e755c9
preserve implicitness of task and function ports
2021-04-10 20:45:40 -04:00
Zachary Snow
d0d897b4e4
package name resolution visits enum base types
2021-04-09 14:07:34 -04:00
Zachary Snow
dce7f14909
fix precedence of non-blocking assignment
2021-04-08 17:04:28 -04:00
Zachary Snow
2a4d1cc5a8
more useful error message on bad stmt asgn
2021-04-08 00:42:18 -04:00
Zachary Snow
5ac7a79f8b
add warning when no input files are specified
2021-03-29 11:16:53 -04:00
Zachary Snow
c6dbdd09ca
preliminary language support for basic classes
2021-03-22 20:01:38 -04:00
Zachary Snow
c0cac48642
release v0.0.7
2021-03-19 12:19:08 -04:00
Zachary Snow
c29c6e0d5e
fix stack sdist warnings
2021-03-10 17:14:24 -05:00
Zachary Snow
f5fcde1659
increase minimum allocation area size to 32m
2021-03-10 17:13:40 -05:00
Zachary Snow
c048ce5b36
remove long deprecated flags
...
- remove -o/--oneunit, has been the default behavior
- revise test coverage for default vs. siloed behavior
- add test to ensure README usage matches CLI help text
- remove -V alias for --version
- remove -? alias for --help
2021-03-10 13:02:54 -05:00
Zachary Snow
9ae29853d5
use iverilog 11 in Linux CI
2021-03-09 18:46:37 -05:00
Zachary Snow
38cc25fad6
more test coverage and dead code removal
2021-03-09 15:48:10 -05:00
Zachary Snow
937a583e41
fix simple loop jump guarded conversion
2021-03-09 12:42:34 -05:00
Zachary Snow
31ebf181bb
improved parse errors for certain unmatched tokens
2021-03-06 15:03:04 -05:00
Zachary Snow
77b2f8b6ce
improve for decl error messaging
2021-03-05 19:58:44 -05:00
Zachary Snow
da07619642
support const declarations of alias types
2021-02-23 16:45:53 -05:00