OCLOperators constraints
No edit summary
Line 17: Line 17:
This operator earlier resulted in a array of booleans with the constraint result. To get the same functionality now, add '''.broken=false''' to the end of the previous expression.
This operator earlier resulted in a array of booleans with the constraint result. To get the same functionality now, add '''.broken=false''' to the end of the previous expression.


Like this;
Like this, used with forAll;
  self.constraints.broken=false
  self.constraints->forAll(c|c.broken=false)
  [[Category:OCLOperators]]
  [[Category:OCLOperators]]
See also: [[Constraints]], [[OCLOperators brokenConstraints]]
See also: [[Constraints]], [[OCLOperators brokenConstraints]]

Revision as of 18:44, 14 December 2018

The operator return both meta information about a class's constraints and if it's currently broken.

The return value is a collection of Tuple containing the following

  1. Name
  2. Description
  3. IsDeleteConstraint: True/False
  4. ErrorLevel: #Information, #Warning or #Error
  5. Broken:Evaluated and Subscribed state of the constraint
Examples

To check if any constraint with error level Error is broken;

self.constraints->select(c|(c.ErrorLevel = #Error) and c.Broken)->isEmpty  -- Returns True if no errors

Returning a collection of Descriptions of broken Warning constraints;

self.constraints->select(c|(c.ErrorLevel = #Warning) and c.Broken)->collect(c|c.Description)
Please note

This operator earlier resulted in a array of booleans with the constraint result. To get the same functionality now, add .broken=false to the end of the previous expression.

Like this, used with forAll;

self.constraints->forAll(c|c.broken=false)

See also: Constraints, OCLOperators brokenConstraints

This page was edited 101 days ago on 02/10/2024. What links here