Package eu.bandm.tools.format
Class Formats
java.lang.Object
eu.bandm.tools.format.Formats
Collection of static factory and transformation methods for Formats.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
static final int
static final String
String formatting template for date and time.static final Format
For marking quoted text in messags and documentation text.static final Format
For marking quoted text in messags and documentation text.static final Pattern
static final Pattern
static final int
static final Pattern
Matches all combinations of "carriage return" and "linefeed", where both appear at most once each.static final Pattern
Matches one single "linefeed", "carriage return", or "horizontal tab" character.static final Pattern
Matches arbitrary non-empty sequemces of blanks and horizontal tabs.static final Pattern
Matches arbitrary non-empty sequemces of blanks and horizontal tabs and numbered variables.static final String
For marking quoted text in messags and documentation text.static final String
For marking quoted text in messags and documentation text. -
Method Summary
Modifier and TypeMethodDescriptionstatic Format
Wraps the given data into a Java-style doc comment.static String
Returns the given date in the format defined byFORMAT_DATE_AND_TIME
.static String
Returns the current state of the calendaric clock in the format defined byFORMAT_DATE_AND_TIME
.static String
generationText
(String prefix, String[] args, int blankEscapeMode, String argSeparator, String lineSeparator, int maxWidth) Generate a primitive string which explains the parameters of a tool application.static Format
list
(Format open, CompoundConstructor outerCombinator, Format delim, CompoundConstructor innerCombinator, Format close, Format... formats) static Format
list
(Format open, CompoundConstructor outerCombinator, Format delim, CompoundConstructor innerCombinator, Format close, Iterable<? extends Format> formats) static Format
list
(Format open, CompoundConstructor outerCombinator, Format delim, CompoundConstructor innerCombinator, Format close, List<? extends Format> formats) Convenience method, creates a complex list display format for sequences ofFormat
s.static Format
Same aslist(Format,CompoundConstructor,Format,CompoundConstructor,Format,List)
, whereouterCombinator
defaults toCompoundConstructor.beside
andinnerCombinator
defaults toCompoundConstructor.line
static Format
Same aslist(Format,CompoundConstructor,Format,CompoundConstructor,Format,List)
, whereouterCombinator
defaults toCompoundConstructor.beside
andinnerCombinator
defaults toCompoundConstructor.line
static Format
Wraps the given data into a Java-style non-doc multi-line comment.static Format
Creates a literal format which chooses quote symbols not appearing in the data, in XML style.static Format
Creates a literal format which quoted doublequotes by escaping them with a backslash.static String
removeHtml
(String orig) Useful when a comment string shall be used in an HTML body but also in an HTML comment, etc.static String
Replaces all occurences of "linefeed", "carriage return", or "horizontal tab" character by a space character.static Format
singleLine
(Format format) Wraps the given data into a Java-style single-line comment.static String
stringescape
(String data, int mode) Escapes blank characters in the given datum according to the methods selected by the mode parameter:NO_ESCAPE
, no change,ESCAPE_BLANKS_INDIVIDUALLY
, escape each blank with an own backslash, orESCAPE_FRAME_WITH_DOUBLEQUOTES
, frame whole string with double quotes and escape all internal double quotes with a backslash.static Format
Convenience method for translating multi-line text into a complex format hierarchy.static Format
textWithVars
(String txt) Transform a text into a complex Format structure, addtionally detecting references to numeric variables.
-
Field Details
-
STRING_GUILLEMETS_GERMAN_LEFT
For marking quoted text in messags and documentation text.- See Also:
-
STRING_GUILLEMETS_GERMAN_RIGHT
For marking quoted text in messags and documentation text.- See Also:
-
format_guillemetsGermanLeft
For marking quoted text in messags and documentation text. -
format_guillemetsGermanRight
For marking quoted text in messags and documentation text. -
pattern_newline
Matches all combinations of "carriage return" and "linefeed", where both appear at most once each. -
pattern_ws
Matches arbitrary non-empty sequemces of blanks and horizontal tabs. -
pattern_wsWithVars
Matches arbitrary non-empty sequemces of blanks and horizontal tabs and numbered variables. -
NO_ESCAPE
public static final int NO_ESCAPE- See Also:
-
ESCAPE_FRAME_WITH_DOUBLEQUOTES
public static final int ESCAPE_FRAME_WITH_DOUBLEQUOTES- See Also:
-
ESCAPE_BLANKS_INDIVIDUALLY
public static final int ESCAPE_BLANKS_INDIVIDUALLY- See Also:
-
pattern_newlineAndTabs
Matches one single "linefeed", "carriage return", or "horizontal tab" character. -
FORMAT_DATE_AND_TIME
String formatting template for date and time. This string passed as the format control toString.format(String,Object...)
with someGregorianCalendar
as second argument. Date and Time format is set to the same format as the shell function "makedate" in "etc/calltools.mk", (beside that the latter does currently not include seconds.)
The result looks like
2009-07-21_01h09m07s
The day-part is defined by the Java string formatting standard code "%tF
", which directly corresponds to "%tY-%tm-%td
", and thus verbatim to ISO 8601
The time-of-day part closely follows the "extended format" of ISO 8601 cf. ISO 8601/en and ISO 8601/de
BUT the separation character "." is replaced by "h" and "m", to make the string directoy usable as a file name/time stamp. (windoof does not allow colon in file names, and you shouldn't try with unix.)Alternatives would have been ...
- better readable "
%tF %tHh%tMm%tS
" - older version "
%tF %tT
" - completely consistent with "extended" format from
ISO8601 is "
%tFT%tT
"
%tH:%tM:%tS
", thus inserting ":" colon chars. So these again could not be used as (compontens of) file names.- See Also:
- better readable "
-
htmlTag
-
htmlBrTag
-
-
Method Details
-
quoteDTDstyle
Creates a literal format which chooses quote symbols not appearing in the data, in XML style.If the data does not contain single quotes then the result is an
Format.Append
with single quotes as first and last character.
Otherwise, if data does not contain double quotes, then do the same with double quotes.
Otherwise replace all single quotes in the data with a XML-style "character entity" and use frame with single quotes. -
quoteJavaStyle
Creates a literal format which quoted doublequotes by escaping them with a backslash.- Parameters:
f
- the text contents of which is quoted and returned.
-
text
Convenience method for translating multi-line text into a complex format hierarchy. The result will have the structureBeneath | Block | | Literal | | Space | | Literal | | Space | | Literal | Space | Block | | Literal | | Space | | Literal *
The limits of blocks will be given by hard "newlines" contained in the text.
Whitespace will be translated into Space and non-whitespace into Literal
Whitespace at the beginning of a line (following a hard newline) will be translated into indentation.
Empty lines (two consecutive newline characters) results to space on the upper level, under the Beneath combinator. -
textWithVars
Transform a text into a complex Format structure, addtionally detecting references to numeric variables. Seetext(java.lang.String)
for details. Additionally all substrings from {code #0} to {code #9} are translated to instances ofFormat.BoundVariable
. -
list
public static Format list(Format open, CompoundConstructor outerCombinator, Format delim, CompoundConstructor innerCombinator, Format close, Iterable<? extends Format> formats) -
list
Same aslist(Format,CompoundConstructor,Format,CompoundConstructor,Format,List)
, whereouterCombinator
defaults toCompoundConstructor.beside
andinnerCombinator
defaults toCompoundConstructor.line
-
list
Same aslist(Format,CompoundConstructor,Format,CompoundConstructor,Format,List)
, whereouterCombinator
defaults toCompoundConstructor.beside
andinnerCombinator
defaults toCompoundConstructor.line
-
list
public static Format list(Format open, CompoundConstructor outerCombinator, Format delim, CompoundConstructor innerCombinator, Format close, Format... formats) -
list
public static Format list(Format open, CompoundConstructor outerCombinator, Format delim, CompoundConstructor innerCombinator, Format close, List<? extends Format> formats) Convenience method, creates a complex list display format for sequences ofFormat
s. The structure which is created is determinded toouter combinator | | | | | close | | | inner comb.-----+--- .... ---+ | | | | | Append Append f[last] | | | | | | f[0] delim f[1] delim | open
(The argument type "List" instead of "Iterable" has been chosen because addtional length information is convenient for the implementation.)- Parameters:
open
- the format at the very left of the result, like an open parenthesisouterCombinator
- how to combine open, the inner list, and closedelim
- the format to separate the elements of the list, like a commainnerCombinator
- how to combine the elements of the inner listclose
- the format at the very right of the result, like a closing parenthesisformats
- the sequence of inner elements.
-
singleLine
Wraps the given data into a Java-style single-line comment. ASSUMES that argument does not contain line breaks. -
apiDoc
Wraps the given data into a Java-style doc comment. -
multiLine
Wraps the given data into a Java-style non-doc multi-line comment. -
stringescape
Escapes blank characters in the given datum according to the methods selected by the mode parameter:-
NO_ESCAPE
, no change, -
ESCAPE_BLANKS_INDIVIDUALLY
, escape each blank with an own backslash, - or
ESCAPE_FRAME_WITH_DOUBLEQUOTES
, frame whole string with double quotes and escape all internal double quotes with a backslash.
-
-
replaceNewlinesAndTabs
Replaces all occurences of "linefeed", "carriage return", or "horizontal tab" character by a space character. -
dateNow_standardFormat
Returns the current state of the calendaric clock in the format defined byFORMAT_DATE_AND_TIME
. -
date_standardFormat
Returns the given date in the format defined byFORMAT_DATE_AND_TIME
. -
generationText
public static String generationText(String prefix, String[] args, int blankEscapeMode, String argSeparator, String lineSeparator, int maxWidth) Generate a primitive string which explains the parameters of a tool application. Concatenates the prefix and the sequence of args, after blank escaping. It joins the args by argSeparator, or by lineSeparator whenever the line length reaches maxWidth.All strings in the "args[]" array are considered as potential file paths and thus (heuristically) anonymized by calling
FilenameUtils.anonymiseLocalFile(String)
.- Parameters:
prefix
- first part of comment which will not be altered.args
- arguments to the generation command: blanks will be replacedblankEscapeMode
- seestringescape(String,int)
argSeparator
- to be inserted after every arglineSeparator
- to be inserted when line length is oversteppedmaxWidth
- maximal line length
-
removeHtml
Useful when a comment string shall be used in an HTML body but also in an HTML comment, etc.
-