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

org.opentripplanner.netex.configure.NetexConfig Maven / Gradle / Ivy

There is a newer version: 2.6.0
Show newest version
package org.opentripplanner.netex.configure;

import org.opentripplanner.datastore.CompositeDataSource;
import org.opentripplanner.datastore.DataSource;
import org.opentripplanner.datastore.FileType;
import org.opentripplanner.datastore.file.ZipFileDataSource;
import org.opentripplanner.netex.NetexModule;
import org.opentripplanner.netex.loader.NetexBundle;
import org.opentripplanner.netex.loader.NetexDataSourceHierarchy;
import org.opentripplanner.standalone.config.BuildConfig;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

/**
 * Responsible for dependency injection and creating main NeTEx module
 * objects. This decouple the main classes in the netex module, and serve
 * as a single entry-point to create a {@link NetexModule} witch simplify
 * the code({@link org.opentripplanner.graph_builder.GraphBuilder}) using it.
 * 

* This class inject the build configuration. This way none of the other * classes in the `org.opentripplanner.netex` have dependencies to the * {@link BuildConfig}. *

* The naming convention used is close to the defacto standard used by Spring. */ public class NetexConfig { private final BuildConfig buildParams; private NetexConfig(BuildConfig builderParams) { this.buildParams = builderParams; } public static NetexModule netexModule( BuildConfig buildParams, Iterable netexSources ) { return new NetexConfig(buildParams).netexModule(netexSources); } public static NetexBundle netexBundleForTest(BuildConfig builderParams, File netexZipFile) { return new NetexConfig(builderParams).netexBundle(new ZipFileDataSource(netexZipFile, FileType.NETEX)); } private NetexModule netexModule(Iterable netexSources) { List netexBundles = new ArrayList<>(); for(DataSource it : netexSources){ NetexBundle netexBundle = netexBundle((CompositeDataSource)it); netexBundles.add(netexBundle); } return new NetexModule( buildParams.netex.netexFeedId, buildParams.parentStopLinking, buildParams.stationTransfers, buildParams.getSubwayAccessTimeSeconds(), buildParams.maxInterlineDistance, buildParams.getTransitServicePeriod(), netexBundles ); } /** public to enable testing */ private NetexBundle netexBundle(CompositeDataSource source) { return new NetexBundle(buildParams.netex.netexFeedId, source, hierarchy(source)); } private NetexDataSourceHierarchy hierarchy(CompositeDataSource source){ org.opentripplanner.standalone.config.NetexConfig c = buildParams.netex; return new NetexDataSourceHierarchy(source).prepare( c.ignoreFilePattern, c.sharedFilePattern, c.sharedGroupFilePattern, c.groupFilePattern ); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy