// ---------------------------------------------------------------------------
// dark-matter-data
// Copyright (c) 2010 dark-matter-data committers
// ---------------------------------------------------------------------------
// This program is free software; you can redistribute it and/or modify it
// under the terms of the GNU Lesser General Public License as published by the
// Free Software Foundation; either version 3 of the License, or (at your
// option) any later version.
// This program is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
// more details.
// You should have received a copy of the GNU Lesser General Public License along
// with this program; if not, see <http://www.gnu.org/licenses/lgpl.html>.
// ---------------------------------------------------------------------------
package org.dmd.dmv.shared.generated.dmo;
// Generated from: org.dmd.dms.util.GenUtility.formatImports(GenUtility.java:391)
import java.io.Serializable; // Always required - (GenUtility.java:220)
import org.dmd.dmc.DmcAttribute; // Any attributes - (GenUtility.java:236)
import org.dmd.dmc.DmcNamedObjectIF; // Named object - (GenUtility.java:371)
import org.dmd.dmc.DmcSliceInfo; // Required for object slicing - (GenUtility.java:225)
import org.dmd.dmc.DmcValueException; // Any attributes - (GenUtility.java:237)
import org.dmd.dmc.types.RuleName; // Naming attribute type - (GenUtility.java:366)
import org.dmd.dms.generated.dmo.MetaDMSAG; // Required for MODREC constructor - (GenUtility.java:224)
import org.dmd.dms.generated.dmo.RuleDataDMO; // Base class - (GenUtility.java:351)
import org.dmd.dms.generated.types.DmcTypeModifierMV; // Required for MODREC constructor - (GenUtility.java:223)
import org.dmd.dms.generated.types.DmcTypeRuleNameSV; // Required type - (GenUtility.java:324)
import org.dmd.dms.generated.types.DmcTypeStringSV; // Required type - (GenUtility.java:324)
/**
* The AllowedAttributesRule will determine whether or not the \n attributes
* of a DMO conform to the must/may specification of its class definition.\n
* For classes of type EXTENSIBLE, only the must have attributes are
* checked.\n <p/>\n Regardless of the environment in which you are running,
* you must ensure that the\n DmcOmni has been loaded with the appropriate
* schema. If you are using the dark-matter\n Model View Whatever (MVW)
* project for GWT, this aspect is taken care of automatically.\n <p/>\n
* Since this is a GLOBAL class rule, there will only ever be a single
* instance of\n this rule created as part of the dmv schema, as indicated
* below:\n <pre>\n AllowedAttributesRuleData\n ruleName
* dmvAllowedAttributes\n ruleTitle An object's attributes must conform to
* its schema.\n description Ensures that must/may attribute rules are
* followed.\n </pre>
* <P>
* Generated from the dmv schema at version 0.1
* <P>
* This code was auto-generated by the dmogenerator utility and shouldn't be alterred manually!
* Generated from: org.dmd.dms.util.DmoFormatter.dumpDMO(DmoFormatter.java:133)
*/
@SuppressWarnings("serial")
public class AllowedAttributesRuleDataDMO extends RuleDataDMO implements DmcNamedObjectIF, Serializable {
public final static String constructionClassName = "AllowedAttributesRuleData";
static {
}
public AllowedAttributesRuleDataDMO() {
super("AllowedAttributesRuleData");
}
protected AllowedAttributesRuleDataDMO(String oc) {
super(oc);
}
@Override
public AllowedAttributesRuleDataDMO getNew(){
AllowedAttributesRuleDataDMO rc = new AllowedAttributesRuleDataDMO();
return(rc);
}
@Override
public AllowedAttributesRuleDataDMO getSlice(DmcSliceInfo info){
AllowedAttributesRuleDataDMO rc = new AllowedAttributesRuleDataDMO();
populateSlice(rc,info);
return(rc);
}
public AllowedAttributesRuleDataDMO(DmcTypeModifierMV mods) {
super("AllowedAttributesRuleData");
modrec(true);
setModifier(mods);
}
public AllowedAttributesRuleDataDMO getModificationRecorder(){
AllowedAttributesRuleDataDMO rc = new AllowedAttributesRuleDataDMO();
rc.setRuleName(getRuleName());
rc.setModifier(new DmcTypeModifierMV(MetaDMSAG.__modify));
rc.modrec(true);
return(rc);
}
// org.dmd.dms.util.DmoFormatter.getAccessFunctions(DmoFormatter.java:744)
public RuleName getObjectName(){
DmcAttribute<?> name = get(MetaDMSAG.__ruleName);
if (name != null)
return((RuleName)name.getSV());
return(null);
}
// org.dmd.dms.util.DmoFormatter.getAccessFunctions(DmoFormatter.java:761)
public DmcAttribute<?> getObjectNameAttribute(){
DmcAttribute<?> name = get(MetaDMSAG.__ruleName);
return(name);
}
// org.dmd.dms.util.DmoFormatter.getAccessFunctions(DmoFormatter.java:768)
public boolean equals(Object obj){
if (obj instanceof AllowedAttributesRuleDataDMO){
return( getObjectName().equals( ((AllowedAttributesRuleDataDMO) obj).getObjectName()) );
}
return(false);
}
// org.dmd.dms.util.DmoFormatter.getAccessFunctions(DmoFormatter.java:776)
public int hashCode(){
RuleName objn = getObjectName();
if (objn == null)
return(0);
return(objn.hashCode());
}
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:774)
public String getDescription(){
DmcTypeStringSV attr = (DmcTypeStringSV) get(MetaDMSAG.__description);
if (attr == null)
return(null);
return(attr.getSV());
}
/**
* Sets description to the specified value.
* @param value String
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:814)
public void setDescription(String value) {
DmcAttribute<?> attr = get(MetaDMSAG.__description);
if (attr == null)
attr = new DmcTypeStringSV(MetaDMSAG.__description);
try{
attr.set(value);
set(MetaDMSAG.__description,attr);
}
catch(DmcValueException ex){
throw(new IllegalStateException("The type specific set() method shouldn't throw exceptions!",ex));
}
}
/**
* Sets description to the specified value.
* @param value A value compatible with DmcTypeStringSV
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:867)
public void setDescription(Object value) throws DmcValueException {
DmcTypeStringSV attr = (DmcTypeStringSV) get(MetaDMSAG.__description);
if (attr == null)
attr = new DmcTypeStringSV(MetaDMSAG.__description);
attr.set(value);
set(MetaDMSAG.__description,attr);
}
/**
* Removes the description attribute value.
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:887)
public void remDescription(){
rem(MetaDMSAG.__description);
}
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:774)
public RuleName getRuleName(){
DmcTypeRuleNameSV attr = (DmcTypeRuleNameSV) get(MetaDMSAG.__ruleName);
if (attr == null)
return(null);
return(attr.getSV());
}
/**
* Sets ruleName to the specified value.
* @param value RuleName
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:814)
public void setRuleName(RuleName value) {
DmcAttribute<?> attr = get(MetaDMSAG.__ruleName);
if (attr == null)
attr = new DmcTypeRuleNameSV(MetaDMSAG.__ruleName);
try{
attr.set(value);
set(MetaDMSAG.__ruleName,attr);
}
catch(DmcValueException ex){
throw(new IllegalStateException("The type specific set() method shouldn't throw exceptions!",ex));
}
}
/**
* Sets ruleName to the specified value.
* @param value A value compatible with DmcTypeRuleNameSV
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:867)
public void setRuleName(Object value) throws DmcValueException {
DmcTypeRuleNameSV attr = (DmcTypeRuleNameSV) get(MetaDMSAG.__ruleName);
if (attr == null)
attr = new DmcTypeRuleNameSV(MetaDMSAG.__ruleName);
attr.set(value);
set(MetaDMSAG.__ruleName,attr);
}
/**
* Removes the ruleName attribute value.
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:887)
public void remRuleName(){
rem(MetaDMSAG.__ruleName);
}
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:774)
public String getRuleTitle(){
DmcTypeStringSV attr = (DmcTypeStringSV) get(MetaDMSAG.__ruleTitle);
if (attr == null)
return(null);
return(attr.getSV());
}
/**
* Sets ruleTitle to the specified value.
* @param value String
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:814)
public void setRuleTitle(String value) {
DmcAttribute<?> attr = get(MetaDMSAG.__ruleTitle);
if (attr == null)
attr = new DmcTypeStringSV(MetaDMSAG.__ruleTitle);
try{
attr.set(value);
set(MetaDMSAG.__ruleTitle,attr);
}
catch(DmcValueException ex){
throw(new IllegalStateException("The type specific set() method shouldn't throw exceptions!",ex));
}
}
/**
* Sets ruleTitle to the specified value.
* @param value A value compatible with DmcTypeStringSV
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:867)
public void setRuleTitle(Object value) throws DmcValueException {
DmcTypeStringSV attr = (DmcTypeStringSV) get(MetaDMSAG.__ruleTitle);
if (attr == null)
attr = new DmcTypeStringSV(MetaDMSAG.__ruleTitle);
attr.set(value);
set(MetaDMSAG.__ruleTitle,attr);
}
/**
* Removes the ruleTitle attribute value.
*/
// org.dmd.dms.util.GenUtility.formatSV(GenUtility.java:887)
public void remRuleTitle(){
rem(MetaDMSAG.__ruleTitle);
}
}