Class BucketSet
- All Implemented Interfaces:
Serializable
,Cloneable
,Map<String,
Object>
- enumerated list of values (FORM_LOV).
- a list of value ranges (FORM_RANGE). Ranges are determined by storing their endpoint values.
- default based on datatype (FORM_DEFAULT). Numeric and Calendar types
are assumed to be range. Other types (boolean and string) are assumed to be LOV.
See
isRange()
A BucketSet is always associated with every Dimension in a decision table. Each DimensionNode in the Dimension takes its values from this BucketSet. To facilitate reuse of BucketSets, a BucketSet can be named and stored in the RuleDictionary data model. In addition, class Properties, class Methods, and Functions can be associated with a named BucketSet (if their types are equal). In this way, a dimension in a decision table whose dimension expression is a property, method call, or function call can automatically be assigned a BucketSet, and thus the choice lists for the DimensionNodes will be populated with the predefined buckets.
If there is no predefined BucketSet, then a local BucketSet will be built up dynamically as new buckets are entered into the DimensionNodes. If new buckets are added to a Dimension that has a predefined BucketSet, a dialog should ask the user whether the intent is to update the named BucketSet in the data model or to make a private updated copy associated with the Dimension.
A BucketSet contains Buckets in a BucketTable. A LOV BucketSet has Buckets with a single String value (if the BucketSet type is not String, the toString method (or Dates.toISO8601{Date,Time,DateTime} methods) is used to convert to String). By default, an initial Bucket with special value "otherwise" is created that is distinct from all other bucket values. This bucket matches all values that have no other bucket. The otherwise bucket may not be deleted but may be excluded. If this bucket is excluded then the semantics of "don't care" change to "match any bucket" but DON'T match a value that is not represented by a Bucket.
A RANGE BucketSet has Buckets that store the String value of the lesser-valued endpoint of the subrange (as per Comparable) . The Bucket also contains a boolean indicating whether the endpoint is included in the range (and thus excluded from the previous range). The first Bucket stores the empty string instead of the String value representing the minimum value (the minimum is never needed for comparison), its included flag is always true, and it may not be deleted. Similarly, the last Bucket stores its minimum endpoint but its maximum endpoint is not stored and is never needed.
In user choice lists and for quickly adding a new bucket to a range, a syntax that specifies one endpoint and an inequality may be used for the first and last bucket (e.g. <0, >=100). A syntax that specifies both endpoints and whether or not the endpoint is included may be used for the other buckets (e.g. [0..100) ).
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class oracle.rules.sdk2.dictionary.DictionaryComponent
DictionaryComponent.Diff<T extends DictionaryComponent>, DictionaryComponent.DiffSummary, DictionaryComponent.DiffType
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final String
Calendar Forms - to distinguish date, time, or datetime calendar formatstatic final String
static final String
static final String
static final String
static final String
Forms - to distinguish LOV bucket set from Range bucket setstatic final String
Fields inherited from class oracle.rules.sdk2.dictionary.DictionaryComponent
PROP_ACCESS, PROP_ACTION_SELECTED, PROP_ACTION_TABLE, PROP_ACTIVE, PROP_ACTUAL_TEST_OUTPUT_TABLE, PROP_ADHOC_TEST_VALIDATION, PROP_ADVANCED_MODE, PROP_AGGREGATE, PROP_AGGREGATE_TABLE, PROP_ALIAS, PROP_ALLOW_GAPS, PROP_ALWAYS_SELECTED, PROP_ARRAY, PROP_ARRAY_COMPONENT_TYPE, PROP_ARRAY_COMPONENT_TYPE_ID, PROP_ARRAY_FACT_TYPE_TABLE, PROP_AUTO_CONFLICT_RESOLUTION, PROP_AUTO_PATTERN_PROPERTY, PROP_AUTO_SYNC, PROP_BODY, PROP_BUCKET_ID_TABLE, PROP_BUCKET_SET, PROP_BUCKET_SET_ID, PROP_BUCKET_SET_TABLE, PROP_BUCKET_TABLE, PROP_CALENDAR_FORM, PROP_CHECK_RULE_FLOW, PROP_CHILD_DIMENSION_NODES, PROP_CONFLICT, PROP_CONFLICT_POLICY, PROP_CONNECTIVE, PROP_CONSTANT, PROP_CONSTRUCTOR, PROP_CONSTRUCTOR_TABLE, PROP_CREATION_UPDATE_NUMBER, PROP_CURSOR_POSITION, PROP_CUSTOM_BINDING, PROP_DATA_MODEL, PROP_DATA_SOURCE, PROP_DECISION_FUNCTION, PROP_DECISION_FUNCTION_ID, PROP_DECISION_FUNCTION_INPUT_TABLE, PROP_DECISION_FUNCTION_OUTPUT_TABLE, PROP_DECISION_FUNCTION_RULESET_TABLE, PROP_DECISION_FUNCTION_TABLE, PROP_DECISION_MODEL, PROP_DESCRIPTION, PROP_DF_FACT, PROP_DF_FACT_ID, PROP_DICT_LOADING_EXTENSION, PROP_DICTIONARY_LINK_TABLE, PROP_DIMENSION_NODE_TABLE, PROP_DIMENSION_TABLE, PROP_DISALLOW_ERROR_SUPPRESSION, PROP_DRAFT, PROP_DSL_ID, PROP_DSL_PARAMETER_TABLE, PROP_DSL_TABLE, PROP_DSL_VALUE, PROP_DT_ACTION_NODE_TABLE, PROP_DT_ACTION_PARAMETER_NAME, PROP_DTACTION_TABLE, PROP_DTRULE_TABLE, PROP_EFFECTIVE_END_DATE, PROP_EFFECTIVE_START_DATE, PROP_ENUM, PROP_ENUM_BUCKET_SET, PROP_ENUM_BUCKET_SET_ID, PROP_ENUM_TYPE, PROP_EXCEPTION_IDS, PROP_EXCEPTIONS, PROP_EXCLUDED, PROP_EXPECTED_TEST_OUTPUT_TABLE, PROP_EXPRESSION, PROP_EXPRESSION_TABLE, PROP_FACT_PATH, PROP_FACT_PATH_IDS, PROP_FACT_TABLE, PROP_FACT_TYPE, PROP_FACT_TYPE_ID, PROP_FACT_TYPE_IDS, PROP_FACT_TYPE_TABLE, PROP_FACT_TYPES, PROP_FIELD_TABLE, PROP_FINAL, PROP_FORM, PROP_FORMAL_PARAMETER_TABLE, PROP_FUNCTION, PROP_FUNCTION_ID, PROP_FUNCTION_SIGNATURE, PROP_FUNCTION_TABLE, PROP_GENERATED_FROM, PROP_GLOBAL_ALIAS, PROP_ID, PROP_INCLUDE_CHAINED_EXPR, PROP_INCLUDED, PROP_INTERFACE, PROP_INTERFACE_IDS, PROP_INTERFACES, PROP_IS_ABSTRACT, PROP_IS_CONSTANT, PROP_IS_ENUM, PROP_IS_FINAL, PROP_IS_JAXB2, PROP_IS_PRIMARY_KEY, PROP_IS_STATIC, PROP_IS_TOPLEVEL_VIEW_OBJECT, PROP_LEFT, PROP_LIFECYCLE, PROP_LIFECYCLE_DESCRIPTION, PROP_LINK_PATH, PROP_LIST, PROP_LIST_CONTENT_TYPE, PROP_LIST_CONTENT_TYPE_ID, PROP_LOCAL, PROP_LOGICAL, PROP_METHOD_TABLE, PROP_MODIFIERS, PROP_NAME, PROP_NAMESPACE, PROP_NESTED_TABLE, PROP_NO_CONFLICT, PROP_NO_RULE_FIRED_IS_ERROR, PROP_NODE_NAME, PROP_OPERATOR, PROP_OPERATOR_ID, PROP_ORDER_RULES_BY_BUCKET, PROP_OTHERWISE, PROP_OUTPUT_TYPES, PROP_OVERLOADED_PARAMETER_TABLE, PROP_OVERRIDDEN_BY, PROP_OVERRIDE, PROP_PACKAGE, PROP_PARAM, PROP_PARAM_EXPRESSION, PROP_PARAMETER_ALIAS, PROP_PARAMETER_ID, PROP_PARAMETER_LIST, PROP_PARAMETER_NAME, PROP_PARAMETER_REQUIRED, PROP_PARAMETER_TYPE_IDS, PROP_PARAMETER_TYPES, PROP_PARENT_DIMENSION_NODE, PROP_PATTERN_TABLE, PROP_PHRASE_SUGGESTION_FORM, PROP_PREFERENCES, PROP_PREFIX_LINKED_NAMES, PROP_PRIORITY, PROP_PRIVATE_BUCKET_SET, PROP_PROPERTIES, PROP_PROPERTY, PROP_PROPERTY_ID, PROP_PROPERTY_TABLE, PROP_PROPERTY_VALUE_TABLE, PROP_QUALIFIER_PATTERN, PROP_READABLE, PROP_REF_ID, PROP_REPORT_BYUSE_NAMES, PROP_REPORT_PATTERNS, PROP_RESOLVED_TARGET, PROP_RESOLVED_VALUE, PROP_RESOURCE_BUNDLE, PROP_RESTRICT_AUTO_SUGGESTIONS, PROP_RETURN_TYPE, PROP_RIGHT, PROP_RIGHT_SEPARATOR, PROP_RULE_EXEC_ALGORITHM, PROP_RULE_FIRING_LIMIT, PROP_RULE_FIRING_LIMIT_ERROR, PROP_RULE_REPORT_TABLE, PROP_RULE_SET_TABLE, PROP_RULE_SHEET_TABLE, PROP_RULE_TABLE, PROP_RULESET, PROP_RUN_AFTER, PROP_RUN_BEFORE, PROP_SERVICE_CONFIGURATION, PROP_SERVICE_NAME, PROP_SERVICE_NAMESPACE, PROP_SHARED_BUCKET_SET, PROP_SHARED_BUCKET_SET_ID, PROP_SHOW_CONSTANTS, PROP_SHOW_FUNCTIONS, PROP_SHOW_VARIABLES, PROP_SIMPLE_TEST_TABLE, PROP_SOURCE, PROP_STATELESS, PROP_STATIC, PROP_SUPER_CLASS, PROP_SUPER_CLASS_ID, PROP_SUPPORT_XPATH, PROP_SUPPORTS_XPATH_ENABLED, PROP_SYNC_MARK, PROP_SYSTEM, PROP_TARGET, PROP_TARGET_PACKAGE, PROP_TEST_CASE_TABLE, PROP_TEST_FORM, PROP_TEST_INPUT_TABLE, PROP_TEST_MODEL, PROP_TEST_RESULT_TABLE, PROP_TEST_SUITE_TABLE, PROP_TEST_TEMPLATE_TABLE, PROP_TIMESTAMP, PROP_TOKEN_UNDER_CURSOR, PROP_TRANSLATED_ALIAS, PROP_TRANSLATED_DESCRIPTION, PROP_TRANSLATED_GLOBAL_ALIAS, PROP_TRANSLATED_PARAMETER_LIST, PROP_TRANSLATED_QUALIFIER_PATTERN, PROP_TRANSLATED_VALUE, PROP_TRANSLATED_VARIABLE, PROP_TREE, PROP_TREE_MODE, PROP_TYPE, PROP_TYPE_ID, PROP_TYPE_IDS, PROP_TYPES, PROP_UNIQUE_RULESETS, PROP_UNSAVED_TRANSLATED_ALIAS, PROP_UNSAVED_TRANSLATED_DESCRIPTION, PROP_UNSAVED_TRANSLATED_GLOBAL_ALIAS, PROP_UNSAVED_TRANSLATED_QUALIFIER_PATTERN, PROP_UNSAVED_TRANSLATED_VALUE, PROP_UPDATE_NUMBER, PROP_UPDATE_TIME, PROP_VALIDATION, PROP_VALIDATION_UPDATE_NUMBER, PROP_VALUE, PROP_VALUES, PROP_VARIABLE, PROP_VARIABLE_TABLE, PROP_VERBAL_RULE_TABLE, PROP_VERSION, PROP_VERTICAL_ORIENTATION, PROP_VISIBILITY_FILTER, PROP_VISIBILITY_FILTER_ENABLED, PROP_VISIBLE, PROP_WEB_SERVICE, PROP_WRITABLE, PROP_XML_NAME
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionAdd Bucket(s) by name.Add Bucket to Range BucketSet in correct order in BucketTablestatic BucketSet
Get BucketsGet BucketTableGet BucketTable Property.Get Calendar Form value (Date, Time, or DateTime).String[]
Get CalendarForm Property.int
getChoices
(DictionaryComponent dc, DOID typeID) getForm()
Get value of Form propertyString[]
Get Form Property.int
String[]
boolean
getRL
(StringBuilder sb, Map<Object, Object> properties) interpackage getRLString[]
Get TestExcludedBuckets Property.String[]
Get the bucket set as an array of bucket names Excluded buckets are not shown.boolean
does the bucketset have excluded buckets?boolean
Does the bucketset contain an otherwise bucket?boolean
Is the type of the bucketset Calendar?boolean
isExcluded
(DictionaryObject context, String constant, boolean test) boolean
isRange()
is the bucketset a range bucketset?boolean
should excluded bucket values be allowed in tests or DT condition cells?Override hashtable put method.void
remove
(Comparable rMinEndpoint, boolean rMinIncluded, Comparable rMaxEndpoint, boolean rMaxIncluded) remove range buckets within rangevoid
Remove buckets by name.void
setCalendarForm
(String form) void
set the FORM to RANGE, LOV, or default based on data type.void
setTestExcludedBuckets
(boolean flag) should excluded bucket values be allowed in tests or DT condition cells?void
validate
(List<SDKException> errors, List<SDKWarning> warnings) Validate and append errors and warnings.void
validate
(List<SDKException> errors, List<SDKWarning> warnings, int modelChangeLowerBound, int ruleChangeLowerBound) Validate a bucket set.Methods inherited from class oracle.rules.sdk2.datamodel.TypedComponent
_getTypeID, get, getFullyQualifiedTypeName, getListContentType, getListContentTypeFullName, getListContentTypeID, getListContentTypeName, getListContentTypeOptions, getListContentTypeProperty, getType, getTypeID, getTypeName, getTypeOptions, getTypeProperty, getTypeSelected, isChainable, isCollection, isPrimitiveType, setListContentType, setListContentTypeID, setListContentTypeName, setType, setTypeID, setTypeName
Methods inherited from class oracle.rules.sdk2.datamodel.ModelComponent
getCreationUpdateNumber, getParent, getParentTable, getVisibleProperty, isVisible, setVisible
Methods inherited from class oracle.rules.sdk2.dictionary.DictionaryComponent
_get, _put, clear, containsKey, containsValue, entrySet, forceSync, getAEReferences, getAlias, getAlias, getAlias, getAlias, getAliasProperty, getAllReferences, getContainedDiffs, getCustom, getDependents, getDescription, getDescription, getDescriptionProperty, getDiff, getDiffMatchValue, getDiffProperties, getDiffs, getExprParserReferences, getFullyQualifiedAlias, getFullyQualifiedName, getIndex, getIndex, getName, getNameProperty, getNext, getNext, getObjectPath, getOptions, getPrevious, getPrevious, getProperties, getProperty, getReferences, getSelected, getTranslatedAlias, getTranslatedAlias, getTranslatedDescription, hasConflict, hasDiff, init, init, isAliasDistinct, isEmpty, isFullyQualifiedName, isModifiable, isNameDistinct, isSystemProperty, isUnsavedTranslatedAlias, isUnsavedTranslatedDescription, keySet, putAll, remove, removeDiff, setAlias, setAlias, setCustom, setDescription, setDescription, setName, setTranslatedAlias, setTranslatedDescription, size, validate, values
Methods inherited from class oracle.rules.sdk2.dictionary.DictionaryObject
_clearID, equals, exists, getAEReferenceCount, getCombinedDataModel, getContainedIDs, getContainedIDs, getDataModel, getDictionary, getID, getIndent, getObjectType, getParentByClass, getParentComponent, getParentComponentTable, getParentObject, getRuleSet, getState, getWarnings, hashCode, isModified, setID, validate
Methods inherited from class java.lang.Object
getClass, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, equals, forEach, getOrDefault, hashCode, merge, putIfAbsent, remove, replace, replace, replaceAll
-
Field Details
-
ALL_VALUES_LIST
-
UNKNOWN_VALUE_LIST
-
CALENDAR_FORM_DATE
Calendar Forms - to distinguish date, time, or datetime calendar formatString values are part of oracle.rules.rl.extensions.JavaDate.from***String methods
- See Also:
-
CALENDAR_FORM_TIME
- See Also:
-
CALENDAR_FORM_DATETIME
- See Also:
-
FORM_LOV
Forms - to distinguish LOV bucket set from Range bucket set- See Also:
-
FORM_RANGE
- See Also:
-
FORM_ENUM
- See Also:
-
FORM_DEFAULT
- See Also:
-
-
Constructor Details
-
BucketSet
required by datamodel.BucketSet
-
-
Method Details
-
getFormProperty
Get Form Property.- Returns:
- TranslatedProperty
-
getForm
Get value of Form property- Returns:
- String
-
setForm
set the FORM to RANGE, LOV, or default based on data type.- Parameters:
form
-
-
getFormOptions
-
getFormSelected
public int getFormSelected() -
getCalendarFormProperty
Get CalendarForm Property.- Returns:
- TranslatedProperty
-
getCalendarForm
Get Calendar Form value (Date, Time, or DateTime). Default is Date.- Returns:
- String
-
setCalendarForm
-
getCalendarFormOptions
-
getCalendarFormSelected
public int getCalendarFormSelected() -
getTestExcludedBucketsProperty
Get TestExcludedBuckets Property.- Returns:
- Boolean SettableProperty
-
isTestExcludedBuckets
public boolean isTestExcludedBuckets()should excluded bucket values be allowed in tests or DT condition cells?- Returns:
- true or false
-
setTestExcludedBuckets
public void setTestExcludedBuckets(boolean flag) should excluded bucket values be allowed in tests or DT condition cells? -
getBucketTableProperty
Get BucketTable Property.- Returns:
- Bucket TableProperty
-
getBucketTable
Get BucketTable- Returns:
- BucketTable of the BucketSet
-
getBuckets
Get Buckets- Returns:
- Buckets in the BucketSet that are not excluded from tests
-
add
Add Bucket(s) by name. Name can be a value to add to a LOV, or the name of a range. If the name of a range, buckets are added (if needed) in correct order in BucketTable with (minEndpoint, included) property values as shown:<v adds (v, true) <=v adds (v, false) >v adds (v, false) >=v adds (v, true) (v1..v2) adds (v1, false) and (v2, true) if v1 < v2 [v1..v2) adds (v1, true) and (v2, true) if v1 < v2 (v1..v2] adds (v1, false) and (v2, false) if v1 < v2 [v1..v3] adds (v1, true) and (v3, false) if v1 <= v3 =v adds (v, true) and (v, false) ==v adds (v, true) and (v, false)
- Parameters:
name
- name of new bucket (value or range)- Throws:
SDKException
- if v1 >= v2, v1 < v3, or v* cannot be parsed
-
add
Add Bucket to Range BucketSet in correct order in BucketTable- Parameters:
value
- minEndpoint of rangeincluded
- endpoint in range?- Returns:
- null if not a range bucketset, or if value cannot be converted to a minEndpoint
-
remove
Remove buckets by name. For LOV BucketSet, simply remove named bucket. For Range BucketSet, parse the name for one or two endpoints as inadd(String)
and delete buckets between two endpoints, or less than or greater than one endpoint, including the endpoints or not according to name notation.- Parameters:
name
- of bucket or bucket range- Throws:
SDKException
- as peradd(String)
-
remove
public void remove(Comparable rMinEndpoint, boolean rMinIncluded, Comparable rMaxEndpoint, boolean rMaxIncluded) remove range buckets within range- Parameters:
rMinEndpoint
- lower end of rangerMinIncluded
- is endpoint included in rangerMaxEndpoint
- upper end of rangerMaxIncluded
- is endpoint included in range
-
getValues
Get the bucket set as an array of bucket names Excluded buckets are not shown.- Returns:
- array of bucket names (values or ranges)
-
validate
Description copied from class:DictionaryComponent
Validate and append errors and warnings.- Overrides:
validate
in classTypedComponent<BucketSet>
- Parameters:
errors
- a List of error exceptions to append to.warnings
- a List of warning exceptions to append to.- See Also:
-
validate
public void validate(List<SDKException> errors, List<SDKWarning> warnings, int modelChangeLowerBound, int ruleChangeLowerBound) Validate a bucket set. Assume containing Dimension's datatype if none assigned. Warn if data type is not string, primitive, or calendar. Warn if there is only one bucket (internal error if no buckets). Warn if more than one otherwise bucket- Overrides:
validate
in classDictionaryObject
- Parameters:
errors
-warnings
-modelChangeLowerBound
- smallest ModelComponent.CreationUpdateNumber modified in thix tx.ruleChangeLowerBound
- smallest RuleComponent.CreationUpdateNumber modified in thix tx. Rulesets and rules with UpdateNumber >= modelChangeLowerBound will be revalidated. a value of 0 will force revalidation of all rulesets. A value of Integer.MAX_VALUE will skip validation of all rulesets.
-
isRange
public boolean isRange()is the bucketset a range bucketset?- Returns:
- true if form is range or form is default and data type is numeric, date, or calendar.
-
getPropertyNames
- Overrides:
getPropertyNames
in classTypedComponent<BucketSet>
- Returns:
- Array of property names available.
-
getStoredPropertyNames
- Overrides:
getStoredPropertyNames
in classTypedComponent<BucketSet>
- Returns:
- Array of property names which are persisted in the order in which they appear in the schema.
-
put
Description copied from class:TypedComponent
Override hashtable put method. For property "Type" and "ListContentType" we must sync the alias and ID -
hasOtherwise
public boolean hasOtherwise()Does the bucketset contain an otherwise bucket? -
hasExclusions
public boolean hasExclusions()does the bucketset have excluded buckets?- Returns:
- true or false
-
isCalendarType
public boolean isCalendarType()Is the type of the bucketset Calendar? This is mainly used for determining if the Calendar Form should be displayed or set -
getRL
interpackage getRL -
getBooleanBucketSet
-
getChoices
- Parameters:
dc
- any dictionary component in the top level dictionarytypeID
-- Returns:
- choices of bucketsets that are type compatible with typeID
-
isExcluded
-
getOtherwise
-