tasks/ext/CapsuleTask.php

Show: inherited
Table of Contents

A phing task for generating output by using Capsule.

This is based on the interface to TexenTask from Apache's Velocity engine.

Author
Hans Lellelid  
Package
phing.tasks.ext  
Version
$Id: 205bc55fd1f7f36783d105ff2d0e27357282bbed $  

\AssignedVar

Package: phing\tasks\ext

An "inner" class for holding assigned var values.

May be need to expand beyond name/value in the future.

Properties

Propertyprivate  $name= ''
Details
Type
n/a
Propertyprivate  $value= ''
Details
Type
n/a

Methods

methodpublicgetName( ) : void

methodpublicgetValue( ) : void

methodpublicsetName(  $v ) : void

Parameters
Name Type Description
$v
methodpublicsetValue(  $v ) : void

Parameters
Name Type Description
$v

\CapsuleTask

Package: phing\tasks\ext

A phing task for generating output by using Capsule.

This is based on the interface to TexenTask from Apache's Velocity engine.

Parent(s)
\Task < \ProjectComponent
Author
Hans Lellelid  
Copyright
2001,2002 THYRELL. All rights reserved  
Version
$Id: 205bc55fd1f7f36783d105ff2d0e27357282bbed $  

Properties

Propertyprotectedarray  $assignedVars= 'array()'

Any vars assigned via the build file.

AssignedVar[]
Default valuearray()Details
Type
array
Propertyprotected\Capsule  $context= ''

Capsule "template" engine.

Details
Type
\Capsule
Propertyprotectedarray  $contextProperties= ''

<p> These are properties that are fed into the initial context from a properties file. This is simply a convenient way to set some values that you wish to make available in the context.

These values are not critical, like the template path or output path, but allow a convenient way to set a value that may be specific to a particular generation task.

<

p> For example, if you are generating scripts to allow user to automatically create a database, then you might want the

$databaseName

to be placed in the initial context so that it is available in a script that might look something like the following:

#!bin/sh

echo y | mysqladmin create $databaseName

The value of

$databaseName

isn't critical to output, and you obviously don't want to change the ant task to simply take a database name. So initial context values can be set with properties file.

Details
Type
array
Propertyprotectedstring  $controlTemplate= ''

This is the control template that governs the output.

It may or may not invoke the services of worker templates.

Details
Type
string
Propertyprotectedstring  $description= ''
inherited

Description of the task

Inherited from: \Task::$$description
Details
Type
string
Inherited_from
\Task::$$description  
Propertyprotected\Location  $location= ''
inherited

Stored buildfile location

Inherited from: \Task::$$location
Details
Type
\Location
Inherited_from
\Task::$$location  
Propertyprotectedstring  $outputDirectory= ''

This is where texen will place all the output that is a product of the generation process.

Details
Type
string
Propertyprotectedstring  $outputFile= ''

This is the file where the generated text will be placed.

Details
Type
string
Propertyprotected\Project  $project= 'null'
inherited

Holds a reference to the project that a project component (a task, a target, etc.) belongs to

A reference to the current project instanceInherited from: \ProjectComponent::$$project\Task::$$project
Default valuenullDetails
Type
\Project
Inherited_from
\ProjectComponent::$$project  
Inherited_from
\Task::$$project  
Propertyprotected\Target  $target= ''
inherited

Owning Target object

Inherited from: \Task::$$target
Details
Type
\Target
Inherited_from
\Task::$$target  
Propertyprotectedstring  $taskName= ''
inherited

Taskname for logger

Inherited from: \Task::$$taskName
Details
Type
string
Inherited_from
\Task::$$taskName  
Propertyprotectedstring  $taskType= ''
inherited

Internal taskname (req)

Inherited from: \Task::$$taskType
Details
Type
string
Inherited_from
\Task::$$taskType  
Propertyprotectedstring  $templatePath= ''

This is where Velocity will look for templates using the file template loader.

Details
Type
string
Propertyprotected\RuntimeConfigurable  $wrapper= ''
inherited

Wrapper of the task

Inherited from: \Task::$$wrapper
Details
Type
\RuntimeConfigurable
Inherited_from
\Task::$$wrapper  

Methods

methodprotectedcleanup( ) : void

