/* * (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.foundation.cg.templates.action; import java.io.File; import java.util.Vector; import java.util.logging.Level; import java.util.logging.Logger; import org.openflexo.foundation.FlexoEditor; import org.openflexo.foundation.FlexoModelObject; import org.openflexo.foundation.action.FlexoAction; import org.openflexo.foundation.action.FlexoActionType; import org.openflexo.foundation.cg.DuplicateCodeRepositoryNameException; import org.openflexo.foundation.cg.templates.CGTemplateFile; import org.openflexo.foundation.cg.templates.CGTemplateObject; import org.openflexo.foundation.rm.FlexoFileResource; import org.openflexo.toolbox.ToolBox; public class SaveCustomTemplateFile extends FlexoAction<SaveCustomTemplateFile, CGTemplateFile, CGTemplateObject> { private static final Logger logger = Logger.getLogger(SaveCustomTemplateFile.class.getPackage().getName()); public static FlexoActionType<SaveCustomTemplateFile, CGTemplateFile, CGTemplateObject> actionType = new FlexoActionType<SaveCustomTemplateFile, CGTemplateFile, CGTemplateObject>( "save_template", FlexoActionType.defaultGroup, FlexoActionType.NORMAL_ACTION_TYPE) { /** * Factory method */ @Override public SaveCustomTemplateFile makeNewAction(CGTemplateFile focusedObject, Vector<CGTemplateObject> globalSelection, FlexoEditor editor) { return new SaveCustomTemplateFile(focusedObject, globalSelection, editor); } @Override public boolean isVisibleForSelection(CGTemplateFile object, Vector<CGTemplateObject> globalSelection) { return object != null && object.isCustomTemplate(); } @Override public boolean isEnabledForSelection(CGTemplateFile object, Vector<CGTemplateObject> globalSelection) { return object != null && object.isCustomTemplate() && object.isEdited(); } }; static { FlexoModelObject.addActionForClass(SaveCustomTemplateFile.actionType, CGTemplateFile.class); } SaveCustomTemplateFile(CGTemplateFile focusedObject, Vector<CGTemplateObject> globalSelection, FlexoEditor editor) { super(actionType, focusedObject, globalSelection, editor); } @Override protected void doAction(Object context) throws DuplicateCodeRepositoryNameException { logger.info("Save CustomTemplateFile " + getFocusedObject()); if (getFocusedObject() != null) { File file = getFocusedObject().getTemplateFile(); long previousLastModified = file.lastModified(); getFocusedObject().save(); if (ToolBox.getPLATFORM() == ToolBox.MACOS) { long startChecking = System.currentTimeMillis(); logger.info("Checking that file " + file.getAbsolutePath() + " has been successfully written"); boolean fileHasBeenWritten = false; while (System.currentTimeMillis() <= startChecking + FlexoFileResource.ACCEPTABLE_FS_DELAY && !fileHasBeenWritten) { if (previousLastModified == 0) { fileHasBeenWritten = file.exists(); } else { fileHasBeenWritten = file.lastModified() > previousLastModified; } if (!fileHasBeenWritten) { logger.info("Waiting file " + file.getAbsolutePath() + " to be written"); try { Thread.sleep(200); } catch (InterruptedException e) { e.printStackTrace(); } } else if (logger.isLoggable(Level.INFO)) { logger.info("Writing of template: " + getFocusedObject().getName() + " took " + (file.lastModified() - previousLastModified) + "ms"); } } if (!fileHasBeenWritten) { if (logger.isLoggable(Level.WARNING)) { logger.warning("Waited for " + FlexoFileResource.ACCEPTABLE_FS_DELAY + "ms but file was still not written on disk!"); } } } } } }