/** * Copyright 2009 Red Hat, Inc. * * This program 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 2 of the License, or * (at your option) any later version. * * This program 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 this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package org.safehaus.penrose.partition; import org.safehaus.penrose.adapter.AdapterConfig; import org.safehaus.penrose.connection.ConnectionConfigManager; import org.safehaus.penrose.directory.DirectoryConfig; import org.safehaus.penrose.interpreter.InterpreterConfig; import org.safehaus.penrose.mapping.MappingConfigManager; import org.safehaus.penrose.module.ModuleConfigManager; import org.safehaus.penrose.scheduler.SchedulerConfig; import org.safehaus.penrose.source.SourceConfigManager; import org.safehaus.penrose.thread.ThreadManagerConfig; import java.io.Serializable; import java.util.*; /** * @author Endi S. Dewata */ public class PartitionConfig implements Serializable, Cloneable { public final static long serialVersionUID = 1L; public final static String ROOT = "ROOT"; protected boolean enabled = true; protected String name; protected String description; protected String partitionClass; protected Collection<String> depends = new ArrayList<String>(); protected Map<String,AdapterConfig> adapterConfigs = new LinkedHashMap<String,AdapterConfig>(); protected Map<String,InterpreterConfig> interpreterConfigs = new LinkedHashMap<String,InterpreterConfig>(); protected Map<String,String> parameters = new LinkedHashMap<String,String>(); protected ConnectionConfigManager connectionConfigManager = new ConnectionConfigManager(); protected SourceConfigManager sourceConfigManager = new SourceConfigManager(); protected MappingConfigManager mappingConfigManager = new MappingConfigManager(); protected DirectoryConfig directoryConfig = new DirectoryConfig(); protected ModuleConfigManager moduleConfigManager = new ModuleConfigManager(); protected ThreadManagerConfig threadManagerConfig; protected SchedulerConfig schedulerConfig; public PartitionConfig() { } public boolean isEnabled() { return enabled; } public void setEnabled(boolean enabled) { this.enabled = enabled; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public ThreadManagerConfig getThreadManagerConfig() { return threadManagerConfig; } public void setThreadManagerConfig(ThreadManagerConfig threadManagerConfig) { this.threadManagerConfig = threadManagerConfig; } public Map<String,String> getParameters() { return parameters; } public Collection<String> getParameterNames() { return parameters.keySet(); } public String getParameter(String name) { return parameters.get(name); } public void setParameters(Map<String,String> parameters) { if (parameters == this.parameters) return; this.parameters.clear(); this.parameters.putAll(parameters); } public void setParameter(String name, String value) { parameters.put(name, value); } public String removeParameter(String name) { return parameters.remove(name); } public ConnectionConfigManager getConnectionConfigManager() { return connectionConfigManager; } public SourceConfigManager getSourceConfigManager() { return sourceConfigManager; } public MappingConfigManager getMappingConfigManager() { return mappingConfigManager; } public DirectoryConfig getDirectoryConfig() { return directoryConfig; } public ModuleConfigManager getModuleConfigManager() { return moduleConfigManager; } public Collection<InterpreterConfig> getInterpreterConfigs() { return interpreterConfigs.values(); } public void addInterpreterConfig(InterpreterConfig interpreterConfig) { interpreterConfigs.put(interpreterConfig.getName(), interpreterConfig); } public Collection<AdapterConfig> getAdapterConfigs() { return adapterConfigs.values(); } public AdapterConfig getAdapterConfig(String name) { return adapterConfigs.get(name); } public void addAdapterConfig(AdapterConfig adapter) { adapterConfigs.put(adapter.getName(), adapter); } public Collection<String> getAdapterNames() { return adapterConfigs.keySet(); } public SchedulerConfig getSchedulerConfig() { return schedulerConfig; } public void setSchedulerConfig(SchedulerConfig schedulerConfig) { this.schedulerConfig = schedulerConfig; } public String getPartitionClass() { return partitionClass; } public void setPartitionClass(String partitionClass) { this.partitionClass = partitionClass; } public Collection<String> getDepends() { return depends; } public void setDepends(Collection<String> depends) { this.depends.clear(); if (depends == null) return; this.depends.addAll(depends); } public void setStringDepends(String depends) { for (StringTokenizer st = new StringTokenizer(depends, ", "); st.hasMoreTokens(); ) { String depend = st.nextToken(); addDepend(depend); } } public String getStringDepends() { StringBuilder sb = new StringBuilder(); for (String depend : depends) { if (sb.length() > 0) sb.append(","); sb.append(depend); } return sb.toString(); } public void addDepend(String depend) { depends.add(depend); } public void removeDepend(String depend) { depends.remove(depend); } public int hashCode() { return name == null ? 0 : name.hashCode(); } boolean equals(Object o1, Object o2) { if (o1 == null && o2 == null) return true; if (o1 != null) return o1.equals(o2); return o2.equals(o1); } public boolean equals(Object object) { if (this == object) return true; if (object == null) return false; if (object.getClass() != this.getClass()) return false; PartitionConfig partitionConfig = (PartitionConfig)object; if (enabled != partitionConfig.enabled) return false; if (!equals(name, partitionConfig.name)) return false; if (!equals(description, partitionConfig.description)) return false; if (!equals(partitionClass, partitionConfig.partitionClass)) return false; if (!equals(depends, partitionConfig.depends)) return false; if (!equals(adapterConfigs, partitionConfig.adapterConfigs)) return false; if (!equals(interpreterConfigs, partitionConfig.interpreterConfigs)) return false; if (!equals(parameters, partitionConfig.parameters)) return false; if (!equals(threadManagerConfig, partitionConfig.threadManagerConfig)) return false; if (!equals(schedulerConfig, partitionConfig.schedulerConfig)) return false; return true; } public Object clone() throws CloneNotSupportedException { PartitionConfig partitionConfig = (PartitionConfig)super.clone(); partitionConfig.enabled = enabled; partitionConfig.name = name; partitionConfig.description = description; partitionConfig.partitionClass = partitionClass; partitionConfig.depends = new ArrayList<String>(); partitionConfig.depends.addAll(depends); partitionConfig.adapterConfigs = new LinkedHashMap<String,AdapterConfig>(); for (AdapterConfig adapterConfig : adapterConfigs.values()) { partitionConfig.addAdapterConfig((AdapterConfig) adapterConfig.clone()); } partitionConfig.interpreterConfigs = new LinkedHashMap<String,InterpreterConfig>(); for (InterpreterConfig interpreterConfig : interpreterConfigs.values()) { partitionConfig.addInterpreterConfig((InterpreterConfig) interpreterConfig.clone()); } partitionConfig.parameters = new LinkedHashMap<String,String>(); partitionConfig.parameters.putAll(parameters); partitionConfig.connectionConfigManager = (ConnectionConfigManager) connectionConfigManager.clone(); partitionConfig.sourceConfigManager = (SourceConfigManager) sourceConfigManager.clone(); partitionConfig.mappingConfigManager = (MappingConfigManager) mappingConfigManager.clone(); partitionConfig.directoryConfig = (DirectoryConfig) directoryConfig.clone(); partitionConfig.moduleConfigManager = (ModuleConfigManager) moduleConfigManager.clone(); partitionConfig.threadManagerConfig = threadManagerConfig == null ? null : (ThreadManagerConfig)threadManagerConfig.clone(); partitionConfig.schedulerConfig = schedulerConfig == null ? null : (SchedulerConfig)schedulerConfig.clone(); return partitionConfig; } }