A hook method called at the end of {@link #execute()} which can be overridden to perform any necessary cleanup activities (such as the release of database connections, etc.). By default, does nothing.

Throws
Exception Description
\Exception Problem cleaning up.
methodpubliccreateAssign( ) : void

Creates an "AssignedVar" class.

methodpublicgetContextProperties( ) : \Properties

Get the context properties that will be fed into the initial context be the generating process starts.

Returns
Type Description
\Properties
methodpublicgetControlTemplate( ) : string

Get the control template for the generating process.

Returns
Type Description
string
methodpublicgetDescription( ) : string
inherited

Returns the textual description of the task

Inherited from: \Task::getDescription()
Returns
Type Description
string The text description of the task
methodpublicgetLocation( ) : \Location
inherited

Returns the location within the buildfile this task occurs. Used by {@link BuildException} to give detailed error messages.

Inherited from: \Task::getLocation()
Returns
Type Description
\Location The location object describing the position of this task within the buildfile.
methodpublicgetOutputDirectory( ) : string

Get the output directory.

Returns
Type Description
string
methodpublicgetOutputFile( ) : string

Get the output file for the generation process.

Returns
Type Description
string
methodpublicgetOwningTarget( ) : \Target
inherited

Returns the owning target of this task.

Inherited from: \Task::getOwningTarget()
Returns
Type Description
\Target The target object that owns this task
methodpublicgetProject( ) : \Project
inherited

Returns a reference to current project

Inherited from: \ProjectComponent::getProject()\Task::getProject()
Returns
Type Description
\Project Reference to current porject object
methodprotectedgetRegisterSlot( string $slotName ) : void
inherited

Returns a name

Inherited from: \Task::getRegisterSlot()
Parameters
Name Type Description
$slotName string
methodpublicgetRuntimeConfigurableWrapper( ) : \RuntimeConfigurable
inherited

Returns the wrapper object for runtime configuration

Inherited from: \Task::getRuntimeConfigurableWrapper()
Returns
Type Description
\RuntimeConfigurable The wrapper object used by this task
methodpublicgetTaskName( ) : string
inherited

Returns the name of task, used only for log messages

Inherited from: \Task::getTaskName()
Returns
Type Description
string Name of this task
methodpublicgetTaskType( ) : string
inherited

Returns the name of the task under which it was invoked, usually the XML tagname

Inherited from: \Task::getTaskType()
Returns
Type Description
string The type of this task (XML Tag)
methodpublicgetTemplatePath( ) : string

Get the path where Velocity will look for templates using the file template loader.

Returns
Type Description
string
methodpublicinit( ) : void
inherited

Called by the parser to let the task initialize properly.

Inherited from: \Task::init()

Should throw a BuildException if something goes wrong with the build

This is abstract here, but may not be overloaded by subclasses.

Throws
Exception Description
\BuildException
methodpublicinitControlContext( ) : \Smarty

Creates a Smarty object.

Returns
Type Description
\Smarty initialized (cleared) Smarty context.
Throws
Exception Description
\Exception the execute method will catch and rethrow as a BuildException
methodpubliclog( string $msg, integer $level = Project::MSG_INFO ) : void
inherited

Provides a project level log event to the task.

Inherited from: \Task::log()
Parameters
Name Type Description
$msg string

The message to log

$level integer

The priority of the message

Details
See
\BuildEvent  
See
\BuildListener  
methodpublicmain( ) : void

Execute the input script with Velocity

Should throw a BuildException if someting goes wrong with the build

This is abstract here. Must be overloaded by real tasks.

Throws
Exception Description
\BuildException BuildExceptions are thrown when required attributes are missing. Exceptions thrown by Velocity are rethrown as BuildExceptions.
methodpublicmaybeConfigure( ) : void
inherited

Configure this task if it hasn't been done already.

Inherited from: \Task::maybeConfigure()
methodpublicperform( ) : void
inherited

Perfrom this task

Inherited from: \Task::perform()
methodprotectedpopulateInitialContext( \Capsule $context ) : void

Place useful objects into the initial context.

Parameters
Name Type Description
$context \Capsule

The context to populate, as retrieved from {@link #initControlContext()}.

Throws
Exception Description
\Exception Error while populating context. The {@link #main()} method will catch and rethrow as a BuildException.
methodpublicsetContextProperties( string $file ) : void

Set the context properties that will be fed into the initial context be the generating process starts.

Parameters
Name Type Description
$file string
methodpublicsetControlTemplate( string $controlTemplate ) : void

[REQUIRED] Set the control template for the generating process.

Parameters
Name Type Description
$controlTemplate string
methodpublicsetDescription( string $desc ) : void
inherited

Sets a textual description of the task

Inherited from: \Task::setDescription()
Parameters
Name Type Description
$desc string

The text describing the task

methodpublicsetLocation( \Location $location ) : void
inherited

Sets the location within the buildfile this task occurs. Called by the parser to set location information.

Inherited from: \Task::setLocation()
Parameters
Name Type Description
$location \Location

The location object describing the position of this task within the buildfile.

methodpublicsetOutputDirectory( \PhingFile $outputDirectory ) : void

[REQUIRED] Set the output directory. It will be created if it doesn't exist.

Parameters
Name Type Description
$outputDirectory \PhingFile
Throws
Exception Description
\Exception
methodpublicsetOutputFile( string $outputFile ) : void

[REQUIRED] Set the output file for the generation process.

Parameters
Name Type Description
$outputFile string

(TODO: change this to File)

methodpublicsetOwningTarget( \Target $target ) : void
inherited

Sets the owning target this task belongs to.

Inherited from: \Task::setOwningTarget()
Parameters
Name Type Description
$target \Target

Reference to owning target

methodpublicsetProject( \Project $project ) : void
inherited

References the project to the current component.

Inherited from: \ProjectComponent::setProject()\Task::setProject()
Parameters
Name Type Description
$project \Project

The reference to the current project

methodpublicsetRuntimeConfigurableWrapper( \RuntimeConfigurable $wrapper ) : void
inherited

Sets the wrapper object this task should use for runtime configurable elements.

Inherited from: \Task::setRuntimeConfigurableWrapper()
Parameters
Name Type Description
$wrapper \RuntimeConfigurable

The wrapper object this task should use

methodpublicsetTaskName( string $name ) : string
inherited

Sets the name of this task for log messages

Inherited from: \Task::setTaskName()
Parameters
Name Type Description
$name string
Returns
Type Description
string A string representing the name of this task for log
methodpublicsetTaskType( string $name ) : void
inherited

Sets the type of the task. Usually this is the name of the XML tag

Inherited from: \Task::setTaskType()
Parameters
Name Type Description
$name string

The type of this task (XML Tag)

methodpublicsetTemplatePath(  $templatePath ) : void

[REQUIRED] Set the path where Velocity will look for templates using the file template loader.

Parameters
Name Type Description
$templatePath
Throws
Exception Description
\Exception
Documentation was generated by DocBlox 0.18.1.