
org.efaps.admin.ui.Table Maven / Gradle / Ivy
/*
* Copyright 2003 - 2012 The eFaps Team
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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.
*
* Revision: $Rev: 7483 $
* Last Changed: $Date: 2012-05-11 11:57:38 -0500 (Fri, 11 May 2012) $
* Last Changed By: $Author: [email protected] $
*/
package org.efaps.admin.ui;
import java.util.UUID;
import org.efaps.admin.datamodel.Type;
import org.efaps.ci.CIAdminUserInterface;
import org.efaps.util.EFapsException;
/**
* @author The eFaps Team
* @version $Id: Table.java 7483 2012-05-11 16:57:38Z [email protected] $ TODO:
* description
*/
public class Table
extends AbstractCollection
implements Cloneable
{
/**
* Stores all instances of class {@link Table}.
*
* @see #getCache()
*/
private static TableCache CACHE = new TableCache();
/**
* This is the constructor to set the id and the name.
*
* @param _id id of the new table
* @param _uuid UUID of the new table
* @param _name name of the new table
*/
public Table(final Long _id,
final String _uuid,
final String _name)
{
super(_id, _uuid, _name);
}
/**
* Creates and returns a copy of this table object.
*
* @return cloned table
*/
public Table cloneTable()
{
Table ret = null;
try {
ret = (Table) super.clone();
} catch (final CloneNotSupportedException e) {
e.printStackTrace();
}
return ret;
}
/**
* Returns for given parameter _id the instance of class
* {@link Table}.
*
* @param _id id to search in the cache
* @return instance of class {@link Table}
* @see #CACHE
*/
public static Table get(final long _id)
{
return Table.CACHE.get(_id);
}
/**
* Returns for given parameter _name the instance of class
* {@link Table}.
*
* @param _name name to search in the cache
* @return instance of class {@link Table}
* @see #CACHE
*/
public static Table get(final String _name)
{
return Table.CACHE.get(_name);
}
/**
* Returns for given parameter UUID the instance of class
* {@link Table}.
*
* @param _uuid UUID to search in the cache
* @return instance of class {@link Table}
* @see #CACHE
*/
public static Table get(final UUID _uuid)
{
return Table.CACHE.get(_uuid);
}
/**
* Static getter method for the table {@link #CACHE}.
*
* @return value of static variable {@link #CACHE}
*/
protected static AbstractUserInterfaceObjectCache getCache()
{
return Table.CACHE;
}
/**
* Cache for Tables.
*/
private static class TableCache
extends AbstractUserInterfaceObjectCache
{
/**
*
*/
protected TableCache()
{
super(Table.class);
}
/**
* {@inheritDoc}
*/
@Override
protected Type getType()
throws EFapsException
{
return CIAdminUserInterface.Table.getType();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy