Britt Park beb44ec6ae Big rearrangement of package structure to allow as many classes
and interfaces to be package local as possible.


git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/WCM-DEV2/root@3381 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2006-07-23 14:59:28 +00:00

174 lines
3.4 KiB
Java

/*
* Copyright (C) 2006 Alfresco, Inc.
*
* Licensed under the Mozilla Public License version 1.1
* with a permitted attribution clause. You may obtain a
* copy of the License at
*
* http://www.alfresco.org/legal/license.txt
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied. See the License for the specific
* language governing permissions and limitations under the
* License.
*/
package org.alfresco.repo.avm;
import java.io.Serializable;
/**
* An entry in a directory. Contains a name, parent, and child.
* @author britt
*/
class ChildEntryImpl implements ChildEntry, Serializable
{
private static final long serialVersionUID = -307752114272916930L;
/**
* The name of the entry.
*/
private String fName;
/**
* The parent.
*/
private DirectoryNode fParent;
/**
* The child.
*/
private AVMNode fChild;
/**
* The Optimistic lock version
*/
private long fVers;
/**
* Default constructor for Hibernate.
*/
protected ChildEntryImpl()
{
}
/**
* Make up a brand new entry.
* @param name
* @param parent
* @param child
*/
public ChildEntryImpl(String name,
DirectoryNode parent,
AVMNode child)
{
fName = name;
fParent = parent;
fChild = child;
}
/**
* Set the name of this entry.
* @param name
*/
public void setName(String name)
{
fName = name;
}
/**
* Get the name of this entry.
* @return The name of this entry.
*/
public String getName()
{
return fName;
}
/**
* Set the parent in this entry.
* @param parent
*/
public void setParent(DirectoryNode parent)
{
fParent = parent;
}
/**
* Get the parent in this entry.
* @return The parent.
*/
public DirectoryNode getParent()
{
return fParent;
}
/**
* Set the child in this entry.
* @param child
*/
public void setChild(AVMNode child)
{
fChild = child;
}
/**
* Get the child in this entry.
* @return The child.
*/
public AVMNode getChild()
{
return fChild;
}
/**
* Equals override.
* @param obj
* @return Equality.
*/
@Override
public boolean equals(Object obj)
{
if (this == obj)
{
return true;
}
if (!(obj instanceof ChildEntry))
{
return false;
}
ChildEntry other = (ChildEntry)obj;
return fName.equals(other.getName()) && fParent.equals(other.getParent());
}
/**
* Get the hash code.
* @return The hash code.
*/
@Override
public int hashCode()
{
return fName.hashCode() + fParent.hashCode();
}
/**
* Get the version for optimistic locking.
* @return The version for optimistic locking.
*/
protected long getVers()
{
return fVers;
}
/**
* Set the version for optimistic locking.
* @param vers the vers to set
*/
protected void setVers(long vers)
{
fVers = vers;
}
}