Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
language:namespaces [2020/05/01 16:48] rajit [Importing namespaces] |
language:namespaces [2024/07/27 12:52] (current) rajit [Renaming namespaces] |
||
---|---|---|---|
Line 12: | Line 12: | ||
A namespace is created by using the '' | A namespace is created by using the '' | ||
- | < | + | < |
namespace lib { | namespace lib { | ||
... | ... | ||
Line 38: | Line 38: | ||
namespaces is shown below. | namespaces is shown below. | ||
- | < | + | < |
namespace datapath { | namespace datapath { | ||
export defproc bus_interface(...) { ... } | export defproc bus_interface(...) { ... } | ||
Line 64: | Line 64: | ||
the entire namespace '' | the entire namespace '' | ||
- | < | + | < |
namespace datapath { | namespace datapath { | ||
export defproc bus_interface(...) { ... } | export defproc bus_interface(...) { ... } | ||
Line 93: | Line 93: | ||
The basic form of import statement is shown below: | The basic form of import statement is shown below: | ||
- | < | + | < |
import " | import " | ||
... | ... | ||
Line 111: | Line 111: | ||
hierarchy. The import statement | hierarchy. The import statement | ||
- | < | + | < |
import processor:: | import processor:: | ||
</ | </ | ||
Line 117: | Line 117: | ||
is equivalent to the following: | is equivalent to the following: | ||
- | < | + | < |
import " | import " | ||
</ | </ | ||
Line 123: | Line 123: | ||
It assumes that the file '' | It assumes that the file '' | ||
'' | '' | ||
- | '' | + | '' |
- | ===== Opening namespaces ===== | + | <code act> |
+ | import foo; | ||
+ | </ | ||
- | If there are two different files that define | + | would do the following: |
+ | * Look for '' | ||
+ | * If unsuccessful, | ||
+ | * If unsuccessful, report an error | ||
- | To resolve this issue, ACT provides a way to rename a namespace | + | After the import, the specified |
- | < | ||
- | import " | ||
- | open lib -> lib1; | ||
- | import " | ||
- | open lib -> lib2; | ||
- | </ | ||
- | In this example, the '' | + | ===== Opening namespaces ===== |
- | has occured, there cannot be any naming conflicts. This version of '' | + | |
- | A second issue is one that is more about convenience. Consider | + | If |
- | project | + | to have each component/ |
own namespace to avoid naming conflicts. This situation can result in | own namespace to avoid naming conflicts. This situation can result in | ||
very long type names. Plus it would be more bookkeeping to have to | very long type names. Plus it would be more bookkeeping to have to | ||
create a test environment for the types within, say, | create a test environment for the types within, say, | ||
'' | '' | ||
- | because not all types might be exported! | + | because not all types might be exported! |
- | < | + | As a syntactic convenience, |
+ | |||
+ | < | ||
import " | import " | ||
open processor:: | open processor:: | ||
Line 164: | Line 164: | ||
at the beginning of an ACT file. | at the beginning of an ACT file. | ||
+ | ===== Renaming namespaces ===== | ||
+ | |||
+ | |||
+ | If there are two different files that define the same namespace (say defined in multiple projects), importing both the files may result in type conflicts. Consider a scenario where we have two '' | ||
+ | |||
+ | To resolve this issue, ACT provides a way to rename a namespace that has been imported. | ||
+ | |||
+ | <code act> | ||
+ | import " | ||
+ | open lib -> lib1; | ||
+ | import " | ||
+ | open lib -> lib2; | ||
+ | </ | ||
+ | |||
+ | In this example, the '' | ||
+ | has occured, there cannot be any naming conflicts. This version of '' | ||
+ | |||
+ | Another renaming scenario that can be useful is to move a namespace into another one. | ||
+ | <code act> | ||
+ | import lib; | ||
+ | import lib => priv; | ||
+ | </ | ||
+ | The first import statement above loads in the '' |