/*
* JBoss, a division of Red Hat
* Copyright 2008, Red Hat Middleware, LLC, and individual contributors as indicated
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* 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.gatein.wsrp.jcr.mapping.mixins;
/**
* Provides default behavior and functionality for classes wishing to use a mixin.
*
* @author <a href="mailto:chris.laprun@jboss.com">Chris Laprun</a>
*/
public abstract class MixinHolder<M extends BaseMixin>
{
/**
* Retrieves a properly initialized mixin that has been created and persisted with the default initial value if none existed.
*
* @return the properly initialized mixin associated with this MixinHolder
*/
protected M getCreatedMixin()
{
M mixin = getMixin();
if (mixin == null)
{
mixin = createMixin();
setMixin(mixin);
mixin.initializeValue();
}
return mixin;
}
/**
* Provides generic access to the mixin. This allows for proper generic encapsulation of the Chromattic-annotated method provided by implementations.
*
* @return the related mixin
*/
public abstract M getMixin();
/**
* Provides a generic way to set the mixin on the holding mapping. This allows for proper generic encapsulation of the Chromattic-annotated method provided by implementations.
*
* @param mixin the mixin to use on this MixinHolder
*/
protected abstract void setMixin(M mixin);
/**
* Provides a generic way to create a new mixin instance. This allows for proper generic encapsulation of the Chromattic-annotated method provided by implementations.
*
* @return the newly created mixin instance.
*/
protected abstract M createMixin();
}