-
Notifications
You must be signed in to change notification settings - Fork 63
Using PCT with Groovy
Despite being primarily a build tool, Apache Ant is a very practical tool for manipulating files including zip files, copy, resource processing, … But if ever you’ve been working with a build.xml file and found yourself a little restricted by all those pointy brackets, or found it a bit weird using XML as a scripting language and wanted something a little cleaner and more straight forward, then maybe Ant scripting with Groovy might be what you’re after.
Wikipedia explains it:
Apache Groovy is an object-oriented programming language for the Java platform. It is a dynamic language with features similar to those of Python, Ruby, Perl, and Smalltalk. It can be used as a scripting language for the Java Platform, is dynamically compiled to Java virtual machine (JVM) bytecode, and interoperates with other Java code and libraries. Groovy uses a Java-like curly-bracket syntax. Most Java code is also syntactically valid Groovy, although semantics may be different.
This page is a very good introduction to Ant scripting in Groovy.
A short example on how to execute an OpenEdge procedure in Groovy:
def ant = new AntBuilder()
ant.taskdef (resource: 'PCT.properties')
ant.PCTRun(procedure: 'updateCustomers.p', dlcHome: '/usr/dlc') {
DBConnection(dbName: 'sports2000', dbDir: '/db/prod')
}
Another example on how to execute the same procedure on each OpenEdge database in a directory:
new File('databases').traverse(type: FileType.FILES, nameFilter: ~/[a-z]+\.db/) { db ->
ant.PCTRun(procedure: 'updateCustomers.p', dlcHome: '/usr/dlc') {
DBConnection(dbName: db.name, dbDir: db.parent)
}
}
If you're working with PCT, it's because your product is written in OpenEdge. OpenEdge includes a Java Virtual Machine since ages. Groovy is pure Java. PCT is pure Java. Both are just a JAR files. This means that if you want to use Groovy / PCT to deploy on customer site, you can rely on the JVM bundled with OpenEdge, which is available at $DLC/jre
. So once the DLC
variable is correctly set, you can execute your update script:
$DLC/jre/bin/java -jar groovy-pct.jar update-script.groovy
- Rolling out new release
- Database update mechanism
- ...
def cli = new groovy.util.CliBuilder(usage: 'java -jar groovy-pct.jar script.groovy [options]')
cli.dlc(args: 1, 'OpenEdge installation directory')
cli.host(args: 1,optionalArg: true, 'Hostname')
cli.port(args: 1,optionalArg: true, 'Port')
cli.user(args: 1,optionalArg: true, 'User name')
cli.password(args: 1,optionalArg: true, 'Password')
def options = cli.parse(args)
propath = [ 'dir1', 'dir2', 'dir3']
ant.PCTRun (procedure: 'readinfo.p', dlcHome: System.env['DLC']) {
DBConnection (dbname: 'dbname', dbdir: '/db/db1')
Propath {
propath.each { pathelement (location: it) }
}
OutputParameter (name: 'xxx')
OutputParameter (name: 'yyy')
}
println "-> Output parameters : '${ant.project.properties.xxx}' and '${ant.project.properties.yyy}'"
With this OpenEdge procedure:
define output parameter op1 as character no-undo.
define output parameter op2 as character no-undo.
assign op1 = 'Your logic here'.
assign op2 = 'Your logic here'.
return '0'.
Make sure all procedures are xcode'd (hint: use PCTXCode). Then use xCodeInit attribute in PCTRun to xcode init procedure on the fly. You have to make sure the xcode
executable is available in the PATH.
ant.PCTRun (procedure: 'readinfo-xcode.p', dlcHome: options.dlc, xCodeInit: true)
def ant = new AntBuilder()
ant.taskdef(uri:'antlib:eu.rssw.pct', resource:'eu/rssw/pct/antlib.xml')
def pct = groovy.xml.NamespaceBuilder.newInstance(ant, 'antlib:eu.rssw.pct')
pct.run(procedure: 'rssw.p', dlcHome: System.env['DLC'])
- QuickStart
- Changelog
- InstallDocumentation
- FAQ
-
Tasks
- PCT
- DlcHome
- PCTRun
- PCTDynRun
- PCTCompile
- PCTWSComp
- PCTCreateDatabase
- Sports2000
- PCTDumpSchema
- PCTDumpSequences
- PCTLoadSchema
- PCTIncrementalDump
- PCTBinaryDump
- PCTBinaryLoad
- PCTDumpData
- PCTLoadData
- PCTSchemaDoc
- PCTLibrary
- PCTProxygen
- PCTXCode
- ProgressVersion
- PCTVersion
- ClassDocumentation
- HtmlDocumentation
- XMLDocumentation
- JsonDocumentation
- ABLDuck
- OEUnit
- ABLUnit
- RestGen
- AssemblyCatalog
- Types