Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
language:types2:data [2025/04/21 14:36] – [Pure structures] rajit | language:types2:data [2025/05/02 10:13] (current) – rajit | ||
---|---|---|---|
Line 5: | Line 5: | ||
* // | * // | ||
* //parameter structures//, | * //parameter structures//, | ||
+ | |||
+ | In addition, data types can also be // | ||
===== Data types ===== | ===== Data types ===== | ||
Line 130: | Line 132: | ||
programming capability within ACT. | programming capability within ACT. | ||
+ | The following is an example of a pure structure: | ||
+ | <code act> | ||
+ | deftype purestruct (int< | ||
+ | </ | ||
+ | |||
+ | Pure structures can be converted to and from an '' | ||
+ | |||
+ | <code act> | ||
+ | purestruct p; | ||
+ | int< | ||
+ | ... | ||
+ | chp { | ||
+ | ... | ||
+ | x := int(p); | ||
+ | ... | ||
+ | p := purestruct(x); | ||
+ | ... | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | In the example above, the ' | ||
+ | <code act> | ||
+ | ... | ||
+ | x := {p.a, p.b, p.q}; | ||
+ | ... | ||
+ | </ | ||
+ | |||
+ | Similarly, the '' | ||
===== Parameter structures ===== | ===== Parameter structures ===== | ||
+ | It can be convenient to group a collection of parameters for readability/ | ||
+ | <code act> | ||
+ | | ||
+ | </ | ||
+ | |||
+ | This defines '' | ||
+ | <code act> | ||
+ | template <myps p> defproc myprocess (bool x[10]) | ||
+ | { | ||
+ | // use p.a, p.b etc. | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | Parameter structures can be initialized element-by-element in the usual way, or by using a built-in constructor for them: | ||
+ | <code act> | ||
+ | myps p; | ||
+ | p.a = 5; // element initialization | ||
+ | |||
+ | myps q; | ||
+ | |||
+ | q = myps (4, 8, false); | ||
+ | </ | ||
+ | |||
+ | ===== Enumerations ===== | ||
+ | |||
+ | A user-defined enumeration can be specified as follows: | ||
+ | |||
+ | <code act> | ||
+ | defenum myenum { | ||
+ | ADD, SUB, MULT | ||
+ | }; | ||
+ | </ | ||
+ | |||
+ | This defines an enumeration called '' | ||
+ | |||
+ | The enumeration constants can be accessed using the enumeration type name as follows: | ||
+ | |||
+ | <code act> | ||
+ | ... | ||
+ | myenum x; | ||
+ | ... | ||
+ | chp { | ||
+ | ... | ||
+ | x := myenum.SUB; | ||
+ | ... | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | Trying to set an enumeration to an integer will result in a type error: | ||
+ | |||
+ | <code act> | ||
+ | chp { | ||
+ | ... | ||
+ | x := 1; | ||
+ | ... | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | will lead to: | ||
+ | |||
+ | < | ||
+ | -[ERROR]-> | ||
+ | stmt: x := 1 | ||
+ | Enumeration/ | ||
+ | </ | ||
+ | |||
+ | However, sometimes a user may want to use user-defined enumerations as integers. In order to do so, | ||
+ | the enumeration can be declared to be a valid integer as follows: | ||
+ | |||
+ | <code act> | ||
+ | defenum myenum : int { | ||
+ | ADD, SUB, MULT | ||
+ | }; | ||
+ | </ | ||
+ | This version will permit integer assignments. Note that it is up to the user to ensure that integer assignments are within range. The ACT simulator '' | ||