/*
|
* ProGuard -- shrinking, optimization, obfuscation, and preverification
|
* of Java bytecode.
|
*
|
* Copyright (c) 2002-2014 Eric Lafortune (eric@graphics.cornell.edu)
|
*
|
* This program is free software; you can redistribute it and/or modify it
|
* under the terms of the GNU General Public License as published by the Free
|
* Software Foundation; either version 2 of the License, or (at your option)
|
* any later version.
|
*
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
* more details.
|
*
|
* You should have received a copy of the GNU General Public License along
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
*/
|
package proguard;
|
|
import proguard.util.ListUtil;
|
|
import java.io.*;
|
import java.util.List;
|
|
|
/**
|
* This class represents an entry from a class path: an apk, a jar, an aar, a
|
* war, a zip, an ear, or a directory, with a name and a flag to indicates
|
* whether the entry is an input entry or an output entry. Optional filters can
|
* be specified for the names of the contained resource/classes, apks, jars,
|
* aars, wars, ears, and zips.
|
*
|
* @author Eric Lafortune
|
*/
|
public class ClassPathEntry
|
{
|
private File file;
|
private boolean output;
|
private List filter;
|
private List apkFilter;
|
private List jarFilter;
|
private List aarFilter;
|
private List warFilter;
|
private List earFilter;
|
private List zipFilter;
|
|
private String cachedName;
|
|
|
/**
|
* Creates a new ClassPathEntry with the given file and output flag.
|
*/
|
public ClassPathEntry(File file, boolean isOutput)
|
{
|
this.file = file;
|
this.output = isOutput;
|
}
|
|
|
/**
|
* Returns the path name of the entry.
|
*/
|
public String getName()
|
{
|
if (cachedName == null)
|
{
|
cachedName = getUncachedName();
|
}
|
|
return cachedName;
|
}
|
|
|
/**
|
* Returns the uncached path name of the entry.
|
*/
|
private String getUncachedName()
|
{
|
try
|
{
|
return file.getCanonicalPath();
|
}
|
catch (IOException ex)
|
{
|
return file.getPath();
|
}
|
}
|
|
|
/**
|
* Returns the file.
|
*/
|
public File getFile()
|
{
|
return file;
|
}
|
|
|
/**
|
* Sets the file.
|
*/
|
public void setFile(File file)
|
{
|
this.file = file;
|
this.cachedName = null;
|
}
|
|
|
/**
|
* Returns whether this data entry is an output entry.
|
*/
|
public boolean isOutput()
|
{
|
return output;
|
}
|
|
|
/**
|
* Specifies whether this data entry is an output entry.
|
*/
|
public void setOutput(boolean output)
|
{
|
this.output = output;
|
}
|
|
|
/**
|
* Returns whether this data entry is a dex file.
|
*/
|
public boolean isDex()
|
{
|
return hasExtension(".dex");
|
}
|
|
|
/**
|
* Returns whether this data entry is an apk file.
|
*/
|
public boolean isApk()
|
{
|
return hasExtension(".apk") ||
|
hasExtension(".ap_");
|
}
|
|
|
/**
|
* Returns whether this data entry is a jar file.
|
*/
|
public boolean isJar()
|
{
|
return hasExtension(".jar");
|
}
|
|
|
/**
|
* Returns whether this data entry is an aar file.
|
*/
|
public boolean isAar()
|
{
|
return hasExtension(".aar");
|
}
|
|
|
/**
|
* Returns whether this data entry is a war file.
|
*/
|
public boolean isWar()
|
{
|
return hasExtension(".war");
|
}
|
|
|
/**
|
* Returns whether this data entry is a ear file.
|
*/
|
public boolean isEar()
|
{
|
return hasExtension(".ear");
|
}
|
|
|
/**
|
* Returns whether this data entry is a zip file.
|
*/
|
public boolean isZip()
|
{
|
return hasExtension(".zip");
|
}
|
|
|
/**
|
* Returns whether this data entry has the given extension.
|
*/
|
private boolean hasExtension(String extension)
|
{
|
return endsWithIgnoreCase(file.getPath(), extension);
|
}
|
|
|
/**
|
* Returns whether the given string ends with the given suffix, ignoring
|
* its case.
|
*/
|
private static boolean endsWithIgnoreCase(String string, String suffix)
|
{
|
int stringLength = string.length();
|
int suffixLength = suffix.length();
|
|
return string.regionMatches(true, stringLength -
|
suffixLength, suffix, 0, suffixLength);
|
}
|
|
|
/**
|
* Returns whether this data entry has any kind of filter.
|
*/
|
public boolean isFiltered()
|
{
|
return filter != null ||
|
apkFilter != null ||
|
jarFilter != null ||
|
aarFilter != null ||
|
warFilter != null ||
|
earFilter != null ||
|
zipFilter != null;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to bottom-level files in this entry.
|
*/
|
public List getFilter()
|
{
|
return filter;
|
}
|
|
/**
|
* Sets the name filter that is applied to bottom-level files in this entry.
|
*/
|
public void setFilter(List filter)
|
{
|
this.filter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to apk files in this entry, if any.
|
*/
|
public List getApkFilter()
|
{
|
return apkFilter;
|
}
|
|
/**
|
* Sets the name filter that is applied to apk files in this entry, if any.
|
*/
|
public void setApkFilter(List filter)
|
{
|
this.apkFilter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to jar files in this entry, if any.
|
*/
|
public List getJarFilter()
|
{
|
return jarFilter;
|
}
|
|
/**
|
* Sets the name filter that is applied to jar files in this entry, if any.
|
*/
|
public void setJarFilter(List filter)
|
{
|
this.jarFilter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to aar files in this entry, if any.
|
*/
|
public List getAarFilter()
|
{
|
return aarFilter;
|
}
|
|
/**
|
* Sets the name filter that is applied to aar files in this entry, if any.
|
*/
|
public void setAarFilter(List filter)
|
{
|
this.aarFilter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to war files in this entry, if any.
|
*/
|
public List getWarFilter()
|
{
|
return warFilter;
|
}
|
|
/**
|
* Sets the name filter that is applied to war files in this entry, if any.
|
*/
|
public void setWarFilter(List filter)
|
{
|
this.warFilter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to ear files in this entry, if any.
|
*/
|
public List getEarFilter()
|
{
|
return earFilter;
|
}
|
|
/**
|
* Sets the name filter that is applied to ear files in this entry, if any.
|
*/
|
public void setEarFilter(List filter)
|
{
|
this.earFilter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
/**
|
* Returns the name filter that is applied to zip files in this entry, if any.
|
*/
|
public List getZipFilter()
|
{
|
return zipFilter;
|
}
|
|
/**
|
* Sets the name filter that is applied to zip files in this entry, if any.
|
*/
|
public void setZipFilter(List filter)
|
{
|
this.zipFilter = filter == null || filter.size() == 0 ? null : filter;
|
}
|
|
|
// Implementations for Object.
|
|
public String toString()
|
{
|
String string = getName();
|
|
if (filter != null ||
|
jarFilter != null ||
|
aarFilter != null ||
|
warFilter != null ||
|
earFilter != null ||
|
zipFilter != null)
|
{
|
string +=
|
ConfigurationConstants.OPEN_ARGUMENTS_KEYWORD +
|
(aarFilter != null ? ListUtil.commaSeparatedString(aarFilter, true) : "") +
|
ConfigurationConstants.SEPARATOR_KEYWORD +
|
(apkFilter != null ? ListUtil.commaSeparatedString(apkFilter, true) : "") +
|
ConfigurationConstants.SEPARATOR_KEYWORD +
|
(zipFilter != null ? ListUtil.commaSeparatedString(zipFilter, true) : "") +
|
ConfigurationConstants.SEPARATOR_KEYWORD +
|
(earFilter != null ? ListUtil.commaSeparatedString(earFilter, true) : "") +
|
ConfigurationConstants.SEPARATOR_KEYWORD +
|
(warFilter != null ? ListUtil.commaSeparatedString(warFilter, true) : "") +
|
ConfigurationConstants.SEPARATOR_KEYWORD +
|
(jarFilter != null ? ListUtil.commaSeparatedString(jarFilter, true) : "") +
|
ConfigurationConstants.SEPARATOR_KEYWORD +
|
(filter != null ? ListUtil.commaSeparatedString(filter, true) : "") +
|
ConfigurationConstants.CLOSE_ARGUMENTS_KEYWORD;
|
}
|
|
return string;
|
}
|
}
|