All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.graphhopper.storage.Directory Maven / Gradle / Ivy

Go to download

GraphHopper is a fast and memory efficient Java road routing engine working seamlessly with OpenStreetMap data.

There is a newer version: 10.0
Show newest version
/*
 *  Licensed to GraphHopper GmbH under one or more contributor
 *  license agreements. See the NOTICE file distributed with this work for
 *  additional information regarding copyright ownership.
 *
 *  GraphHopper GmbH licenses this file to you 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.graphhopper.storage;

import java.util.Map;

/**
 * Maintains a collection of DataAccess objects stored at the same location. One GraphStorage per
 * Directory as we need one to maintain one DataAccess object for nodes, edges and location2id
 * index.
 * 

* * @author Peter Karich */ public interface Directory { /** * @return an id or location in the local filesystem. */ String getLocation(); /** * Creates a new DataAccess object with the given name in the location of this Directory. Each name can only * be used once. */ DataAccess create(String name); /** * @param segmentSize segment size in bytes or -1 to use the default of the corresponding DataAccess implementation */ DataAccess create(String name, int segmentSize); DataAccess create(String name, DAType type); DataAccess create(String name, DAType type, int segmentSize); /** * Removes the specified object from the directory. */ void remove(String name); /** * @return the default type of a newly created DataAccess object */ DAType getDefaultType(); DAType getDefaultType(String dataAccess, boolean preferInts); /** * Removes all contained objects from the directory and releases its resources. */ void clear(); /** * Releases all allocated resources from the directory without removing backing files. */ void close(); Directory create(); Map getDAs(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy