/*
* Copyright 2009 VoidSearch.com
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.voidsearch.voidbase.storage.distributed;
import com.voidsearch.voidbase.storage.StorageException;
import com.voidsearch.voidbase.storage.bdb.BDBStore;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class DistributedStorage {
protected static DistributedStorage storage = null;
protected Map<String, DistributedStore> stores = new ConcurrentHashMap<String, DistributedStore>();
protected static final Logger logger = LoggerFactory.getLogger(DistributedStorage.class.getName());
protected DistributedStorage() {
super();
}
public Object clone() throws CloneNotSupportedException {
throw new CloneNotSupportedException();
}
public static synchronized DistributedStorage getInstance() {
if (storage == null) {
storage = new DistributedStorage();
}
return storage;
}
public synchronized void open(String name, String path) throws StorageException {
if (name == null || stores.containsKey(name))
return;
stores.put(name, new DistributedStore(name, path));
}
public synchronized void close(String name) throws StorageException {
if (name == null || !stores.containsKey(name))
return;
stores.get(name).close();
}
public Boolean isOpened(String name) {
if (name == null)
return false;
return stores.containsKey(name);
}
}