Comments (3)
I dont have anything built-in that would query user-properties directly like that.
This isn't documented, but this is how you could fetch the names of all UDPs that exist in the current design:
rdlc = RDLCompiler()
# [compile & elaborate as usual...]
all_udp_names = list(rdlc.env.property_rules.user_properties.keys())
Perhaps I'll break that out into a more official method since that seems useful.
Combining the above with the Node.descendants() method to traverse all child instances, you could probably accomplish what you want.
Regarding the boolean getting cast to a 1/0: I'll look into that. Officially, the RDL spec says that true
and false
are simply aliases for 1
and 0
, but I've been striving to preserve the boolean type whenever possible since it's less surprising to the user.
from systemrdl-compiler.
Thanks a lot for the pointer! With this I could query the information I was looking for.
from systemrdl-compiler.
Added some more mechanisms to list UDPs in the upcoming v1.12 release:
- Added RDLCompiler.list_udps()
- Added more options to Node.list_properties()
Also fixed the boolean issue.
Thank you again for reporting!
from systemrdl-compiler.
Related Issues (20)
- regfile inside addrmap does not compile HOT 1
- Cannot alias registers with we = true HOT 2
- Add ability to inject define macros into preprocessor
- Empty addrmap causes compiler to crash HOT 4
- Software-writable field spanning multiple words should cause error message (accesswidth/regwidth problem) HOT 1
- User defined property default for array type causes exception HOT 2
- [BUG] Parameter internal cleanup after first elaboration HOT 1
- Add support for assigning references in importer API
- Unintended `external` applied to `addrmap` instance HOT 3
- missing parameterization in the component hierarchy HOT 13
- Add method to generate a globally scoped type name to Node API HOT 1
- if struct is not fully defined, compiler crashes, it should point the line with to the error in the SystemRDL file HOT 2
- detecting name collisions during path serialization HOT 1
- Allow Elaboration without addrmap HOT 1
- Set abbreviated Node.type_name for long parameterized types HOT 1
- [FEATURE] property_src_ref needed for UserEnum and UserEnumMember
- Describe how addressing is impacted by ispresent in docs HOT 2
- `define for value replacement does not work HOT 2
- Compatibility between UDP `default` property and `UDPDefinition.default_assignment` HOT 4
- [BUG] [QUESTION] - Importer API support for signals HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from systemrdl-compiler.