Name
Data::Table::Text - Write data in tabular text format.
Synopsis
use Data::Table::Text;
# Print a table:
my $d =
[[qq(a), qq(b\nbb), qq(c\ncc\nccc\n)],
[qq(1), qq(1\n22), qq(1\n22\n333\n)],
];
my $t = formatTable($d, [qw(A BB CCC)]);
ok $t eq <<END;
A BB CCC
1 a b c
bb cc
ccc
2 1 1 1
22 22
333
END
# Print a table containing tables and make it into a report:
my $D = [[qq(See the\ntable\nopposite), $t],
[qq(Or\nthis\none), $t],
];
my $T = formatTable
($D,
[qw(Description Table)],
head=>q(Table of Tables.),
rows=>q(NNNN rows containing a table.),
);
ok $T eq <<END;
Table of Tables.
2 rows containing a table.
Description Table
1 See the A BB CCC
table 1 a b c
opposite bb cc
ccc
2 1 1 1
22 22
333
2 Or A BB CCC
this 1 a b c
one bb cc
ccc
2 1 1 1
22 22
333
END
# Print an array of arrays:
my $aa = formatTable
([[qw(A B C )],
[qw(AA BB CC )],
[qw(AAA BBB CCC)],
[qw(1 22 333)]],
[qw (aa bb cc)]);
ok $aa eq <<END;
aa bb cc
1 A B C
2 AA BB CC
3 AAA BBB CCC
4 1 22 333
END
# Print an array of hashes:
my $ah = formatTable
([{aa=> "A", bb => "B", cc => "C" },
{aa=> "AA", bb => "BB", cc => "CC" },
{aa=> "AAA", bb => "BBB", cc => "CCC" },
{aa=> 1, bb => 22, cc => 333 }]);
ok $ah eq <<END;
aa bb cc
1 A B C
2 AA BB CC
3 AAA BBB CCC
4 1 22 333
END
# Print a hash of arrays:
my $ha = formatTable
({"" => ["aa", "bb", "cc"],
"1" => ["A", "B", "C"],
"22" => ["AA", "BB", "CC"],
"333" => ["AAA", "BBB", "CCC"],
"4444" => [1, 22, 333]},
[qw(Key A B C)]
);
ok $ha eq <<END;
Key A B C
aa bb cc
1 A B C
22 AA BB CC
333 AAA BBB CCC
4444 1 22 333
END
# Print a hash of hashes:
my $hh = formatTable
({a => {aa=>"A", bb=>"B", cc=>"C" },
aa => {aa=>"AA", bb=>"BB", cc=>"CC" },
aaa => {aa=>"AAA", bb=>"BBB", cc=>"CCC" },
aaaa => {aa=>1, bb=>22, cc=>333 }});
ok $hh eq <<END;
aa bb cc
a A B C
aa AA BB CC
aaa AAA BBB CCC
aaaa 1 22 333
END
# Print an array of scalars:
my $a = formatTable(["a", "bb", "ccc", 4], [q(#), q(Col)]);
ok $a eq <<END;
# Col
0 a
1 bb
2 ccc
3 4
END
# Print a hash of scalars:
my $h = formatTable({aa=>"AAAA", bb=>"BBBB", cc=>"333"}, [qw(Key Title)]);
ok $h eq <<END;
Key Title
aa AAAA
bb BBBB
cc 333
END
Description
Write data in tabular text format.
The following sections describe the methods in each functional area of this module. For an alphabetic listing of all methods by name see Index.
Time stamps
Date and timestamps as used in logs of long running commands.
dateTimeStamp()
Year-monthNumber-day at hours:minute:seconds
Example:
ok dateTimeStamp =~ m(\A\d{4}-\d\d-\d\d at \d\d:\d\d:\d\d\Z);
dateStamp()
Year-monthName-day
Example:
ok dateStamp =~ m(\A\d{4}-\w{3}-\d\d\Z);
versionCode()
YYYYmmdd-HHMMSS
Example:
ok versionCode =~ m(\A\d{8}-\d{6}\Z);
versionCodeDashed()
YYYY-mm-dd-HH:MM:SS
Example:
ok versionCodeDashed =~ m(\A\d{4}-\d\d-\d\d-\d\d:\d\d:\d\d\Z);
timeStamp()
hours:minute:seconds
Example:
ok timeStamp =~ m(\A\d\d:\d\d:\d\d\Z);
microSecondsSinceEpoch()
Micro seconds since unix epoch.
Example:
ok microSecondsSinceEpoch > 47*365*24*60*60*1e6;
Command execution
Various ways of processing commands.
xxx(@)
Execute a shell command. The command to execute is specified as one or more strings which are joined together after removing any new lines. Optionally the last string can be a regular expression that is used to test the output generated by the execution the command: if the regular expression fails the command output is printed, else it is suppressed as being uninteresting.
Parameter Description
1 @cmd Command to execute followed by an optional regular expression to test the results
Example:
{ok xxx("echo aaa") =~ /aaa/;
yyy($)
Execute a block of shell commands line by line after removing comments - stop if there is a non zero return code from any command.
Parameter Description
1 $cmd Commands to execute separated by new lines
Example:
ok !yyy <<END;
echo aaa
echo bbb
END
zzz($$$$)
Execute lines of commands after replacing new lines with && then check that the pipeline execution results in a return code of zero and that the execution results match the optional regular expression if one has been supplied; confess() to an error if either check fails.
Parameter Description
1 $cmd Commands to execute - one per line with no trailing &&
2 $success Optional regular expression to check for acceptable results
3 $returnCode Optional regular expression to check the acceptable return codes
4 $message Message of explanation if any of the checks fail
Example:
ok zzz(<<END, qr(aaa\s*bbb)s);
echo aaa
echo bbb
END
parseCommandLineArguments(&$$)
Classify the specified array of words into positional parameters and keyword parameters, then call the specified sub with a reference to an array of positional parameters followed by a reference to a hash of keywords and their values and return the value returned by this sub.
Parameter Description
1 $sub Sub to call
2 $args List of arguments to parse
3 $valid Optional list of valid parameters else all parameters will be accepted
Example:
my $r = parseCommandLineArguments {[@_]}
[qw( aaa bbb -c --dd --eee=EEEE -f=F), q(--gg=g g), q(--hh=h h)];
is_deeply $r,
[["aaa", "bbb"],
{c=>undef, dd=>undef, eee=>"EEEE", f=>"F", gg=>"g g", hh=>"h h"},
];
call(&@)
Call the specified sub in a separate process, wait for it to complete, copy back the named our variables, free the memory used.
Parameter Description
1 $sub Sub to call
2 @our Our variable names with preceding sigils to copy back
Example:
ˢ{our $a = q(1);
our @a = qw(1);
our %a = (a=>1);
our $b = q(1);
for(2..4) {
call {$a = $_ x 1000; $a[0] = $_; $a{a} = $_; $b = 2;} qw($a @a %a);
ok $a == $_ x 1000;
ok $a[0] == $_;
ok $a{a} == $_;
ok $b == 1;
}
};
Files and paths
Operations on files and paths.
Statistics
Information about each file.
fileSize($)
Get the size of a file.
Parameter Description
1 $file File name
Example:
my $f = writeFile("zzz.data", "aaa");
ok fileSize($f) == 3;
fileModTime($)
Get the modified time of a file in seconds since the epoch.
Parameter Description
1 $file File name
Example:
ok fileModTime($0) =~ m(\A\d+\Z)s;
fileOutOfDate(&$@)
Calls the specified sub once for each source file that is missing, then calls the sub for the target if there were any missing files or if the target is older than any of the non missing source files or if the target does not exist. The file name is passed to the sub each time in $_. Returns the files to be remade in the order they should be made.
Parameter Description
1 $make Make with this sub
2 $target Target file
3 @source Source files
Example:
if (0) {
my @Files = qw(a b c);
my @files = (@Files, qw(d));
writeFile($_, $_), sleep 1 for @Files;
my $a = '';
my @a = fileOutOfDate {$a .= $_} q(a), @files;
ok $a eq 'da';
is_deeply [@a], [qw(d a)];
my $b = '';
my @b = fileOutOfDate {$b .= $_} q(b), @files;
ok $b eq 'db';
is_deeply [@b], [qw(d b)];
my $c = '';
my @c = fileOutOfDate {$c .= $_} q(c), @files;
ok $c eq 'dc';
is_deeply [@c], [qw(d c)];
my $d = '';
my @d = fileOutOfDate {$d .= $_} q(d), @files;
ok $d eq 'd';
is_deeply [@d], [qw(d)];
my @A = fileOutOfDate {} q(a), @Files;
my @B = fileOutOfDate {} q(b), @Files;
my @C = fileOutOfDate {} q(c), @Files;
is_deeply [@A], [qw(a)];
is_deeply [@B], [qw(b)];
is_deeply [@C], [];
unlink for @Files;
}
firstFileThatExists(@)
Returns the name of the first file that exists or undef if none of the named files exist.
Parameter Description
1 @files Files to check
Example:
my $d = temporaryFolder;
ok $d eq firstFileThatExists("$d/$d", $d);
Components
Create file names from file name components.
filePath(@)
Create a file name from an array of file name components. If all the components are blank then a blank file name is returned. Identical to fpf.
Parameter Description
1 @file File name components
Example:
if (1)
{ok filePath (qw(/aaa bbb ccc ddd.eee)) eq "/aaa/bbb/ccc/ddd.eee";
ok filePathDir(qw(/aaa bbb ccc ddd)) eq "/aaa/bbb/ccc/ddd/";
ok filePathDir('', qw(aaa)) eq "aaa/";
ok filePathDir('') eq "";
ok filePathExt(qw(aaa xxx)) eq "aaa.xxx";
ok filePathExt(qw(aaa bbb xxx)) eq "aaa/bbb.xxx";
ok fpd (qw(/aaa bbb ccc ddd)) eq "/aaa/bbb/ccc/ddd/";
ok fpf (qw(/aaa bbb ccc ddd.eee)) eq "/aaa/bbb/ccc/ddd.eee";
ok fpe (qw(aaa bbb xxx)) eq "aaa/bbb.xxx";
}
fpf is a synonym for filePath.
filePathDir(@)
Create a directory name from an array of file name components. If all the components are blank then a blank file name is returned. Identical to fpd.
Parameter Description
1 @file Directory name components
Example:
if (1)
{ok filePath (qw(/aaa bbb ccc ddd.eee)) eq "/aaa/bbb/ccc/ddd.eee";
ok filePathDir(qw(/aaa bbb ccc ddd)) eq "/aaa/bbb/ccc/ddd/";
ok filePathDir('', qw(aaa)) eq "aaa/";
ok filePathDir('') eq "";
ok filePathExt(qw(aaa xxx)) eq "aaa.xxx";
ok filePathExt(qw(aaa bbb xxx)) eq "aaa/bbb.xxx";
ok fpd (qw(/aaa bbb ccc ddd)) eq "/aaa/bbb/ccc/ddd/";
ok fpf (qw(/aaa bbb ccc ddd.eee)) eq "/aaa/bbb/ccc/ddd.eee";
ok fpe (qw(aaa bbb xxx)) eq "aaa/bbb.xxx";
}
fpd is a synonym for filePathDir.
filePathExt(@)
Create a file name from an array of file name components the last of which is an extension. Identical to fpe.
Parameter Description
1 @File File name components and extension
Example:
if (1)
{ok filePath (qw(/aaa bbb ccc ddd.eee)) eq "/aaa/bbb/ccc/ddd.eee";
ok filePathDir(qw(/aaa bbb ccc ddd)) eq "/aaa/bbb/ccc/ddd/";
ok filePathDir('', qw(aaa)) eq "aaa/";
ok filePathDir('') eq "";
ok filePathExt(qw(aaa xxx)) eq "aaa.xxx";
ok filePathExt(qw(aaa bbb xxx)) eq "aaa/bbb.xxx";
ok fpd (qw(/aaa bbb ccc ddd)) eq "/aaa/bbb/ccc/ddd/";
ok fpf (qw(/aaa bbb ccc ddd.eee)) eq "/aaa/bbb/ccc/ddd.eee";
ok fpe (qw(aaa bbb xxx)) eq "aaa/bbb.xxx";
}
fpe is a synonym for filePathExt.
fp($)
Get path from file name.
Parameter Description
1 $file File name
Example:
ok fp (q(a/b/c.d.e)) eq q(a/b/);
fpn($)
Remove extension from file name.
Parameter Description
1 $file File name
Example:
ok fpn(q(a/b/c.d.e)) eq q(a/b/c.d);
fn($)
Remove path and extension from file name.
Parameter Description
1 $file File name
Example:
ok fn (q(a/b/c.d.e)) eq q(c.d);
fne($)
Remove path from file name.
Parameter Description
1 $file File name
Example:
ok fne(q(a/b/c.d.e)) eq q(c.d.e);
fe($)
Get extension of file name.
Parameter Description
1 $file File name
Example:
ok fe (q(a/b/c.d.e)) eq q(e);
checkFile($)
Return the name of the specified file if it exists, else confess the maximum extent of the path that does exist.
Parameter Description
1 $file File to check
Example:
{my $d = filePath (my @d = qw(a b c d));
my $f = filePathExt(qw(a b c d e x));
my $F = filePathExt(qw(a b c e d));
createEmptyFile($f);
ok checkFile($d);
ok checkFile($f);
quoteFile($)
Quote a file name.
Parameter Description
1 $file File name
Example:
ok quoteFile(fpe(qw(a b c))) eq q("a/b.c");
removeFilePrefix($@)
Removes a file prefix from an array of files.
Parameter Description
1 $prefix File prefix
2 @files Array of file names
Example:
is_deeply [qw(a b)], [&removeFilePrefix(qw(a/ a/a a/b))];
is_deeply [qw(b)], [&removeFilePrefix("a/", "a/b")];
titleToUniqueFileName($$$$)
Create a file name from a title that is unique within the set %uniqueNames.
Parameter Description
1 $uniqueFileNames Unique file names hash {} which will be updated by this method
2 $title Title
3 $suffix File name suffix
4 $ext File extension
Example:
ˢ{my $f = {};
ok q(a_p.txt) eq &titleToUniqueFileName($f, qw(a p txt));
ok q(a_p_2.txt) eq &titleToUniqueFileName($f, qw(a p txt));
ok q(a_p_3.txt) eq &titleToUniqueFileName($f, qw(a p txt));
ok q(a_q.txt) eq &titleToUniqueFileName($f, qw(a q txt));
ok q(a_q_5.txt) eq &titleToUniqueFileName($f, qw(a q txt));
ok q(a_q_6.txt) eq &titleToUniqueFileName($f, qw(a q txt));
};
ok q(a_p.txt) eq &titleToUniqueFileName($f, qw(a p txt));
ok q(a_p_2.txt) eq &titleToUniqueFileName($f, qw(a p txt));
ok q(a_p_3.txt) eq &titleToUniqueFileName($f, qw(a p txt));
ok q(a_q.txt) eq &titleToUniqueFileName($f, qw(a q txt));
ok q(a_q_5.txt) eq &titleToUniqueFileName($f, qw(a q txt));
ok q(a_q_6.txt) eq &titleToUniqueFileName($f, qw(a q txt));
Position
Position in the file system.
currentDirectory()
Get the current working directory.
Example:
currentDirectory;
currentDirectoryAbove()
The path to the folder above the current working folder.
Example:
currentDirectoryAbove;
parseFileName($)
Parse a file name into (path, name, extension).
Parameter Description
1 $file File name to parse
Example:
is_deeply [parseFileName "a.b/c.d.e"], [qw(a.b/ c.d e)];
fullFileName()
Full name of a file.
Example:
fullFileName(fpe(qw(a txt)));
absFromAbsPlusRel($$)
Create an absolute file from an absolute file and a relative file.
Parameter Description
1 $a Absolute file name
2 $f Relative file name
Example:
ok "/home/la/perl/aaa.pl" eq absFromAbsPlusRel("/home/la/perl/bbb", "aaa.pl");
ok "/home/la/perl/aaa.pl" eq absFromAbsPlusRel("/home/il/perl/bbb.pl", "../../la/perl/aaa.pl");
relFromAbsAgainstAbs($$)
Derive a relative file name for the first absolute file name relative to the second absolute file name.
Parameter Description
1 $f Absolute file to be made relative
2 $a Absolute file name to make relative to.
Example:
ok "bbb.pl" eq relFromAbsAgainstAbs("/home/la/perl/bbb.pl", "/home/la/perl/aaa.pl");
ok "../perl/bbb.pl" eq relFromAbsAgainstAbs("/home/la/perl/bbb.pl", "/home/la/java/aaa.jv");
Temporary
Temporary files and folders
temporaryFile()
Create a temporary file that will automatically be unlinked during END processing.
Example:
{my $f = temporaryFile;
temporaryFolder()
Create a temporary folder that will automatically be rmdired during END processing.
Example:
my $D = temporaryFolder;
temporaryDirectory is a synonym for temporaryFolder.
Find
Find files and folders below a folder.
findFiles($$)
Find all the files under a folder and optionally filter the selected files with a regular expression.
Parameter Description
1 $dir Folder to start the search with
2 $filter Optional regular expression to filter files
Example:
my $D = temporaryFolder;
my $d = fpd($D, q(ddd));
my @f = map {createEmptyFile(fpe($d, $_, qw(txt)))} qw(a b c);
is_deeply [sort map {fne $_} findFiles($d, qr(txt\Z))], [qw(a.txt b.txt c.txt)];
findDirs($$)
Find all the folders under a folder and optionally filter the selected folders with a regular expression.
Parameter Description
1 $dir Folder to start the search with
2 $filter Optional regular expression to filter files
Example:
my $D = temporaryFolder;
my $d = fpd($D, q(ddd));
my @f = map {createEmptyFile(fpe($d, $_, qw(txt)))} qw(a b c);
is_deeply [findDirs($D)], [$D, $d];
fileList($)
Files that match a given search pattern handed to bsd_glob.
Parameter Description
1 $pattern Search pattern
Example:
my $D = temporaryFolder;
my $d = fpd($D, q(ddd));
my @f = map {createEmptyFile(fpe($d, $_, qw(txt)))} qw(a b c);
is_deeply [sort map {fne $_} fileList("$d/*.txt")],
["a.txt", "b.txt", "c.txt"];
searchDirectoryTreesForMatchingFiles(@)
Search the specified directory trees for the files (not folders) that match the specified extensions. The argument list should include at least one path name to be useful. If no file extension is supplied then all the files below the specified paths are returned.
Parameter Description
1 @foldersandExtensions Mixture of folder names and extensions
Example:
my $D = temporaryFolder;
my $d = fpd($D, q(ddd));
my @f = map {createEmptyFile(fpe($d, $_, qw(txt)))} qw(a b c);
is_deeply [sort map {fne $_} searchDirectoryTreesForMatchingFiles($d)],
["a.txt", "b.txt", "c.txt"];
matchPath($)
Given an absolute path find out how much of the path actually exists.
Parameter Description
1 $file File name
Example:
{my $d = filePath (my @d = qw(a b c d));
ok matchPath($d) eq $d;
findFileWithExtension($@)
Find the first extension from the specified extensions that produces a file that exists when appended to the specified file.
Parameter Description
1 $file File name minus extensions
2 @ext Possible extensions
Example:
my $f = createEmptyFile(fpe(my $d = temporaryFolder, qw(a jpg)));
my $F = findFileWithExtension(fpf($d, q(a)), qw(txt data jpg));
ok $F eq "jpg";
clearFolder($$)
Remove all the files and folders under and including the specified folder as long as the number of files to be removed is less than the specified limit.
Parameter Description
1 $folder Folder
2 $limitCount Maximum number of files to remove to limit damage
Example:
my $D = temporaryFolder;
my $d = fpd($D, q(ddd));
my @f = map {createEmptyFile(fpe($d, $_, qw(txt)))} qw(a b c);
clearFolder($D, 5);
ok !-e $_ for @f;
ok !-d $D;
Read and write files
Read and write strings from and to files creating paths as needed.
readFile($)
Read a file containing unicode.
Parameter Description
1 $file Name of unicode file to read
Example:
{my $f = writeFile(undef, "aaa");
my $s = readFile($f);
ok $s eq "aaa";
appendFile($f, "bbb");
my $S = readFile($f);
ok $S eq "aaabbb";
evalFile($)
Read a file containing unicode, evaluate it, confess to any errors and then return any result - an improvement on do which silently ignores any problems.
Parameter Description
1 $file File to read
Example:
if (1)
{my $f = writeFile(undef, q([qw(aaa bbb ccc)]));
my $s = evalFile($f);
is_deeply $s, [qw(aaa bbb ccc)];
writeFile($f, q({qw(aaa bbb ccc)]));
$s = eval q{ evalFile($f) };
ok $@ =~ m(\Asyntax error);
unlink $f;
}
evalGZipFile($)
Read a file containing compressed utf-8, evaluate it, confess to any errors and then return any result.
Parameter Description
1 $file File to read
Example:
if (!$windows) {
dumpGZipFile($$)
Write a data structure through gzip to a file.
Parameter Description
1 $file File to write
2 $data Reference to data
Example:
if (!$windows) {
readBinaryFile($)
Read binary file - a file whose contents are not to be interpreted as unicode.
Parameter Description
1 $file File to read
Example:
my $f = writeBinaryFile(undef, 0xff x 8);
my $s = readBinaryFile($f);
ok $s eq 0xff x 8;
readGZipFile($)
Read the specified $file, containing compressed utf-8, through gzip
Parameter Description
1 $file File to read.
Example:
if (!$windows) {
makePath($)
Make the path for the specified file name or folder.
Parameter Description
1 $file File
Example:
{my $d = fpd(my $D = temporaryDirectory, qw(a));
my $f = fpe($d, qw(bbb txt));
ok !-d $d;
makePath($f);
ok -d $d;
writeFile($$)
Write a unicode string to a file after creating a path to the file if necessary and return the name of the file on success else confess.
Parameter Description
1 $file File to write to or B<undef> for a temporary file
2 $string Unicode string to write
Example:
{my $f = writeFile(undef, "aaa");
my $s = readFile($f);
ok $s eq "aaa";
appendFile($f, "bbb");
my $S = readFile($f);
ok $S eq "aaabbb";
writeGZipFile($$)
Write a unicode string through gzip to a file.
Parameter Description
1 $file File to write to
2 $string String
Example:
if (!$windows) {
writeFiles($$)
Write the values of a hash as a file identified by the key of the value
Parameter Description
1 $hash Hash of key value pairs representing files and data
2 $folder Optional folder to contain files else the current folder
Example:
{my $h =
{"aaa/1.txt"=>"1111",
"aaa/2.txt"=>"2222",
};
writeFiles($h);
for(sort keys %$h)
{ok -e $_;
ok readFile($_) eq $h->{$_};
appendFile($$)
Append a unicode string to a file, possibly creating the file and the path to the file if necessary and return the name of the file on success else confess.
Parameter Description
1 $file File to append to
2 $string Unicode string to append
Example:
{my $f = writeFile(undef, "aaa");
my $s = readFile($f);
ok $s eq "aaa";
appendFile($f, "bbb");
my $S = readFile($f);
ok $S eq "aaabbb";
writeBinaryFile($$)
Write a non unicode string to a file in after creating a path to the file if necessary and return the name of the file on success else confess.
Parameter Description
1 $file File to write to or B<undef> for a temporary file
2 $string Non unicode string to write
Example:
my $f = writeBinaryFile(undef, 0xff x 8);
my $s = readBinaryFile($f);
ok $s eq 0xff x 8;
createEmptyFile($)
Create an empty file - writeFile complains if no data is written to the file - and return the name of the file on success else confess.
Parameter Description
1 $file File to create or B<undef> for a temporary file
Example:
my $D = temporaryFolder;
my $d = fpd($D, q(ddd));
my @f = map {createEmptyFile(fpe($d, $_, qw(txt)))} qw(a b c);
is_deeply [sort map {fne $_} findFiles($d, qr(txt\Z))], [qw(a.txt b.txt c.txt)];
numberOfLinesInFile($)
The number of lines in a file
Parameter Description
1 $file File
Example:
{my $f = writeFile(undef, "a
b
");
ok numberOfLinesInFile($f) == 2;
Images
Image operations.
imageSize($)
Return (width, height) of an image obtained via Imagemagick.
Parameter Description
1 $image File containing image
Example:
my ($width, $height) = imageSize(fpe(qw(a image jpg)));
convertImageToJpx($$$)
Convert an image to jpx format using Imagemagick.
Parameter Description
1 $source Source file
2 $target Target folder (as multiple files will be created)
3 $Size Optional size of each tile - defaults to 256
Example:
convertImageToJpx(fpe(qw(a image jpg)), fpe(qw(a image jpg)), 256);
convertDocxToFodt($$)
Convert a docx file to fodt using unoconv which must not be running elsewhere at the time. Unoconv can be installed via:
sudo apt install sharutils unoconv
Parameters:
Parameter Description
1 $inputFile Input file
2 $outputFile Output file
Example:
convertDocxToFodt(fpe(qw(a docx)), fpe(qw(a fodt)));
cutOutImagesInFodtFile($$$)
Cut out the images embedded in a fodt file, perhaps produced via convertDocxToFodt, placing them in the specified folder and replacing them in the source file with:
<image href="$imageFile" outputclass="imageType">
This conversion requires that you have both Imagemagick and unoconv installed on your system:
sudo apt install sharutils imagemagick unoconv
Parameters:
Parameter Description
1 $inputFile Input file
2 $outputFolder Output folder for images
3 $imagePrefix A prefix to be added to image file names
Example:
cutOutImagesInFodtFile(fpe(qw(source fodt)), fpd(qw(images)), q(image));
Encoding and Decoding
Encode and decode using Json and Mime.
encodeJson($)
Encode Perl to Json.
Parameter Description
1 $string Data to encode
Example:
my $A = encodeJson(my $a = {a=>1,b=>2, c=>[1..2]});
my $b = decodeJson($A);
is_deeply $a, $b;
decodeJson($)
Decode Perl from Json.
Parameter Description
1 $string Data to decode
Example:
my $A = encodeJson(my $a = {a=>1,b=>2, c=>[1..2]});
my $b = decodeJson($A);
is_deeply $a, $b;
encodeBase64($)
Encode a string in base 64.
Parameter Description
1 $string String to encode
Example:
my $A = encodeBase64(my $a = "Hello World" x 10);
my $b = decodeBase64($A);
ok $a eq $b;
decodeBase64($)
Decode a string in base 64.
Parameter Description
1 $string String to decode
Example:
my $A = encodeBase64(my $a = "Hello World" x 10);
my $b = decodeBase64($A);
ok $a eq $b;
convertUnicodeToXml($)
Convert a string with unicode points that are not directly representable in ascii into string that replaces these points with their representation on Xml making the string usable in Xml documents.
Parameter Description
1 $s String to convert
Example:
ok convertUnicodeToXml('setenta e três') eq q(setenta e três);
Numbers
Numeric operations,
powerOfTwo($)
Test whether a number is a power of two, return the power if it is else undef.
Parameter Description
1 $n Number to check
Example:
ok powerOfTwo(1) == 0;
ok powerOfTwo(2) == 1;
ok !powerOfTwo(3);
ok powerOfTwo(4) == 2;
containingPowerOfTwo($)
Find log two of the lowest power of two greater than or equal to a number.
Parameter Description
1 $n Number to check
Example:
ok containingPowerOfTwo(1) == 0;
ok containingPowerOfTwo(2) == 1;
ok containingPowerOfTwo(3) == 2;
ok containingPowerOfTwo(4) == 2;
Sets
Set operations.
setIntersectionOfTwoArraysOfWords($$)
Intersection of two arrays of words.
Parameter Description
1 $a Reference to first array of words
2 $b Reference to second array of words
Example:
is_deeply [qw(a b c)],
[setIntersectionOfTwoArraysOfWords([qw(e f g a b c )], [qw(a A b B c C)])];
setUnionOfTwoArraysOfWords($$)
Union of two arrays of words.
Parameter Description
1 $a Reference to first array of words
2 $b Reference to second array of words
Example:
is_deeply [qw(a b c)],
[setUnionOfTwoArraysOfWords([qw(a b c )], [qw(a b)])];
contains($@)
Returns the indices at which an item matches elements of the specified array. If the item is a regular expression then it is matched as one, else it is a number it is matched as a number, else as a string.
Parameter Description
1 $item Item
2 @array Array
Example:
is_deeply [1], [contains(1,0..1)];
is_deeply [1,3], [contains(1, qw(0 1 0 1 0 0))];
is_deeply [0, 5], [contains('a', qw(a b c d e a b c d e))];
is_deeply [0, 1, 5], [contains(qr(a+), qw(a baa c d e aa b c d e))];
Minima and Maxima
Find the smallest and largest elements of arrays.
min(@)
Find the minimum number in a list.
Parameter Description
1 @n Numbers
Example:
ok min(1) == 1;
ok min(5,4,2,3) == 2;
max(@)
Find the maximum number in a list.
Parameter Description
1 @n Numbers
Example:
ok !max;
ok max(1) == 1;
ok max(1,4,2,3) == 4;
Format
Format data structures as tables.
maximumLineLength($)
Find the longest line in a string
Parameter Description
1 $string String of lines of text
Example:
ok 3 == maximumLineLength(<<END);
a
bb
ccc
END
formatTableBasic($)
Tabularize an array of arrays of text.
Parameter Description
1 $data Reference to an array of arrays of data to be formatted as a table.
Example:
my $d = [[qw(a 1)], [qw(bb 22)], [qw(ccc 333)], [qw(dddd 4444)]];
ok formatTableBasic($d) eq <<END;
a 1
bb 22
ccc 333
dddd 4444
END
formatTable($$%)
Format various data structures as a table. Optionally create a report from the table using the following optional report options:
file=>$file the name of a file to write the report to.
head=>$head a header line in which DDDD will be replaced with the data and time.
rows=>$rows a header line in which NNNN will be replaced with the number of rows in the table.
Parameters:
Parameter Description
1 $data Data to be formatted
2 $title Optional reference to an array of titles
3 %options Options
Example:
ok formatTable
([[qw(A B C D )],
[qw(AA BB CC DD )],
[qw(AAA BBB CCC DDD )],
[qw(AAAA BBBB CCCC DDDD)],
[qw(1 22 333 4444)]], [qw(aa bb cc)]) eq <<END;
aa bb cc
1 A B C D
2 AA BB CC DD
3 AAA BBB CCC DDD
4 AAAA BBBB CCCC DDDD
5 1 22 333 4444
END
ok formatTable
([[qw(1 B C)],
[qw(22 BB CC)],
[qw(333 BBB CCC)],
[qw(4444 22 333)]], [qw(aa bb cc)]) eq <<END;
aa bb cc
1 1 B C
2 22 BB CC
3 333 BBB CCC
4 4444 22 333
END
ok formatTable
([{aa=>'A', bb=>'B', cc=>'C'},
{aa=>'AA', bb=>'BB', cc=>'CC'},
{aa=>'AAA', bb=>'BBB', cc=>'CCC'},
{aa=>'1', bb=>'22', cc=>'333'}
]) eq <<END;
aa bb cc
1 A B C
2 AA BB CC
3 AAA BBB CCC
4 1 22 333
END
ok formatTable
({''=>[qw(aa bb cc)],
1=>[qw(A B C)],
22=>[qw(AA BB CC)],
333=>[qw(AAA BBB CCC)],
4444=>[qw(1 22 333)]}) eq <<END;
aa bb cc
1 A B C
22 AA BB CC
333 AAA BBB CCC
4444 1 22 333
END
ok formatTable
({1=>{aa=>'A', bb=>'B', cc=>'C'},
22=>{aa=>'AA', bb=>'BB', cc=>'CC'},
333=>{aa=>'AAA', bb=>'BBB', cc=>'CCC'},
4444=>{aa=>'1', bb=>'22', cc=>'333'}}) eq <<END;
aa bb cc
1 A B C
22 AA BB CC
333 AAA BBB CCC
4444 1 22 333
END
ok formatTable({aa=>'A', bb=>'B', cc=>'C'}, [qw(aaaa bbbb)]) eq <<END;
aaaa bbbb
aa A
bb B
cc C
END
if (1) {
my $file = fpe(qw(report txt)); # Create a report
my $t = formatTable
([["a",undef], [undef, "b0ac"]], # Data - please replace 0a with a new line
[undef, "BC"], # Column titles
file=>$file, # Output file
head=>qq(Sample report.), # Header
rows=>qq(NNNN rows.)); # Row count
ok -e $file;
ok readFile($file) eq $t;
unlink $file;
ok $t eq <<END;
Sample report.
2 rows.
This file: report.txt
BC
1 a
2 b
c
END
}
keyCount($$)
Count keys down to the specified level.
Parameter Description
1 $maxDepth Maximum depth to count to
2 $ref Reference to an array or a hash
Example:
{my $a = [[1..3], {map{$_=>1} 1..3}];
my $h = {a=>[1..3], b=>{map{$_=>1} 1..3}};
ok keyCount(2, $a) == 6;
ok keyCount(2, $h) == 6;
Lines
Load data structures from lines.
loadArrayFromLines($)
Load an array from lines of text in a string.
Parameter Description
1 $string The string of lines from which to create an array
Example:
my $s = loadArrayFromLines <<END;
a a
b b
END
is_deeply $s, [q(a a), q(b b)];
ok formatTable($s) eq <<END;
0 a a
1 b b
END
loadHashFromLines($)
Load a hash: first word of each line is the key and the rest is the value.
Parameter Description
1 $string The string of lines from which to create a hash
Example:
my $s = loadHashFromLines <<END;
a 10 11 12
b 20 21 22
END
is_deeply $s, {a => q(10 11 12), b =>q(20 21 22)};
ok formatTable($s) eq <<END;
a 10 11 12
b 20 21 22
END
loadArrayArrayFromLines($)
Load an array of arrays from lines of text: each line is an array of words.
Parameter Description
1 $string The string of lines from which to create an array of arrays
Example:
my $s = loadArrayArrayFromLines <<END;
A B C
AA BB CC
END
is_deeply $s, [[qw(A B C)], [qw(AA BB CC)]];
ok formatTable($s) eq <<END;
1 A B C
2 AA BB CC
END
loadHashArrayFromLines($)
Load a hash of arrays from lines of text: the first word of each line is the key, the remaining words are the array contents.
Parameter Description
1 $string The string of lines from which to create a hash of arrays
Example:
my $s = loadHashArrayFromLines <<END;
a A B C
b AA BB CC
END
is_deeply $s, {a =>[qw(A B C)], b => [qw(AA BB CC)] };
ok formatTable($s) eq <<END;
a A B C
b AA BB CC
END
loadArrayHashFromLines($)
Load an array of hashes from lines of text: each line is an hash of words.
Parameter Description
1 $string The string of lines from which to create an array of arrays
Example:
my $s = loadArrayHashFromLines <<END;
A 1 B 2
AA 11 BB 22
END
is_deeply $s, [{A=>1, B=>2}, {AA=>11, BB=>22}];
ok formatTable($s) eq <<END;
A AA B BB
1 1 2
2 11 22
END
loadHashHashFromLines($)
Load a hash of hashes from lines of text: the first word of each line is the key, the remaining words are the sub hash contents.
Parameter Description
1 $string The string of lines from which to create a hash of arrays
Example:
my $s = loadHashHashFromLines <<END;
a A 1 B 2
b AA 11 BB 22
END
is_deeply $s, {a=>{A=>1, B=>2}, b=>{AA=>11, BB=>22}};
ok formatTable($s) eq <<END;
A AA B BB
a 1 2
b 11 22
END
checkKeys($$)
Check the keys in a hash.
Parameter Description
1 $test The hash to test
2 $permitted A hash of the permitted keys and their meanings
Example:
eval q{checkKeys({a=>1, b=>2, d=>3}, {a=>1, b=>2, c=>3})};
ok nws($@) =~ m(\AInvalid options chosen: d Permitted.+?: a 1 b 2 c 3);
LVALUE methods
Replace $a->{value} = $b with $a->value = $b which reduces the amount of typing required, is easier to read and provides a hard check that {value} is spelled correctly.
genLValueScalarMethods(@)
Generate lvalue scalar methods in the current package, A method whose value has not yet been set will return a new scalar with value undef. Suffixing X to the scalar name will confess if a value has not been set.
Parameter Description
1 @names List of method names
Example:
package Scalars;
my $a = bless{};
Data::Table::Text::genLValueScalarMethods(qw(aa bb cc));
$a->aa = 'aa';
Test::More::ok $a->aa eq 'aa';
Test::More::ok !$a->bb;
Test::More::ok $a->bbX eq q();
$a->aa = undef;
Test::More::ok !$a->aa;
addLValueScalarMethods(@)
Generate lvalue scalar methods in the current package if they do not already exist. A method whose value has not yet been set will return a new scalar with value undef. Suffixing X to the scalar name will confess if a value has not been set.
Parameter Description
1 @names List of method names
Example:
my $class = "Data::Table::Text::Test";
my $a = bless{}, $class;
addLValueScalarMethods(qq(${class}::$_)) for qw(aa bb aa bb);
$a->aa = 'aa';
ok $a->aa eq 'aa';
ok !$a->bb;
ok $a->bbX eq q();
$a->aa = undef;
ok !$a->aa;
genLValueScalarMethodsWithDefaultValues(@)
Generate lvalue scalar methods with default values in the current package. A reference to a method whose value has not yet been set will return a scalar whose value is the name of the method.
Parameter Description
1 @names List of method names
Example:
package ScalarsWithDefaults;
my $a = bless{};
Data::Table::Text::genLValueScalarMethodsWithDefaultValues(qw(aa bb cc));
Test::More::ok $a->aa eq 'aa';
genLValueArrayMethods(@)
Generate lvalue array methods in the current package. A reference to a method that has no yet been set will return a reference to an empty array.
Parameter Description
1 @names List of method names
Example:
package Arrays;
my $a = bless{};
Data::Table::Text::genLValueArrayMethods(qw(aa bb cc));
$a->aa->[1] = 'aa';
Test::More::ok $a->aa->[1] eq 'aa';
genLValueHashMethods(@)
Generate lvalue hash methods in the current package. A reference to a method that has no yet been set will return a reference to an empty hash.
Parameter Description
1 @names Method names
Example:
package Hashes;
my $a = bless{};
Data::Table::Text::genLValueHashMethods(qw(aa bb cc));
$a->aa->{a} = 'aa';
Test::More::ok $a->aa->{a} eq 'aa';
assertRef(@)
Confirm that the specified references are to the package into which this routine has been exported.
Parameter Description
1 @refs References
Example:
eval q{assertRef(my $r = bless {}, q(aaa))};
ok $@ =~ m(\AWanted reference to Data::Table::Text, but got aaa);
ˢ(&)
Immediately executed inline sub to allow a code block before if.
Parameter Description
1 $sub Sub enclosed in {} without the word "sub"
Example:
ok ˢ{1} == 1;
ok ˢ{1};
ˢ{my $s =
ˢ{if (1)
{return q(aa) if 1;
q(bb);
}
};
ok $s eq q(aa);
};
Attribute classes
Build classes of attributes
addClass($$)
Copy attributes definitions from the $source class to the $target class.
Parameter Description
1 $targetClass Target class
2 $sourceClass Source class
Example:
if (1)
{my $c = genClass(q(Test::Class1), aa=>q(aa attribute), bb=>q(bb attribute)); # Define first class
ok defined(&Test::Class1::aa);
ok defined(&Test::Class1::bb);
ok !defined(&Test::Class1::cc);
my $d = genClass(q(Test::Class2), cc=>q(cc attribute), bb=>q(bb attribute)); # Define second class
ok !defined(&Test::Class2::aa);
ok defined(&Test::Class2::bb);
ok defined(&Test::Class2::cc);
$c->addClass($d); # Add second class to first class
$c->cc = "cc"; # Set attribute in first class copied from first class
ok defined(&Test::Class1::cc);
ok $c->cc eq q(cc);
ok $c->printClass eq <<END; # Print class attributes available
Attribute Value
1 aa aa attribute
2 bb bb attribute
3 cc cc attribute
END
ok $c->print eq <<END; # Print current values of attributes in an instance of a class
Attribute Value
1 aa
2 bb
3 cc cc
END
}
genClass($%)
Generate a class $class with the specified %Attributes. Each class will also have a new method which creates a new instance of the class with the specified attributes, an addClass method which adds attribute definitions from another class to the specified class, printClass which prints the definition of the class and print which prints the attributes of scalar attributes in an instance of the class.
Parameter Description
1 $class Class name
2 %Attributes Hash of attribute names to attribute descriptions.
Example:
if (1)
{my $c = genClass(q(Test::Class), aa=>q(aa attribute), bb=>q(bb attribute)); # Define a class
my $a = $c->new(aa=>q(aa)); # Create an object in the class
is_deeply $a, bless({
aa => "aa",
class => "Test::Class",
attributes => { aa => "aa attribute", bb => "bb attribute" },
}, "Test::Class");
$a->aa = q(bb); # Modify object
is_deeply $a, bless({
aa => "bb",
class => "Test::Class",
attributes => { aa => "aa attribute", bb => "bb attribute" },
}, "Test::Class");
my $b = $a->new(bb=>q(bb)); # Create an object
is_deeply $b, bless({
bb => "bb",
class => "Test::Class",
attributes => { aa => "aa attribute", bb => "bb attribute" },
}, "Test::Class");
$b->aa = q(aa); # Modify object
is_deeply $b, bless({
aa => "aa",
bb => "bb",
class => "Test::Class",
attributes => { aa => "aa attribute", bb => "bb attribute" },
}, "Test::Class");
}
Strings
Actions on strings.
indentString($$)
Indent lines contained in a string or formatted table by the specified string.
Parameter Description
1 $string The string of lines to indent
2 $indent The indenting string
Example:
my $t = [qw(aa bb cc)];
my $d = [[qw(A B C)], [qw(AA BB CC)], [qw(AAA BBB CCC)], [qw(1 22 333)]];
ok $s eq <<END;
1 A B C
2 AA BB CC
3 AAA BBB CCC
4 1 22 333
END
isBlank($)
Test whether a string is blank.
Parameter Description
1 $string String
Example:
ok isBlank("");
ok isBlank("
");
trim($)
Remove any white space from the front and end of a string.
Parameter Description
1 $string String
Example:
ok trim(" a b ") eq join ' ', qw(a b);
pad($$$)
Pad a string with blanks or the specified padding character to a multiple of a specified length.
Parameter Description
1 $string String
2 $length Tab width
3 $pad Padding char
Example:
ok pad('abc ', 2).'=' eq "abc =";
ok pad('abc ', 3).'=' eq "abc=";
ok pad('abc ', 4, q(.)).'=' eq "abc.=";
nws($)
Normalize white space in a string to make comparisons easier. Leading and trailing white space is removed; blocks of white space in the interior are reduced to a singe space. In effect: this puts everything on one long line with never more than one space at a time.
Parameter Description
1 $string String to normalize
Example:
ok nws(qq(a b c)) eq q(a b c);
boldString($)
Bold a string.
Parameter Description
1 $string String to bold
Example:
ok boldString(q(zZ)) eq q(𝘇𝗭);
javaPackage($)
Extract the package name from a java string or file.
Parameter Description
1 $java Java file if it exists else the string of java
Example:
writeFile($f, <<END);
// Test
package com.xyz;
END
ok javaPackage($f) eq "com.xyz";
javaPackageAsFileName($)
Extract the package name from a java string or file and convert it to a file name.
Parameter Description
1 $java Java file if it exists else the string of java
Example:
writeFile($f, <<END);
// Test
package com.xyz;
END
ok javaPackageAsFileName($f) eq "com/xyz";
perlPackage($)
Extract the package name from a perl string or file.
Parameter Description
1 $perl Perl file if it exists else the string of perl
Example:
writeFile($f, <<END);
package a::b;
END
ok perlPackage($f) eq "a::b";
printQw(@)
Print an array of words in qw() format.
Parameter Description
1 @words Array of words
Example:
ok printQw(qw(a b c)) eq q(qw(a b c));
numberOfLinesInString($)
The number of lines in a string.
Parameter Description
1 $string String
Example:
ok numberOfLinesInString("a
b
") == 2;
Cloud Cover
Useful for operating across the cloud.
saveCodeToS3($$$$)
Save source code files.
Parameter Description
1 $saveCodeEvery Save every seconds
2 $zipFileName Zip file name
3 $bucket Bucket/key
4 $S3Parms Additional S3 parameters like profile or region as a string
Example:
saveCodeToS3(1200, q(projectName), q(bucket/folder), q(--only-show-errors));
addCertificate($)
Add a certificate to the current ssh session.
Parameter Description
1 $file File containing certificate
Example:
addCertificate(fpf(qw(.ssh cert)));
hostName()
The name of the host we are running on.
Example:
hostName;
userId()
The userid we are currently running under.
Example:
userId;
wwwEncode($)
Replace spaces in a string with %20 .
Parameter Description
1 $string String
Example:
ok wwwEncode(q(a b c)) eq q(a%20%20b%20c);
startProcess(&\%$)
Start new processes while the number of child processes recorded in %$pids is less than the specified $maximum. Use waitForAllStartedProcessesToFinish to wait for all these processes to finish.
Parameter Description
1 $sub Sub to start
2 $pids Hash in which to record the process ids
3 $maximum Maximum number of processes to run at a time
Example:
if (0) {
my %pids;
ˢ{startProcess {} %pids, 1; ok 1 >= keys %pids} for 1..8;
waitForAllStartedProcessesToFinish(%pids);
ok !keys(%pids)
}
waitForAllStartedProcessesToFinish(\%)
Wait until all the processes started by startProcess have finished.
Parameter Description
1 $pids Hash of started process ids
Example:
if (0) {
my %pids;
ˢ{startProcess {} %pids, 1; ok 1 >= keys %pids} for 1..8;
waitForAllStartedProcessesToFinish(%pids);
ok !keys(%pids)
}
Documentation
Extract, format and update documentation for a perl module.
htmlToc($@)
Generate a table of contents for some html.
Parameter Description
1 $replace Sub-string within the html to be replaced with the toc
2 $html String of html
Example:
ok nws(htmlToc("XXXX", <<END)), 'htmlToc'
<h1 id="1">Chapter 1</h1>
<h2 id="11">Section 1</h1>
<h1 id="2">Chapter 2</h1>
XXXX
END
eq nws(<<END);
<h1 id="1">Chapter 1</h1>
<h2 id="11">Section 1</h1>
<h1 id="2">Chapter 2</h1>
<table cellspacing=10 border=0>
<tr><td>
<tr><td align=right>1<td> <a href="#1">Chapter 1</a>
<tr><td align=right>2<td> <a href="#11">Section 1</a>
<tr><td>
<tr><td align=right>3<td> <a href="#2">Chapter 2</a>
</table>
END
updateDocumentation($)
Update documentation from the comments in a perl script. Comments between the lines marked with:
#Dn title # description
and:
#D
where n is either 1, 2 or 3 indicating the heading level of the section and the # is in column 1.
Methods are formatted as:
sub name(signature) #FLAGS comment describing method
{my ($parameters) = @_; # comments for each parameter separated by commas.
FLAGS can be chosen from:
- I
-
method of interest to new users
- P
-
private method
- r
-
optionally replaceable method
- R
-
required replaceable method
- S
-
static method
- X
-
die rather than received a returned undef result
Other flags will be handed to the method extractDocumentationFlags(flags to process, method name) found in the file being documented, this method should return [the additional documentation for the method, the code to implement the flag].
Text following 'Example:' in the comment (if present) will be placed after the parameters list as an example. Lines containing comments consisting of '#T'.methodName will also be aggregated and displayed as examples for that method.
Lines formatted as:
BEGIN{*source=*target}
starting in column 1 will define a synonym for a method.
Lines formatted as:
#C emailAddress text
will be aggregated in the acknowledgments section at the end of the documentation.
The character sequence \n in the comment will be expanded to one new line, \m to two new lines and L<$_>,L<confess>,L<die>,L<eval>,L<lvalueMethod> to links to the perl documentation.
Search for '#D1': in https://metacpan.org/source/PRBRENAN/Data-Table-Text-20180810/lib/Data/Table/Text.pm to see more examples of such documentation in action - although it is quite difficult to see as it looks just like normal comments placed in the code.
Parameters:
Parameter Description
1 $perlModule Optional file name with caller's file being the default
Example:
{my $s = updateDocumentation(<<'END' =~ s(#) (#)gsr =~ s(~) ()gsr);
package Sample::Module;
#D1 Samples # Sample methods.
sub sample($@) #R Documentation for the: sample() method. See also L<Data::Table::Text::sample2|/Data::Table::Text::sample2>. #Tsample
{my ($node, @context) = @_; # Node, optional context
1
}
~BEGIN{*smpl=*sample}
sub Data::Table::Text::sample2(\&@) #PS Documentation for the sample2() method.
{my ($sub, @context) = @_; # Sub to call, context.
1
}
ok sample(undef, qw(a b c)) == 1; #Tsample
if (1) #Tsample
{ok sample(q(a), qw(a b c)) == 2;
ok sample(undef, qw(a b c)) == 1;
}
ok sample(<<END2)) == 1; #Tsample
sample data
END2
ok $s =~ m'=head2 sample28\$\@29';
Private Methods
denormalizeFolderName($)
Remove any trailing folder separator from a folder name component.
Parameter Description
1 $name Name
renormalizeFolderName($)
Normalize a folder name component by adding a trailing separator.
Parameter Description
1 $name Name
trackFiles($@)
Track the existence of files.
Parameter Description
1 $label Label
2 @files Files
printFullFileName()
Print a file name on a separate line with escaping so it can be used easily from the command line.
readUtf16File($)
Read a file containing unicode in utf-16 format.
Parameter Description
1 $file Name of file to read
binModeAllUtf8()
Set STDOUT and STDERR to accept utf8 without complaint.
Example:
binModeAllUtf8;
convertImageToJpx690($$$)
Convert an image to jpx format using versions of Imagemagick version 6.9.0 and above.
Parameter Description
1 $source Source file
2 $target Target folder (as multiple files will be created)
3 $Size Optional size of each tile - defaults to 256
formatTableMultiLine($$)
Tabularize text that has new lines in it.
Parameter Description
1 $data Reference to an array of arrays of data to be formatted as a table
2 $separator Optional line separator to use instead of new line for each row.
formatTableAA($$)
Tabularize an array of arrays.
Parameter Description
1 $data Data to be formatted
2 $title Optional reference to an array of titles
formatTableHA($$)
Tabularize a hash of arrays.
Parameter Description
1 $data Data to be formatted
2 $title Optional titles
formatTableAH($)
Tabularize an array of hashes.
Parameter Description
1 $data Data to be formatted
formatTableHH($)
Tabularize a hash of hashes.
Parameter Description
1 $data Data to be formatted
formatTableA($$)
Tabularize an array.
Parameter Description
1 $data Data to be formatted
2 $title Optional title
formatTableH($$)
Tabularize a hash.
Parameter Description
1 $data Data to be formatted
2 $title Optional title
saveSourceToS3($$)
Save source code.
Parameter Description
1 $aws Aws target file and keywords
2 $saveIntervalInSeconds Save internal
extractTest($)
Remove example markers from test code.
Parameter Description
1 $string String containing test line
docUserFlags($$$$)
Generate documentation for a method by calling the extractDocumentationFlags method in the package being documented, passing it the flags for a method and the name of the method. The called method should return the documentation to be inserted for the named method.
Parameter Description
1 $flags Flags
2 $perlModule File containing documentation
3 $package Package containing documentation
4 $name Name of method to be processed
updatePerlModuleDocumentation($)
Update the documentation in a perl file and show said documentation in a web browser.
Parameter Description
1 $perlModule File containing the code of the perl module
Synonyms
fpd is a synonym for filePathDir - Create a directory name from an array of file name components.
fpe is a synonym for filePathExt - Create a file name from an array of file name components the last of which is an extension.
fpf is a synonym for filePath - Create a file name from an array of file name components.
temporaryDirectory is a synonym for temporaryFolder - Create a temporary folder that will automatically be rmdired during END processing.
Index
1 absFromAbsPlusRel - Create an absolute file from an absolute file and a relative file.
2 addCertificate - Add a certificate to the current ssh session.
3 addClass - Copy attributes definitions from the $source class to the $target class.
4 addLValueScalarMethods - Generate lvalue scalar methods in the current package if they do not already exist.
5 appendFile - Append a unicode string to a file, possibly creating the file and the path to the file if necessary and return the name of the file on success else confess.
6 assertRef - Confirm that the specified references are to the package into which this routine has been exported.
7 binModeAllUtf8 - Set STDOUT and STDERR to accept utf8 without complaint.
8 boldString - Bold a string.
9 call - Call the specified sub in a separate process, wait for it to complete, copy back the named our variables, free the memory used.
10 checkFile - Return the name of the specified file if it exists, else confess the maximum extent of the path that does exist.
11 checkKeys - Check the keys in a hash.
12 clearFolder - Remove all the files and folders under and including the specified folder as long as the number of files to be removed is less than the specified limit.
13 containingPowerOfTwo - Find log two of the lowest power of two greater than or equal to a number.
14 contains - Returns the indices at which an item matches elements of the specified array.
15 convertDocxToFodt - Convert a docx file to fodt using unoconv which must not be running elsewhere at the time.
16 convertImageToJpx - Convert an image to jpx format using Imagemagick.
17 convertImageToJpx690 - Convert an image to jpx format using versions of Imagemagick version 6.
18 convertUnicodeToXml - Convert a string with unicode points that are not directly representable in ascii into string that replaces these points with their representation on Xml making the string usable in Xml documents.
19 createEmptyFile - Create an empty file - writeFile complains if no data is written to the file - and return the name of the file on success else confess.
20 currentDirectory - Get the current working directory.
21 currentDirectoryAbove - The path to the folder above the current working folder.
22 cutOutImagesInFodtFile - Cut out the images embedded in a fodt file, perhaps produced via convertDocxToFodt, placing them in the specified folder and replacing them in the source file with:
<image href="$imageFile" outputclass="imageType">
This conversion requires that you have both Imagemagick and unoconv
23 dateStamp - Year-monthName-day
24 dateTimeStamp - Year-monthNumber-day at hours:minute:seconds
25 decodeBase64 - Decode a string in base 64.
26 decodeJson - Decode Perl from Json.
27 denormalizeFolderName - Remove any trailing folder separator from a folder name component.
28 docUserFlags - Generate documentation for a method by calling the extractDocumentationFlags method in the package being documented, passing it the flags for a method and the name of the method.
29 dumpGZipFile - Write a data structure through gzip to a file.
30 encodeBase64 - Encode a string in base 64.
31 encodeJson - Encode Perl to Json.
32 evalFile - Read a file containing unicode, evaluate it, confess to any errors and then return any result - an improvement on do which silently ignores any problems.
33 evalGZipFile - Read a file containing compressed utf-8, evaluate it, confess to any errors and then return any result.
34 extractTest - Remove example markers from test code.
35 fe - Get extension of file name.
36 fileList - Files that match a given search pattern handed to bsd_glob.
37 fileModTime - Get the modified time of a file in seconds since the epoch.
38 fileOutOfDate - Calls the specified sub once for each source file that is missing, then calls the sub for the target if there were any missing files or if the target is older than any of the non missing source files or if the target does not exist.
39 filePath - Create a file name from an array of file name components.
40 filePathDir - Create a directory name from an array of file name components.
41 filePathExt - Create a file name from an array of file name components the last of which is an extension.
42 fileSize - Get the size of a file.
43 findDirs - Find all the folders under a folder and optionally filter the selected folders with a regular expression.
44 findFiles - Find all the files under a folder and optionally filter the selected files with a regular expression.
45 findFileWithExtension - Find the first extension from the specified extensions that produces a file that exists when appended to the specified file.
46 firstFileThatExists - Returns the name of the first file that exists or undef if none of the named files exist.
47 fn - Remove path and extension from file name.
48 fne - Remove path from file name.
49 formatTable - Format various data structures as a table.
50 formatTableA - Tabularize an array.
51 formatTableAA - Tabularize an array of arrays.
52 formatTableAH - Tabularize an array of hashes.
53 formatTableBasic - Tabularize an array of arrays of text.
54 formatTableH - Tabularize a hash.
55 formatTableHA - Tabularize a hash of arrays.
56 formatTableHH - Tabularize a hash of hashes.
57 formatTableMultiLine - Tabularize text that has new lines in it.
58 fp - Get path from file name.
59 fpn - Remove extension from file name.
60 fullFileName - Full name of a file.
61 genClass - Generate a class $class with the specified %Attributes.
62 genLValueArrayMethods - Generate lvalue array methods in the current package.
63 genLValueHashMethods - Generate lvalue hash methods in the current package.
64 genLValueScalarMethods - Generate lvalue scalar methods in the current package, A method whose value has not yet been set will return a new scalar with value undef.
65 genLValueScalarMethodsWithDefaultValues - Generate lvalue scalar methods with default values in the current package.
66 hostName - The name of the host we are running on.
67 htmlToc - Generate a table of contents for some html.
68 imageSize - Return (width, height) of an image obtained via Imagemagick.
69 indentString - Indent lines contained in a string or formatted table by the specified string.
70 isBlank - Test whether a string is blank.
71 javaPackage - Extract the package name from a java string or file.
72 javaPackageAsFileName - Extract the package name from a java string or file and convert it to a file name.
73 keyCount - Count keys down to the specified level.
74 loadArrayArrayFromLines - Load an array of arrays from lines of text: each line is an array of words.
75 loadArrayFromLines - Load an array from lines of text in a string.
76 loadArrayHashFromLines - Load an array of hashes from lines of text: each line is an hash of words.
77 loadHashArrayFromLines - Load a hash of arrays from lines of text: the first word of each line is the key, the remaining words are the array contents.
78 loadHashFromLines - Load a hash: first word of each line is the key and the rest is the value.
79 loadHashHashFromLines - Load a hash of hashes from lines of text: the first word of each line is the key, the remaining words are the sub hash contents.
80 makePath - Make the path for the specified file name or folder.
81 matchPath - Given an absolute path find out how much of the path actually exists.
82 max - Find the maximum number in a list.
83 maximumLineLength - Find the longest line in a string
84 microSecondsSinceEpoch - Micro seconds since unix epoch.
85 min - Find the minimum number in a list.
86 numberOfLinesInFile - The number of lines in a file
87 numberOfLinesInString - The number of lines in a string.
88 nws - Normalize white space in a string to make comparisons easier.
89 pad - Pad a string with blanks or the specified padding character to a multiple of a specified length.
90 parseCommandLineArguments - Classify the specified array of words into positional parameters and keyword parameters, then call the specified sub with a reference to an array of positional parameters followed by a reference to a hash of keywords and their values and return the value returned by this sub.
91 parseFileName - Parse a file name into (path, name, extension).
92 perlPackage - Extract the package name from a perl string or file.
93 powerOfTwo - Test whether a number is a power of two, return the power if it is else undef.
94 printFullFileName - Print a file name on a separate line with escaping so it can be used easily from the command line.
95 printQw - Print an array of words in qw() format.
96 quoteFile - Quote a file name.
97 readBinaryFile - Read binary file - a file whose contents are not to be interpreted as unicode.
98 readFile - Read a file containing unicode.
99 readGZipFile - Read the specified $file, containing compressed utf-8, through gzip
100 readUtf16File - Read a file containing unicode in utf-16 format.
101 relFromAbsAgainstAbs - Derive a relative file name for the first absolute file name relative to the second absolute file name.
102 removeFilePrefix - Removes a file prefix from an array of files.
103 renormalizeFolderName - Normalize a folder name component by adding a trailing separator.
104 saveCodeToS3 - Save source code files.
105 saveSourceToS3 - Save source code.
106 searchDirectoryTreesForMatchingFiles - Search the specified directory trees for the files (not folders) that match the specified extensions.
107 setIntersectionOfTwoArraysOfWords - Intersection of two arrays of words.
108 setUnionOfTwoArraysOfWords - Union of two arrays of words.
109 startProcess - Start new processes while the number of child processes recorded in %$pids is less than the specified $maximum.
110 temporaryFile - Create a temporary file that will automatically be unlinked during END processing.
111 temporaryFolder - Create a temporary folder that will automatically be rmdired during END processing.
112 timeStamp - hours:minute:seconds
113 titleToUniqueFileName - Create a file name from a title that is unique within the set %uniqueNames.
114 trackFiles - Track the existence of files.
115 trim - Remove any white space from the front and end of a string.
116 updateDocumentation - Update documentation from the comments in a perl script.
117 updatePerlModuleDocumentation - Update the documentation in a perl file and show said documentation in a web browser.
118 userId - The userid we are currently running under.
119 versionCode - YYYYmmdd-HHMMSS
120 versionCodeDashed - YYYY-mm-dd-HH:MM:SS
121 waitForAllStartedProcessesToFinish - Wait until all the processes started by startProcess have finished.
122 writeBinaryFile - Write a non unicode string to a file in after creating a path to the file if necessary and return the name of the file on success else confess.
123 writeFile - Write a unicode string to a file after creating a path to the file if necessary and return the name of the file on success else confess.
124 writeFiles - Write the values of a hash as a file identified by the key of the value
125 writeGZipFile - Write a unicode string through gzip to a file.
126 wwwEncode - Replace spaces in a string with %20 .
127 xxx - Execute a shell command.
128 yyy - Execute a block of shell commands line by line after removing comments - stop if there is a non zero return code from any command.
129 zzz - Execute lines of commands after replacing new lines with && then check that the pipeline execution results in a return code of zero and that the execution results match the optional regular expression if one has been supplied; confess() to an error if either check fails.
130 ˢ - Immediately executed inline sub to allow a code block before if.
Installation
This module is written in 100% Pure Perl and, thus, it is easy to read, comprehend, use, modify and install via cpan:
sudo cpan install Data::Table::Text
Author
Copyright
Copyright (c) 2016-2018 Philip R Brenan.
This module is free software. It may be used, redistributed and/or modified under the same terms as Perl itself.
Acknowledgements
Thanks to the following people for their help with this module:
- mim@cpan.org
-
Testing on windows
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 5000:
Unterminated L<...> sequence