SourceInformationImpl.java
// @formatter:off
/*******************************************************************************
*
* This file is part of JMad.
*
* Copyright (c) 2008-2011, CERN. All rights reserved.
*
* 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.
*
******************************************************************************/
// @formatter:on
/**
*
*/
package cern.accsoft.steering.jmad.modeldefs.domain;
import static java.util.Objects.requireNonNull;
import java.io.File;
/**
* The default implementation for the {@link SourceInformation} interface.
*
* @author Kajetan Fuchsberger (kajetan.fuchsberger at cern.ch)
*/
public class SourceInformationImpl implements SourceInformation {
/** The path to the jmd.xml or the name of the zip archive */
private final File rootPath;
/** The type of the model definition (like JAR, ZIP or LOCAL) */
private final SourceType sourceType;
/** The name of the xml file from which the model definition was loaded. */
private final String xmlFileName;
/**
* The path offset inside the archive, relative to which the files can be fond. This is usually the parent of the
* xmlFileName
*/
private final String pathOffsetWithinArchive;
/**
* The constructor which requires both the {@link SourceInformation.SourceType} and the rootPath
*
* @param sourceType defines the method how the model-file paths will be treated.
* @param rootPath the path to the zip or base dir for the model definitions
* @param xmlFileName the name of the file from which the modelDefinition was loaded (usually fully qualified)
* @param pathOffsetWithinArchive the path offset within an archive to use, when querying files. This is usually the
* parent path (within the offset) of the xml file.
*/
public SourceInformationImpl(SourceType sourceType, File rootPath, String xmlFileName,
String pathOffsetWithinArchive) {
this.sourceType = sourceType;
this.rootPath = rootPath;
this.xmlFileName = xmlFileName;
this.pathOffsetWithinArchive = requireNonNull(pathOffsetWithinArchive,
"pathWithinArchive must not be null");
}
@Override
public File getRootPath() {
return this.rootPath;
}
@Override
public SourceType getSourceType() {
return this.sourceType;
}
@Override
public String getFileName() {
return this.xmlFileName;
}
@Override
public String getPathOffsetWithinArchive() {
return this.pathOffsetWithinArchive;
}
}