/*
* (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.dm.action;
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.dm.DMRepository;
import org.openflexo.foundation.dm.DMSet;
import org.openflexo.foundation.dm.DMSet.PackageReference.ClassReference;
import org.openflexo.foundation.dm.ExternalRepository;
import org.openflexo.foundation.dm.LoadableDMEntity;
import org.openflexo.localization.FlexoLocalization;
public class UpdateDMRepository extends FlexoAction {
private static final Logger logger = Logger.getLogger(UpdateDMRepository.class.getPackage().getName());
public static FlexoActionType actionType = new FlexoActionType("update_repository", FlexoActionType.defaultGroup) {
/**
* Factory method
*/
@Override
public FlexoAction makeNewAction(FlexoModelObject focusedObject, Vector globalSelection, FlexoEditor editor) {
return new UpdateDMRepository(focusedObject, globalSelection, editor);
}
@Override
public boolean isVisibleForSelection(FlexoModelObject object, Vector globalSelection) {
return true;
}
@Override
public boolean isEnabledForSelection(FlexoModelObject object, Vector globalSelection) {
return object instanceof DMRepository && ((DMRepository) object).isUpdatable();
}
};
static {
FlexoModelObject.addActionForClass(actionType, DMRepository.class);
}
UpdateDMRepository(FlexoModelObject focusedObject, Vector globalSelection, FlexoEditor editor) {
super(actionType, focusedObject, globalSelection, editor);
}
private DMRepository _repository;
private DMSet _updatedSet;
public DMSet getUpdatedSet() {
if (_updatedSet == null && getRepository() instanceof ExternalRepository) {
_updatedSet = new DMSet(getRepository().getProject(), (ExternalRepository) getRepository(), false, null);
}
return _updatedSet;
}
public void setUpdatedSet(DMSet updatedSet) {
_updatedSet = updatedSet;
}
@Override
protected void doAction(Object context) {
makeFlexoProgress(FlexoLocalization.localizedForKey("updating_repository"), 3);
setProgress(FlexoLocalization.localizedForKey("updating_classes"));
if (logger.isLoggable(Level.INFO)) {
logger.info("repository = " + getRepository());
logger.info("getUpdatedSet() = " + getUpdatedSet());
logger.info("getUpdatedSet().getSelectedObjects() = " + getUpdatedSet().getSelectedObjects());
}
resetSecondaryProgress(getUpdatedSet().getSelectedObjects().size());
for (FlexoModelObject next : getUpdatedSet().getSelectedObjects()) {
if (next instanceof ClassReference) {
ClassReference classReference = (ClassReference) next;
setSecondaryProgress(FlexoLocalization.localizedForKey("updating") + " " + classReference.getName());
LoadableDMEntity entity = (LoadableDMEntity) getRepository().getDMEntity(classReference.getPackageName(),
classReference.getName());
if (entity != null) {
if (logger.isLoggable(Level.INFO)) {
logger.info("Update entity for " + classReference.getReferencedClass());
}
entity.update(getUpdatedSet().getImportGetOnlyProperties(), getUpdatedSet().getImportMethods());
} else if (classReference.getReferencedClass() != null) {
if (logger.isLoggable(Level.INFO)) {
logger.info("Create entity for " + classReference.getReferencedClass());
}
LoadableDMEntity.createLoadableDMEntity(getRepository(), classReference.getReferencedClass(), getUpdatedSet()
.getImportGetOnlyProperties(), getUpdatedSet().getImportMethods());
}
}
}
setProgress(FlexoLocalization.localizedForKey("updating_classes_done"));
hideFlexoProgress();
}
public DMRepository getRepository() {
if (_repository == null) {
if (getFocusedObject() != null && getFocusedObject() instanceof DMRepository) {
_repository = (DMRepository) getFocusedObject();
}
}
return _repository;
}
}