/*
* Copyright (C) 2009 eXo Platform SAS.
*
* This 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 2.1 of
* the License, or (at your option) any later version.
*
* This software 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 software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.services.jcr.core.nodetype;
import org.exoplatform.services.jcr.impl.core.nodetype.NodeDefinitionImpl;
import java.util.Arrays;
import java.util.List;
import javax.jcr.nodetype.NodeDefinition;
/**
* Created by The eXo Platform SAS<br>
*
* The NodeDefinitionValue interface extends ItemDefinitionValue with the addition of writing methods,
* enabling the characteristics of a child node definition to be set,
* after that the NodeDefinitionValue is added to a NodeTypeValue.
*
* @author <a href="mailto:gennady.azarenkov@exoplatform.com">Gennady Azarenkov</a>
* @version $Id: NodeDefinitionValue.java 11907 2008-03-13 15:36:21Z ksm $
* @LevelAPI Unsupported
*/
public final class NodeDefinitionValue extends ItemDefinitionValue
{
private String defaultNodeTypeName;
private List<String> requiredNodeTypeNames;
private boolean sameNameSiblings;
public NodeDefinitionValue()
{
}
/**
* @param name
* @param autoCreate
* @param mandatory
* @param onVersion
* @param readOnly
* @param defaultNodeTypeName
* @param requiredNodeTypeNames
* @param sameNameSiblings
*/
public NodeDefinitionValue(String name, boolean autoCreate, boolean mandatory, int onVersion, boolean readOnly,
String defaultNodeTypeName, List<String> requiredNodeTypeNames, boolean sameNameSiblings)
{
super(name, autoCreate, mandatory, onVersion, readOnly);
this.defaultNodeTypeName = defaultNodeTypeName;
this.requiredNodeTypeNames = requiredNodeTypeNames;
this.sameNameSiblings = sameNameSiblings;
}
public NodeDefinitionValue(NodeDefinition nodeDefinition)
{
super(nodeDefinition);
this.defaultNodeTypeName = ((NodeDefinitionImpl)nodeDefinition).getDefaultPrimaryTypeName();
this.requiredNodeTypeNames = Arrays.asList(((NodeDefinitionImpl)nodeDefinition).getRequiredPrimaryTypeNames());
this.sameNameSiblings = nodeDefinition.allowsSameNameSiblings();
}
/**
* @return Returns the defaultNodeTypeName.
*/
public String getDefaultNodeTypeName()
{
return defaultNodeTypeName;
}
/**
* @param defaultNodeTypeName The defaultNodeTypeName to set.
*/
public void setDefaultNodeTypeName(String defaultNodeTypeName)
{
this.defaultNodeTypeName = defaultNodeTypeName;
}
/**
* @return Returns the sameNameSiblings.
*/
public boolean isSameNameSiblings()
{
return sameNameSiblings;
}
/**
* @param multiple The sameNameSiblings to set.
*/
public void setSameNameSiblings(boolean multiple)
{
this.sameNameSiblings = multiple;
}
/**
* @return Returns the requiredNodeTypeNames.
*/
public List<String> getRequiredNodeTypeNames()
{
return requiredNodeTypeNames;
}
/**
* @param requiredNodeTypeNames The requiredNodeTypeNames to set.
*/
public void setRequiredNodeTypeNames(List<String> requiredNodeTypeNames)
{
this.requiredNodeTypeNames = requiredNodeTypeNames;
}
}