Class CombinedDataModel


public class CombinedDataModel extends CombinedDictionaryModel<DataModel,ModelComponent>
Provide readonly access to the total data model including components in linked dictionaries. This class does not extend DictionaryObject.
  • Constructor Details

  • Method Details

    • getFactTypeByAlias

      public FactType getFactTypeByAlias(String alias)
      Get a particular facttype by alias
      Parameters:
      alias - alias of the facttype
      Returns:
      the facttype matching the alias. null if no such facttype.
    • getFactTypeByAlias

      public FactType getFactTypeByAlias(String alias, boolean translate)
    • getFactTypeByName

      public FactType getFactTypeByName(String name)
      Get a particular facttype by name; especially important for programming metadata where the alias is very likely to be changed (ADF-BC fact types, since their default aliases aren't user-friendly at all)
      Parameters:
      name - name of the facttype
      Returns:
      the facttype matching the alias. null if no such facttype.
    • getFunctionByAlias

      public Function getFunctionByAlias(String alias)
      Get function by alias. Functions may be overloaded in RL but we require unique aliases in SDK
      Parameters:
      alias - alias of the function
      Returns:
      the function matching the name
    • getFunctionByAlias

      public Function getFunctionByAlias(String alias, boolean translate)
    • getVariableByAlias

      public Variable getVariableByAlias(String alias)
      Get a global variable by alias
      Parameters:
      alias - alias of the variable
      Returns:
      the variable matching the name
    • getVariableByAlias

      public Variable getVariableByAlias(String alias, boolean translate)
    • getBucketSetByAlias

      public BucketSet getBucketSetByAlias(String alias)
      Get a bucketset by alias
      Parameters:
      alias - alias of the bucketset
      Returns:
      the bucketset matching the name
    • getBucketSetByAlias

      public BucketSet getBucketSetByAlias(String alias, boolean translate)
    • getDecisionFunctionByAlias

      public DecisionFunction getDecisionFunctionByAlias(String alias)
      Get a decision function by alias
      Parameters:
      alias - alias of the decision function
      Returns:
      the decision function matching the name
    • getDecisionFunctionByAlias

      public DecisionFunction getDecisionFunctionByAlias(String alias, boolean translate)
    • getDSLByValue

      public DSL getDSLByValue(String value)
      Get a DSL by its String value
      Parameters:
      value -
      Returns:
      the DSL matching the given value
    • getDSLByValue

      public DSL getDSLByValue(String value, boolean translate)
    • getFactTypes

      public List<FactType> getFactTypes()
      Get all FactTypes inside the data model
      Returns:
      all the FactTypes inside the data model
    • getVariables

      public List<Variable> getVariables()
      Get all global variables inside the data model
      Returns:
      all the global variables inside the data model
    • getVariables

      public List<Variable> getVariables(boolean includeDiffs)
      Get all global variables inside the data model
      Parameters:
      includeDiffs - boolean value to indicate if diffs should also be included in the result
      Returns:
      all the global variables inside the data model including/excluding diffs as specified by param
    • getVariables

      public List<Variable> getVariables(boolean includeDiffs, String filterPattern, boolean translate)
      Get a filtered list of Variables from the data model
      Parameters:
      includeDiffs - boolean value to indicate if diffs should also be included in the result
      filterPattern - pattern for filtering
      translate - boolean value to indicate if the translated value should be used for filtering
      Returns:
      Variables inside the data model that match the given filter pattern
    • getBucketSets

      public List<BucketSet> getBucketSets()
      Get all bucketsets inside the data model
      Returns:
      all the bucketsets inside the data model
    • getBucketSets

      public List<BucketSet> getBucketSets(boolean includeDiffs)
      Get all bucketsets inside the data model
      Parameters:
      includeDiffs - boolean value to indicate if diffs should also be included in the result
      Returns:
      all the bucketsets inside the data model including/excluding diffs as specified by param
    • getBucketSets

      public List<BucketSet> getBucketSets(boolean includeDiffs, String filterPattern, boolean translate)
      Get a filtered list of bucketsets from the data model
      Parameters:
      includeDiffs - boolean value to indicate if diffs should also be included in the result
      filterPattern - pattern for filtering
      translate - boolean value to indicate if the translated value should be used for filtering
      Returns:
      bucketsets inside the data model that match the given filter pattern
    • getDecisionFunctions

      public List<DecisionFunction> getDecisionFunctions()
      Get all decision functions inside the data model
      Returns:
      all the decision functions inside the data model
    • getDecisionFunctions

      public List<DecisionFunction> getDecisionFunctions(boolean includeDiffs)
    • getFunctions

      public List<Function> getFunctions()
      Get all functions inside the data model
      Returns:
      all the functions inside the data model
    • getFunctions

      public List<Function> getFunctions(boolean includeDiffs)
    • getDSLs

      public List<DSL> getDSLs()
      Get all DSLs inside the data model
      Returns:
      all the DSLs inside the data model
    • getDSLs

      public List<DSL> getDSLs(boolean includeDiffs)
      Get all DSLs inside the data model
      Parameters:
      includeDiffs - boolean value to indicate if diffs should also be included in the result
      Returns:
      all the DSLs inside the data model including/excluding diffs as specified by param
    • getDSLs

      public List<DSL> getDSLs(boolean includeDiffs, String filterPattern, boolean translate)
      Get a filtered list of DSLs from the data model
      Parameters:
      includeDiffs - boolean value to indicate if diffs should also be included in the result
      filterPattern - pattern for filtering
      translate - boolean value to indicate if the translated value should be used for filtering
      Returns:
      DSLs inside the data model that match the given filterPattern
    • getJavaFactTypes

      public List<JavaFactType> getJavaFactTypes()
      Get all Java FactTypes inside the data model (excluding JAXB fact type)
      Returns:
      all the Java FactTypes inside the data model
    • getJavaFactTypes

      public List<JavaFactType> getJavaFactTypes(boolean includeDiffs)
    • getJaxbFactTypes

      public List<JaxbFactType> getJaxbFactTypes()
      Get all Jaxb FactTypes inside the data model
      Returns:
      all the Jaxb FactTypes inside the data model
    • getJaxbFactTypes

      public List<JaxbFactType> getJaxbFactTypes(boolean includeDiffs)
    • getRLFactTypes

      public List<RLFactType> getRLFactTypes()
      Get all RL FactTypes inside the data model
      Returns:
      all the RL FactTypes inside the data model
    • getRLFactTypes

      public List<RLFactType> getRLFactTypes(boolean includeDiffs)
    • getPrimitiveTypes

      public List<PrimitiveFactType> getPrimitiveTypes()
      Get all primitive FactTypes inside the data model. Look in all dictionaries, even though they should only be in 1
      Returns:
      all the primitive FactTypes inside the builtin data model
    • getAdfBcFactTypes

      public List<AdfBcFactType> getAdfBcFactTypes()
      Get all AdfBc FactTypes inside the data model
      Returns:
      all the AdfBc FactTypes inside the data model
    • getAdfBcFactTypes

      public List<AdfBcFactType> getAdfBcFactTypes(boolean includeDiffs)
    • getAlias

      public String getAlias(DictionaryComponent c)
      Get alias for a dictionary component. If component in a linked dictionary, that dictonary's alias is prepended as a qualifier.
      Overrides:
      getAlias in class CombinedDictionaryModel<DataModel,ModelComponent>
      Parameters:
      c - DictionaryComponent
      Returns:
      alias of c, possibly qualified with containing dictionary's alias
    • getAlias

      public String getAlias(DictionaryComponent c, boolean translate)
      Get alias for a dictionary component. If component in a linked dictionary, that dictonary's alias is prepended as a qualifier.
      Overrides:
      getAlias in class CombinedDictionaryModel<DataModel,ModelComponent>
      Parameters:
      c - DictionaryComponent
      translate - flag to translate alias
      Returns:
      alias of c, possibly qualified with containing dictionary's alias
    • getEnumTypeChoices

      public List<Choice> getEnumTypeChoices()
      Get enum type options.
      Returns:
      type options
    • toString

      public String toString()
      Get String representation of all dictionaries' datamodel
      Overrides:
      toString in class Object
      Returns:
      String representation of datamodels in all linked dictionaries
    • getAssociatedBucketSet

      public BucketSet getAssociatedBucketSet(DOID id)
      Get bucket set associated with given id
      Parameters:
      id - id of Property, Function, or Method
      Returns:
      BucketSet or null if none associated
    • isComparable

      public boolean isComparable(DOID typeID1, DOID typeID2)
    • getComparableConversion

      public String[] getComparableConversion(DOID typeID1, DOID typeID2)
      Returns String[3] if the argument types can be compared, else null. The 3 strings are RL snippets to effect the comparison, and are to be inserted: 0: before the operator 1: after the operator 2: after the right operand
      Parameters:
      typeID1 -
      typeID2 -
      Returns:
      3 conversion Strings or null if conversion not allowed
    • isAssignableFrom

      public boolean isAssignableFrom(DOID ltypeID, DOID rtypeID)
    • getAssignableFromConversion

      public String[] getAssignableFromConversion(DOID ltypeID, DOID rtypeID, CombinedDataModel.ConversionMode mode)
      Parameters:
      ltypeID -
      rtypeID -
      Returns:
      String[2] of RL to insert before/after the RL for the RHS
    • isFullyComparable

      public boolean isFullyComparable(DOID typeID1, DOID typeID2)
      both classes are assignable to a common type. that type implements Comparable in it's ancestor tree. any changes made here may need to also be changed in oracle.rules.rl.analyze.TypeHelper
      Parameters:
      typeID1 - DOID of first type
      typeID2 - DOID of second type
      Returns:
      boolean
    • getUnboxConversionFrom

      public static String getUnboxConversionFrom(DOID typeID)
    • getBigUnboxConversionTo

      public static String getBigUnboxConversionTo(DOID typeID)
    • getUnboxTypeID

      public static DOID getUnboxTypeID(DOID typeID)
    • getBoxConversionFrom

      public static String[] getBoxConversionFrom(DOID typeID)
    • isBucketSetCompatible

      public boolean isBucketSetCompatible(DOID ltypeID, DOID rtypeID, boolean range)
    • getDataModelQuerier

      public DataModelQuerier getDataModelQuerier()
    • setDataModelQuerier

      public void setDataModelQuerier(DataModelQuerier dmq)
    • isCollection

      public boolean isCollection(DOID doid)
    • isComparable

      public boolean isComparable(DOID doid)
    • generateRL

      public StringBuilder generateRL() throws SDKException
      Validates then generates RL code for the data model.
      Returns:
      A String containing the executable RL rule set
      Throws:
      SDKException
    • getFactTypeAssociations

      public Set<DOID> getFactTypeAssociations(DOID id)