7 Commits

Author SHA1 Message Date
Mark Ryan
3c73392134
Add CSR encodings for Go and remove call to Go fmt (#329)
* Don't run go fmt error in go_utils.py

go_utils.py currently runs go fmt to pretty print the generated
inst.go file. Unfortunately, this call to go fmt always fails as
inst.go contains an internal import and go fmt is being run out of
tree. Here we remove the code that attempts to format inst.go
resulting in a clean run of go_utils.py without any errors. The
generated file, inst.go, can be formatted when it's copied into the
Go source tree, prior to its submission to the Golang project.

* Add CSR support to go_utils.py

go_utils.py now generates a Go map that maps CSR numbers to CSR
names. The resulting map is written into inst.go for use by the
Go assembler.
2025-01-09 14:50:24 -08:00
Tim Hutt
359a94356d
Enable Pylint in CI and fix its errors (#311)
* Remove wildcard imports

Use explicit imports rather than wildcards. This is more maintainable.

* Enable Pylint in CI and fix its errors

The main fixes were:

* Specify encoding for all file opens. By default it depends on environment variables which is bad.
* Use `with` to open files. Otherwise they don't necessarily get closed.

There were also a few minor things like using `enumerate`, not using objects as default arguments, etc. In some cases I slightly refactored the code.
2024-11-05 06:32:12 -08:00
Tim Hutt
284a5fa0f7 Add static type hints
This makes the code easier to understand and navigate, and also detected a few of bugs:

1. Missing brackets on e.upper. (Fixed)
2. Not strictly related to types, but a lot of the regexes were not raw strings and therefore contained invalid escape sequences. Python prints a warning about these in recent versions. (Fixed)
3. Expression in `process_pseudo_instructions()` that is always false. (Not fixed)
4. Missing definition of `log_and_exit()`. (Fixed)

This is validated via pre-commit in CI.
2024-10-31 11:42:41 +00:00
Jay Dev Jha
14d6674bed Remove commented out import lines
Signed-off-by: Jay Dev Jha <jaydev.neuroscitech@gmail.com>
2024-10-30 14:00:28 +00:00
Tim Hutt
938e6d5b03 Remove unused imports
Remove unused Python import statements.
2024-10-29 21:11:51 +00:00
IIITM-Jay
41fc44b695 removed walrus operator 2024-10-09 20:50:59 +05:30
IIITM-Jay
1b0ef5d896 Refactored and Optimized Logic:: Parser Logic, Latex Based Output & Shared Modules 2024-09-17 00:53:00 +05:30