Selector that filters files based on their size.
It provides support for gathering the parameters together as well as for assigning an error message and throwing a build exception if an error is detected.
| author | Hans Lellelid <hans@xmpl.org> (Phing) |
|---|---|
| author | Bruce Atherton <bruce@callenish.com> (Ant) |
| package | phing.types.selectors |
| version | $Id$ |
circularReference()
| inherited_from | \DataType::circularReference() |
|---|---|
| inherited_from | \BaseSelector::circularReference() |
| inherited_from | \BaseExtendSelector::circularReference() |
dieOnCircularReference($stk, \Project $p)
If one is included, throw a BuildException created by circularReference
This implementation is appropriate only for a DataType that cannot hold other DataTypes as children.
The general contract of this method is that it shouldn't do anything if checked is true and set it to true on exit.
| inherited_from | \DataType::dieOnCircularReference() |
|---|---|
| inherited_from | \BaseSelector::dieOnCircularReference() |
| inherited_from | \BaseExtendSelector::dieOnCircularReference() |
getCheckedRef($requiredClass, $dataTypeName)
| inherited_from | \DataType::getCheckedRef() |
|---|---|
| inherited_from | \BaseSelector::getCheckedRef() |
| inherited_from | \BaseExtendSelector::getCheckedRef() |
getDescription()
| inherited_from | \DataType::getDescription() |
|---|---|
| inherited_from | \BaseSelector::getDescription() |
| inherited_from | \BaseExtendSelector::getDescription() |
getError() : \the
| inherited_from | \BaseSelector::getError() |
|---|---|
| inherited_from | \BaseExtendSelector::getError() |
\theerror conditiongetProject() : \Project
| inherited_from | \ProjectComponent::getProject() |
|---|---|
| inherited_from | \DataType::getProject() |
| inherited_from | \BaseSelector::getProject() |
| inherited_from | \BaseExtendSelector::getProject() |
\ProjectReference to current porject objectisReference()
| inherited_from | \DataType::isReference() |
|---|---|
| inherited_from | \BaseSelector::isReference() |
| inherited_from | \BaseExtendSelector::isReference() |
isSelected(\PhingFile $basedir, \filename $filename, \PhingFile $file) : \whether
This is where the selector gets to decide on the inclusion of a file in a particular fileset.
\basedirA PhingFile object for the base directory
\filenameThe name of the file to check
\fileA PhingFile object for this filename
\BuildException |
if the selector was not configured correctly |
|---|
\whetherthe file should be selected or notlog(string $msg, integer $level)
| inherited_from | \ProjectComponent::log() |
|---|---|
| inherited_from | \DataType::log() |
| inherited_from | \BaseSelector::log() |
| inherited_from | \BaseExtendSelector::log() |
stringThe message to be logged.
integerThe message's priority at this message should have
noChildrenAllowed()
| inherited_from | \DataType::noChildrenAllowed() |
|---|---|
| inherited_from | \BaseSelector::noChildrenAllowed() |
| inherited_from | \BaseExtendSelector::noChildrenAllowed() |
parsingComplete() : void
| inherited_from | \DataType::parsingComplete() |
|---|---|
| inherited_from | \BaseSelector::parsingComplete() |
| inherited_from | \BaseExtendSelector::parsingComplete() |
setDescription($desc)
It will be useful in commenting what we are doing.
| inherited_from | \DataType::setDescription() |
|---|---|
| inherited_from | \BaseSelector::setDescription() |
| inherited_from | \BaseExtendSelector::setDescription() |
setError(\msg $msg)
Note that only the first error message is recorded.
| inherited_from | \BaseSelector::setError() |
|---|---|
| inherited_from | \BaseExtendSelector::setError() |
\msgThe error message any BuildException should throw.
setParameters(\parameters $parameters)
It translates each parameter into the appropriate setXXX() call.
\parametersthe complete set of parameters for this selector
setProject(\Project $project)
| inherited_from | \ProjectComponent::setProject() |
|---|---|
| inherited_from | \DataType::setProject() |
| inherited_from | \BaseSelector::setProject() |
| inherited_from | \BaseExtendSelector::setProject() |
setRefid(\Reference $r) : void
Subclasses may need to check whether any other attributes have been set as well or child elements have been created and thus override this method. if they do they must call parent::setRefid()
| inherited_from | \DataType::setRefid() |
|---|---|
| inherited_from | \BaseSelector::setRefid() |
| inherited_from | \BaseExtendSelector::setRefid() |
\Reference
setUnits($units) : void
This is a little complicated because common usage has created standards that play havoc with capitalization rules. Thus, some people will use "K" for indicating 1000's, when the SI standard calls for "k". Others have tried to introduce "K" as a multiple of 1024, but that falls down when you reach "M", since "m" is already defined as 0.001.
<
p> To get around this complexity, a number of standards bodies have proposed the 2^10 standard, and at least one has adopted it. But we are still left with a populace that isn't clear on how capitalization should work.
<
p> We therefore ignore capitalization as much as possible. Completely mixed case is not possible, but all upper and lower forms are accepted for all long and short forms. Since we have no need to work with the 0.001 case, this practice works here.
<
p> This function translates all the long and short forms that a unit prefix can occur in and translates them into a single multiplier.
The units to compare the size to.
setValue(\size $size)
This will be further modified by the multiplier to get an actual size limit.
\sizethe size to select against expressed in units
setWhen(\cmp $cmp)
\cmpThe comparison to perform, an EnumeratedAttribute
toString()
tooManyAttributes()
| inherited_from | \DataType::tooManyAttributes() |
|---|---|
| inherited_from | \BaseSelector::tooManyAttributes() |
| inherited_from | \BaseExtendSelector::tooManyAttributes() |
validate()
| inherited_from | \BaseSelector::validate() |
|---|---|
| inherited_from | \BaseExtendSelector::validate() |
verifySettings()
In this case, it means that the size attribute has been set (to a positive value), that the multiplier has a valid setting, and that the size limit is valid. Since the latter is a calculated value, this can only fail due to a programming error.
If a problem is detected, the setError() method is called.
getParameters() : \the
| inherited_from | \BaseExtendSelector::getParameters() |
|---|
\theset of parameters defined for this selector$description
| inherited_from | \DataType::$$description |
|---|---|
| inherited_from | \BaseSelector::$$description |
| inherited_from | \BaseExtendSelector::$$description |
$ref
Type of Reference
| inherited_from | \DataType::$$ref |
|---|---|
| inherited_from | \BaseSelector::$$ref |
| inherited_from | \BaseExtendSelector::$$ref |
$checked : boolean
Subclasses are responsible for setting this value to false if we'd need to investigate this condition (usually because a child element has been added that is a subclass of DataType).
| inherited_from | \DataType::$$checked |
|---|---|
| inherited_from | \BaseSelector::$$checked |
| inherited_from | \BaseExtendSelector::$$checked |
$parameters
| inherited_from | \BaseExtendSelector::$$parameters |
|---|
$project : \Project
| inherited_from | \ProjectComponent::$$project |
|---|---|
| inherited_from | \DataType::$$project |
| inherited_from | \BaseSelector::$$project |
| inherited_from | \BaseExtendSelector::$$project |
$byteUnits
$cmp
$errmsg
| inherited_from | \BaseSelector::$$errmsg |
|---|---|
| inherited_from | \BaseExtendSelector::$$errmsg |
$multiplier
$size
$sizeComparisons
$sizelimit
SIZE_KEY
UNITS_KEY
WHEN_KEY