/*
* (c) Copyright 2010-2011 AgileBirds
*
* This file is part of OpenFlexo.
*
* OpenFlexo is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* OpenFlexo 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with OpenFlexo. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.openflexo.generator;
import java.util.Date;
import java.util.Vector;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.openflexo.foundation.FlexoException;
import org.openflexo.foundation.FlexoModelObject;
import org.openflexo.foundation.cg.CGFile;
import org.openflexo.foundation.cg.GenerationRepository;
import org.openflexo.foundation.cg.generator.GeneratedCopiedFile;
import org.openflexo.foundation.cg.generator.IFlexoResourceGenerator;
import org.openflexo.foundation.rm.FlexoCopiedResource;
import org.openflexo.foundation.rm.FlexoGeneratedResource;
import org.openflexo.foundation.rm.SaveResourceException;
import org.openflexo.foundation.rm.cg.CGRepositoryFileResource;
import org.openflexo.logging.FlexoLogger;
/**
* @author gpolet
*
*/
public class CopiedResourceGenerator<R extends GenerationRepository> extends Generator<FlexoModelObject, R> implements
IFlexoResourceGenerator {
private static final Logger logger = FlexoLogger.getLogger(CopiedResourceGenerator.class.getPackage().getName());
private FlexoCopiedResource copiedResource;
private Generator<?, R> parent;
/**
*
*/
public CopiedResourceGenerator(FlexoCopiedResource copiedResource, AbstractProjectGenerator<R> projectGenerator, Generator<?, R> parent) {
super(projectGenerator, null);
this.parent = parent;
this.copiedResource = copiedResource;
generatedCode = new GeneratedCopiedFile(copiedResource.getFile());
}
/**
* Overrides generate
*
* @see org.openflexo.foundation.cg.generator.IFlexoResourceGenerator#generate(boolean)
*/
@Override
public void generate(boolean forceRegenerate) {
if (forceRegenerate) {
if (logger.isLoggable(Level.INFO)) {
logger.info("Called force generate on copied resource");
}
if (copiedResource.getResourceToCopy() instanceof FlexoGeneratedResource) {
try {
((FlexoGeneratedResource) copiedResource.getResourceToCopy()).generate();
} catch (SaveResourceException e) {
e.printStackTrace();
} catch (FlexoException e) {
e.printStackTrace();
}
}
}
}
/**
* Overrides getIdentifier
*
* @see org.openflexo.foundation.cg.generator.IFlexoResourceGenerator#getIdentifier()
*/
@Override
public String getIdentifier() {
return "SCREENSHOT-" + copiedResource.getResourceIdentifier();
}
/**
* Overrides getMemoryLastGenerationDate
*
* @see org.openflexo.foundation.cg.generator.IFlexoResourceGenerator#getMemoryLastGenerationDate()
*/
@Override
public Date getMemoryLastGenerationDate() {
return copiedResource.getDiskLastModifiedDate();
}
/**
* Overrides isCodeAlreadyGenerated
*
* @see org.openflexo.foundation.cg.generator.IFlexoResourceGenerator#isCodeAlreadyGenerated()
*/
@Override
public boolean isCodeAlreadyGenerated() {
return true;
}
/**
* Overrides needsGeneration
*
* @see org.openflexo.foundation.cg.generator.IFlexoResourceGenerator#needsGeneration()
*/
@Override
public boolean needsGeneration() {
return false;
}
// Just put this method to satisfy the Interface IFlexoResourceGenerator.
// but, the TemplateLocator don't exist for copied resources and shouldn't be called.
// so it returns null.
@Override
public TemplateLocator getTemplateLocator() {
return null;
}
@Override
public void addToGeneratedResourcesGeneratedByThisGenerator(CGRepositoryFileResource<?, ?, ? extends CGFile> resource) {
}
@Override
public void removeFromGeneratedResourcesGeneratedByThisGenerator(CGRepositoryFileResource<?, ?, ? extends CGFile> resource) {
}
@Override
public void silentlyGenerateCode() {
if (logger.isLoggable(Level.SEVERE)) {
logger.severe("This operation is not supported!");
}
}
@Override
public void buildResourcesAndSetGenerators(R repository, Vector<CGRepositoryFileResource> resources) {
if (parent != null) {
parent.buildResourcesAndSetGenerators(repository, resources);
}
}
@Override
public Logger getGeneratorLogger() {
return null;
}
}