blob: 634a14b04fbaf325373aa66dec858e48c759ff92 [file] [log] [blame]
// ========================================================================
// Copyright (c) Webtide LLC
// ------------------------------------------------------------------------
// All rights reserved. This program and the accompanying materials
// are made available under the terms of the Eclipse Public License v1.0
// and Apache License v2.0 which accompanies this distribution.
//
// The Eclipse Public License is available at
// http://www.eclipse.org/legal/epl-v10.html
//
// The Apache License v2.0 is available at
// http://www.apache.org/licenses/LICENSE-2.0.txt
//
// You may elect to redistribute this code under either of these licenses.
// ========================================================================
package org.eclipse.jetty.deploy.util;
import java.io.File;
/**
* Simple, yet surprisingly common utility methods for identifying various file types commonly seen and worked with in a
* deployment scenario.
*/
public class FileID
{
/**
* Is the path a Web Archive?
*
* @param path
* the path to test.
* @return True if a .war or .jar or exploded web directory
* @see FileID#isWebArchiveFile(File)
*/
public static boolean isWebArchive(File path)
{
if (path.isFile())
{
String name = path.getName().toLowerCase();
return (name.endsWith(".war") || name.endsWith(".jar"));
}
File webInf = new File(path,"WEB-INF");
File webXml = new File(webInf,"web.xml");
return webXml.exists() && webXml.isFile();
}
/**
* Is the path a Web Archive File (not directory)
*
* @param path
* the path to test.
* @return True if a .war or .jar file.
* @see FileID#isWebArchive(File)
*/
public static boolean isWebArchiveFile(File path)
{
if (!path.isFile())
{
return false;
}
String name = path.getName().toLowerCase();
return (name.endsWith(".war") || name.endsWith(".jar"));
}
public static boolean isXmlFile(File path)
{
if (!path.isFile())
{
return false;
}
String name = path.getName().toLowerCase();
return name.endsWith(".xml");
}
}