Class SignedPrinterParser
- java.lang.Object
-
- org.joda.money.format.SignedPrinterParser
-
- All Implemented Interfaces:
java.io.Serializable
,MoneyParser
,MoneyPrinter
final class SignedPrinterParser extends java.lang.Object implements MoneyPrinter, MoneyParser, java.io.Serializable
Prints and parses using delegated formatters, one for positive and one for megative.This class is immutable and thread-safe.
-
-
Field Summary
Fields Modifier and Type Field Description private static long
serialVersionUID
Serialization version.private MoneyFormatter
whenNegative
The formatter to use when negative.private MoneyFormatter
whenPositive
The formatter to use when positive.private MoneyFormatter
whenZero
The formatter to use when zero.
-
Constructor Summary
Constructors Constructor Description SignedPrinterParser(MoneyFormatter whenPositive, MoneyFormatter whenZero, MoneyFormatter whenNegative)
Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
parse(MoneyParseContext context)
Parses monetary information using a textual representation.void
print(MoneyPrintContext context, java.lang.Appendable appendable, BigMoney money)
Prints part of a monetary value to the output appendable.java.lang.String
toString()
-
-
-
Field Detail
-
serialVersionUID
private static final long serialVersionUID
Serialization version.- See Also:
- Constant Field Values
-
whenPositive
private final MoneyFormatter whenPositive
The formatter to use when positive.
-
whenZero
private final MoneyFormatter whenZero
The formatter to use when zero.
-
whenNegative
private final MoneyFormatter whenNegative
The formatter to use when negative.
-
-
Constructor Detail
-
SignedPrinterParser
SignedPrinterParser(MoneyFormatter whenPositive, MoneyFormatter whenZero, MoneyFormatter whenNegative)
Constructor.- Parameters:
whenPositive
- the formatter to use when the amount is positivewhenZero
- the formatter to use when the amount is zerowhenNegative
- the formatter to use when the amount is positive
-
-
Method Detail
-
print
public void print(MoneyPrintContext context, java.lang.Appendable appendable, BigMoney money) throws java.io.IOException
Description copied from interface:MoneyPrinter
Prints part of a monetary value to the output appendable.The implementation determines what to append, which may be some or all of the data held in the
BigMoney
.The context is not a thread-safe object and a new instance will be created for each print. The context must not be stored in an instance variable or shared with any other threads.
- Specified by:
print
in interfaceMoneyPrinter
- Parameters:
context
- the context being used, not nullappendable
- the appendable to add to, not nullmoney
- the money to print, not null- Throws:
java.io.IOException
- if an IO exception occurs
-
parse
public void parse(MoneyParseContext context)
Description copied from interface:MoneyParser
Parses monetary information using a textual representation.The text and parse index are stored in the context. The parsed data and updated index is also stored in the context.
Implementations should avoid throwing exceptions and use the error index in the context instead to record the problem. The context can be assumed to not be in error on entry to this method.
The context is not a thread-safe object and a new instance will be created for each parse. The context must not be stored in an instance variable or shared with any other threads.
- Specified by:
parse
in interfaceMoneyParser
- Parameters:
context
- the context to use and parse into, not null
-
toString
public java.lang.String toString()
- Overrides:
toString
in classjava.lang.Object
-
-