githubEdit

What's New in 5.3.1

Updated bundled Java libraries

  • JLine - 3.19.0

  • jGit - 5.11.0.202103091610-r

  • Launch4j - 3.14

  • JANSI - 2.3.2

Recursive jar scanning libDirs

When you configure libDirs for a server, CommandBox used to only load jar files found in the root. Now it will include sub directories which gives you more flexibility around how to install your jars.

# Jar installs to lib/jline-3.0.0.M1/jline-3.0.0.M1.jar
install "jar:https://search.maven.org/remotecontent?filepath=jline/jline/3.0.0.M1/jline-3.0.0.M1.jar"

# Load up the jar when the server starts
server set app.libDirs=lib

New printTable Command

In the previous release, we introduced a new helper for printing ASCII Art tables in your custom commands and task runners. We've taken this a step further and wrapped the table printer utiilty in a new command so you can use it from the CLI directly. We've also expanded its functionality to accept ANY data in as JSON and it will marshall it into a query for you. This means it can be a query, an array of structs, an array or arrays, and more. You can now get quick and easy visualization of any data right from the CLI or in builds.

# array of structs
printTable [{a:1,b:2},{a:3,b:4},{a:5,b:6}]

╔═══╤═══╗
 a  b 
╠═══╪═══╣
 1  2 
╟───┼───╢
 3  4 
╟───┼───╢
 5  6 
╚═══╧═══╝

# array of arrays
printTable data=[[1,2],[3,4],[5,6]] headerNames=foo,bar

╔═════╤═════╗
 foo  bar 
╠═════╪═════╣
 1    2   
╟─────┼─────╢
 3    4   
╟─────┼─────╢
 5    6   
╚═════╧═════╝

# Query object
#extensionlist | printTable name,version

╔═════════════════════════════════════════╤═══════════════════╗
 name                                     version           
╠═════════════════════════════════════════╪═══════════════════╣
 MySQL                                    8.0.19            
╟─────────────────────────────────────────┼───────────────────╢
 Microsoft SQL Server (Vendor Microsoft) │ 6.5.4             ║
╟─────────────────────────────────────────┼───────────────────╢
 PostgreSQL                               9.4.1212          
╟─────────────────────────────────────────┼───────────────────╢
 Ajax Extension                           1.0.0.3           
╚═════════════════════════════════════════╧═══════════════════╝

# JSON list of all servers
server list --json | printTable name,host,port,status

╔══════════════════════════════╤═════════════════════════════╤═══════╤═════════╗
 name                          host                         port   status  
╠══════════════════════════════╪═════════════════════════════╪═══════╪═════════╣
 servicetest                   127.0.0.1                    54427  stopped 
╟──────────────────────────────┼─────────────────────────────┼───────┼─────────╢
 servicetest2                  127.0.0.1                    52919  stopped 
╟──────────────────────────────┼─────────────────────────────┼───────┼─────────╢
 FRDemos                       127.0.0.1                    50458  stopped 
╚══════════════════════════════╧═════════════════════════════╧═══════╧═════════╝

New sql command for on-the-fly manipulation of data

As if the previous command isn't cool enough, we've also added a new "sql" command which will also accept any sort of data as JSON, marshall it into a query object and allow you to alias, filter, order, and limit the rows on the fly using CFML's query of queries!

The sql command works very nicely with the new tablePrinter command, and truly makes JSON a first class citizen of the CommandBox CLI.

Small change to print.table() helper

We've made a small adjustment to the print.table() helper that was introduced in CommandBox 5.3.1 as follows. The old method signature is

And the new method signature is:

The parameters to the new printTable command matches the NEW method signature of the print.table() helper as well.

Format XML in REPL

When working with XML in the REPL, formatting is now applied when the XML is printed out to the console, making it easier to read (same as JSON)

Release Notes

Bug

COMMANDBOX-1320arrow-up-right Server stop doesn't message user when it fails

COMMANDBOX-1319arrow-up-right Stop loading cfusion/lib in system class loader

COMMANDBOX-1318arrow-up-right 5.3.0 errors with commandbox-dotenv 1.x versions due to WireBox change

COMMANDBOX-1314arrow-up-right When building Lucee war from local jars, seeded web.xml file is ignored

COMMANDBOX-1311arrow-up-right Table printer error with no rows

COMMANDBOX-1310arrow-up-right update '{slug}' fails as it is trying to print the package version and its dependencies.

COMMANDBOX-1308arrow-up-right Relative Web Alias Behavior (regression)

COMMANDBOX-1307arrow-up-right jq doesn't resolve file paths to current working directory

COMMANDBOX-1303arrow-up-right CFEngine adobe - Could not initialize class coldfusion.vfs.VFile when using s3 protocol

Improvement

COMMANDBOX-1328arrow-up-right Improve performance of piping large strings to "cfml" command

COMMANDBOX-1317arrow-up-right Format XML in REPL

COMMANDBOX-1316arrow-up-right Change default CLI JSON representation of query to array of structs

COMMANDBOX-1306arrow-up-right Allow upgrade command to pull stable versions when CLI is a prerelease version

COMMANDBOX-1305arrow-up-right Update bundled java libraries

COMMANDBOX-1302arrow-up-right app.libDirs does not load jars/classes recursively from sub folders

COMMANDBOX-1210arrow-up-right Allow for relative URLs when defining trayoption elements

COMMANDBOX-1194arrow-up-right Add Libraries To Runwar Necessary For URLRewrite Proxy

New Feature

COMMANDBOX-1324arrow-up-right New "printTable" command to add CLI usage of table printer

COMMANDBOX-1323arrow-up-right New "sql" command to filter tabular data with SQL

COMMANDBOX-1321arrow-up-right Add --verbose to 'server stop' to see raw output

COMMANDBOX-1309arrow-up-right Add printTable command that proxies to print.table() helper

Last updated

Was this helpful?