# Changelog ## 6.8.3 - Added support for the British Penny (GBX) - Fixed LKR currency html_entity symbol ## 6.8.2 - Removed subunits for HUF - Fixed `#from_amount` accepting `nil` as currency_code - Relaxed i18n version (< 0.9) - Set symbol for UZS - Added disambiguate_symbol for XFU - Fixed Peruvian Sol name - Fixed symbol_first for VND (now `false`) ## 6.8.1 - Fixed issue with calling `format` on a frozen `Money` object ## 6.8.0 - Ruby 2.4.0 support - Fixed UZS syntax - Fixed HUF smallest denomination - Fixed ruby 1.9 issues - Fixed html entity for COP - Updated all currency decimals to ISO-4217 - Fixed money allocation for negative amounts - Fixed symbol_first for RON - Fixed disambiguate option when symbol is set to true - Fixed thousands separator for CZK - Improved formatter performance by precaching I18n calls ## 6.7.1 - Changed DKK symbol from 'kr' to 'kr.' - Improved Money::Formatting#format docs - Updated VEF symbol from 'Bs F' to 'Bs' - `Currency#exponent` now returns Fixnum - Fixed coercion issues - Fixed edge case with explicit override of thousands separator and decimal mark - `Money#==` will now raise error for non-zero numeric values - Fixed divmod - Added disambiguation symbol to USD Dollar - Use disambiguation symbol when both disambiguate and symbol are true in `format` method ## 6.7.0 - Changed `Money#<=>` to return `nil` if the comparison is inappropriate. (#584) - Remove implicit conversion of values being compared. Only accept `Money` and subclasses of `Money` for comparisons and raise TypeError otherwise. - When comparing fails due to `Money::Bank::UnknownRate` `Money#<=>` will now return `nil` as `Comparable#==` will not rescue exceptions in the next release. - Fix `Currency` specs for `#exponent` and `#decimal_places` not making assertions. - Fix a couple of Ruby warnings found in specs. - Fix `Money#-`,`Money#+` arithmetics for Ruby 2.3+ : check for zero value without using eql? with a Fixnum. (#577) - Use `Money#decimal_mark` when formatting with `rounded_infinite_precision` rule set to `true`. - Replaced meta-defined `thousands_separator` and `decimal_mark` methods with regular methods. (#579) ## 6.6.0 - Fixed VariableExchange#exchange_with for big numbers. - Add Currency symbol translation support - `Currency.all` raises a more helpful error message (`Currency::MissingAttributeError`)if a currency has no priority - `Currency` implements `Enumerable`. - `Currency#<=>` sorts alphabetically by `id` if the `priority`s are the same, and no longer raises an error if one of the priorities is missing. - `Money::Currency.unregister` can take an ISO code argument in addition to a hash. - `Money::Currency.unregister` returns `true` if the given currency previously existed, and `false` if it didn't. - Fix symbol for SZL currency - Trying to create a Currency without an `iso_code` now raises a more helpful error message. - Add `Money.usd`, `.cad` and `.eur` as aliases for `.us_dollar`, `.ca_dollar`, and `.euro`. - Add helper methods for British pounds: `Money.pound_sterling` and `Money.gbp`. - Add `Money.from_amount` to create money from a value in units instead of fractional units. - Changed CHF symbol from 'Fr' to 'CHF' - Changed CLF exponent from 0 to 4 - Changed CLP subunit_to_unit from 1 to 100 - Minor fixes to prevent warnings on unused variables and the redefinition of `Money.default_currency` - `Money#==` changed to acknowledge that 0 in one currency is equal to 0 in any currency. - Changed KRW subunit_to_unit from 100 to 1 - Decouple exchange rates storage from bank objects and formalize storage public API. Default is `Money::RatesStore::Memory`. - `Currency.new` now a singleton by its id ## 6.5.1 - Fix format for BYR currency ## 6.5.0 - Add method to round a given amount of money to the nearest possible value in cash (aka Swedish rounding). - Fixed the subunit_to_unit values of the CLP and KRW currencies - Add option for `disambiguate` symbols for formatting - Fixed the subunit_to_unit values of the VND currency - Fix formatting of NGN - show symbol before amount - Switch default and alternate symbols for RUB currency - Fix symbol for TRY currency - Add `Money.default_formatting_rules` hash, meant to define default rules for everytime `Money#format` is called. They can be overwritten if provided on method call - Add support for the new official symbol for Russian Ruble (RUB) — «₽» ## 6.2.1 - Ensure set is loaded ## 6.2.0 - Fixes formatting error when both `thousands_separator` and `decimal_mark` was added to Money#format as options. - Add Money#to_i which returns the whole part of the value. i.e. Money.new(100, "USD").to_i # => 1 - Fix output on Ukrainian Hryvnia symbol in HTML. - Add documentation about i18n in README. - Update iso code, symbol, subunit for the new Turkmenistani manat (GH-181) - Performance Improvements (1.99x faster on MRI, 1.85x on Rubinius, 41.4x faster on JRuby) - Money can now add and subtract Fixnum 0 - Money#new uses Money.default_currency if currency arg is nil (GH-410) - Fixed formatting of NOK, putting the symbol after numbers - Fixed issue where rounded_infinite_precision formatting fails for some localized currencies (GH-422) ## 6.1.1 - Remove lingering Monetize call ## 6.1.0 - Remove deprecated methods. - Fix issue with block form of rounding_mode. ## 6.0.1 - Deprecated methods lists caller on print out for easier updating. - Added support for Money::Currency#to_str and Money::Currency#to_sym - Added ability to temporally change the rounding methond inside a given block - Replaced parsing and core extensions with the monetize gem ## 6.0.0 - Fix BTC subunit - New option :sign_positive to add a + sign to positive numbers - Only allow to multiply a money by a number (int, float) - Fix typo - Wrap the currency symbol in a span if :html is specified in the rules - Added Money::Currency.all method - Allow combined comparison operator to handle zero values without rates - Added Money::Currency.unregister method - Works on Ruby 1.8.7 - Update deps - Depreciate Money.parse - Passing :symbol => false when formatting 'JPY' currency in :ja locale will work as expected - Divide now obeys the specified rounding mode - Add Money#round method. This is helpful when working in infinite_precision mode and would like to perform rounding at specific points in your work flow. - In infinite precision mode, deserialized Money objects no longer return Float values from the `fractional` method. - Changed `thousands_separator` for Swedish Krona from dot to blank space. - Allow mathematical operations with first argument being not an instance of Money (eg. 2 * money instead of money * 2). - Money#dollars and Money#amount methods return numbers of type BigDecimal. - Change Money.from_bigdecimal (and in that way .to_money too) to keep precision when using `Money.infinite_precision = true` - Add :rounded_infinite_precision option to .format - Changed the New Taiwan Dollar symbol position from after the amount to before the amount. - Passing a Money instance to the Money constructor will obtain a new Money object with the same property values as the original - Add deprecation warning to comparators - Add Money.disallow_currency_conversion! option - Allow to inherits from `Money` ## 5.1.1 - Added :sign_before_symbol option to format negative numbers as -£1 rather than £-1 - Ensure BigDecimal.new always receives a string - compatibility fix for ruby-1.9.2-p320 - Update Maldivian Currency to MVR and fix ރ. to be ރ - Add exponent to currency - Add find_numeric to find currencies by ISO 4217 numeric code. - Fixed regression where thousands separator was missing on certain currencies. (GH-245) - Added :symbol_before_without_space option to add a space between currency symbol and amount. ## 5.1.0 - Fix currency assumption when parsing $ with a non-USD default currency. - Changed the Bulgarian lev symbol position from before the amount to after the amount. - Changed the symbol and html entity for INR. It is now "₹" instead of "₨". - Added Money::Currency.analyze for determining potential currencies for a given string using powereful algorithms - will detect symbols, iso codes and names even if mixed with text. - Changed UGX symbol from 'Sh' to 'USh'. - Changed SYP symbol from "£ or ل.س" to "£S". The previous symbols remain as alternates. - Changed RWF symbol from 'FR' to 'FRw'. - Changed RSD symbol from "din. or дин." to 'РСД'. The previous symbols remain as alternates. - Added MGA symbol 'Ar' - Added KGS symbol 'som' - Changed KES symbol from 'Sh' to 'KSh' - Added ETB symbol 'Br' - Changed EGP symbol from "£ or ج.م" to "ج.م" - Changed DJF symbol from 'Fr' to 'Fdj' - Changed CVE symbol from '$ or Esc' to '$'. 'Esc' remains as an alternate symbol. - Added BTN symbol 'Nu.' - Changed BAM symbol from 'KM or КМ' to 'КМ', the alternate (cyrillic script) remains as an alternate symbol. - Added alternate symbols for all currencies. For example, USD can be written as both '$' and 'US$', SEK can be 'Kr' or ':-', etc. - Renamed Money#cents to Money#fractional. Money#cents can still be used as a synonym and equivalent of Money#fractional. - Added Money.new_with_amount and Money#amount. Money.new_with_dollars and Money#dollars remain as synonyms. - Calling Bank::Base.instance doesn't make Bank::VariableExchange.instance return Bank::Base.instance anymore (semaperepelitsa) - Update Turkmenistan manat from TMM to TMT currency (GH-181). [Thanks @Exoth] - Moved ZWD Zimbabwean dollars to currency_bc.json, also added there ZWL, ZWN, and ZWR Zimbabwean dollars (GH-184). - Switch to multi_json gem (GH-170) - Fix "warning: ambiguous first argument..." (GH-166) - Update dependencies to latest and greatest (GH-172) - TravisBot is now watching Pull Request!!! (GH-171) - Minor code cleaning - Remove subunit from South Korean won (KRW) - Fixed bug where bankers rounding wasn't being used everywhere. ## 5.0.0 - Minor bugfix - incorrect use of character range resulted in botched results for Money::Parsing#extract_cents (GH-162) - Money::Currency::TABLE removed. Use Money::Currency.register to add additional currencies (GH-143) - Fix rounding error in Numeric.to_money (GH-145) - Allow on-the-fly calculation of decimal places if not known already (GH-146,GH-147,GH-148) - Move Euro symbol ahead of amount (GH-151) - Changed settings for Polish currency (GH-152) - Fall back to symbol if there is no html_entity present (GH-153) - Optionally Allow parsing of money values prefixed by symbols in key currencies (GH-155) - Fix bug where rates exported to a file from VariableExchange leave the File object open (GH-154) - Added Money#positive? and Money#negative? methods (GH-157) - Fix format function output for custom currencies (GH-156) - Fix parsing of strings with 3 decimal digits (GH-158) - Updated development dependencies - Said goodbye to RubyForge ## 4.0.2 - Money.to_money now understands a currency option (GH-121) - Added Money#-@ method to change object polarity (GH-122) - Added Money#symbol_or_iso_code utility method (GH-128) - Money.parse now understands trailing - as negative inputs (GH-133) - Money::Currency.new now validates input to avoid memory leaks (GH-137) - Forced UTF-8 encoding on currency JSON (GH-117) - Fixed position of Philippine peso sign (GH-124) - Fixed position of Danish currency sign (GH-127) ## 4.0.1 - Add missing config dir. Money 4.0.0 =========== The big change this release is moving the currency information into a JSON file. This should make it easier for users to add and test things. Thanks to Steve Morris for working on this during his Mendicant University course. In addition to this big change there were well over a dozen other minor changes. Features -------- - a new exchange bank nordea has been added to the README. (k33l0r) - a new exchange bank nbrb_currency has been added to the README. (slbug) - update Rake tasks - See our CI status in the README - Add syntax highlighting to the README (phlipper) - Remove minor unit from YEN (pwim) - Format YEN (pwim) - Update README for `_as_string` (mjankowski) - Update Lebanon currency (kaleemullah) - Update Polish złoty (holek) - Move currency information into JSON storage! (stevemorris) - Add ISO4217 Numeric codes (alovak) Bugfixes -------- - EEK currency is no longer used, kept for BC ([#issue/110](http://github.com/RubyMoney/money/issues/110)) - Lithuanian Litas symbol position fixed (laurynas) - Fixed README typos (phlipper) - Fixed README typos (pwim) - Fix specs (alovak) Money 3.7.1 =========== Bugfixes -------- - Add encoding indicator to top of Gemspec Money 3.7.0 =========== Features -------- - add Money#to_d (thanks Andrew White) - Add Money.use_i18n, this allows you to enable/disable i18n from being used, even if it's required in your app. Money 3.6.2 =========== Features -------- - i18n enhancements (thanks eloyesp [link](https://github.com/RubyMoney/money/commit/b2cab76c78ae04f40251fa20c4ab18faa968dc53)) - README updates (thanks pconnor) - Break into modules - Added `:no_cents_if_whole` format option - Update HKD from Ho to Cent - Performance improvements (thanks weppos) - Added Symbol#to_currency - Added Gemfile for development - Updated HUF currency to use `symbol_first => false` - Updated "Turkish New Lira" to "Turkish Lira" Money 3.6.1 =========== Bugfixes -------- - Floating point comparison needs to Epsilon aware (thanks Tobias Luetke) - reimplement fix for #issue/43, enable Marshal.(load/dump) Money 3.6.0 =========== Features -------- - Add a symbol position option for Money#format (thanks Romain, Gil and Julien) - Updated CNY to use "Fen" and subunit_to_unit of 100 - Updates to work with gem-testers.org Bugfixes -------- - Fixed issue with #format(:no_cents => true) (thanks Romain & Julien) Money 3.5.5 =========== Features -------- - Enhancements to Money::Currency (thanks Matthew McEachen) - Replace delimiter with thousands_separator - Replace separator with decimal_mark - Added symbol_first and html_entity - Added allocation algorithm for fair(ish) splitting of money between parties without losing pennies (thanks Tobias Luetke) Bugfixes -------- - Always store cents as an Integer (thanks Abhay Kumar) - Fixed TypeError in rate exchange (thanks Christian Billen) - Cleanup #parse (thanks Tom Lianza) Money 3.5.4 =========== Features -------- - Added Currency#decimal_places. Bugfixes -------- - Fixed error with Money#to_s error with negative amounts that are only cents. Money 3.5.3 =========== Bugfixes -------- - Fixed an error in #to_s when cents is negative Money 3.5.2 =========== Bugfixes -------- - Fixed an error in #to_s which appended extra 0s incorrectly Money 3.5.1 =========== Bugfixes -------- - Removed erroneous require. Money 3.5.0 =========== Features -------- - Updated to RSpec2. - Use i18n to lookup separator and delimiter signs. - Removed all deprecated methods up to v3.5.0, including the following: - Using Money#format with params instead of a Hash. - Using a Hash with Money#new. - Using Bank#exchange, use Bank#exchange_with instead. Bugfixes -------- - Updated Money#to_s to respect :separator and :subunit_to_unit. - Fixed Money#format for :subunit_to_unit != 100. ([#issue/37](http://github.com/RubyMoney/money/issue/37)) - Fixed String#to_money for :subunit_to_unit != 100. ([#issue/36](http://github.com/RubyMoney/money/issue/36)) - Removed duplicate currencies. ([#issue/38](http://github.com/RubyMoney/money/issue/38)) - Fixed issue related to JRuby returning 2 for Math.log10(1000).floor instead of correctly returning 3. Money 3.1.5 =========== Features -------- - Added support for creating objects with the main monetary unit instead of cents. ([#issue/25](http://github.com/RubyMoney/money/issues/25)) - Deprecated `Money#format` with separate params instead of Hash. Deprecation target set to Money 3.5.0. ([#issue/31](http://github.com/RubyMoney/money/issues/31)) - Deprecated `Money#new(0, :currency => "EUR")` in favor of `Money#new(0, "EUR")`. Deprecation target set to Money 3.5.0. ([#issue/31](http://github.com/RubyMoney/money/issues/31)) - Throw ArgumentError when trying to multiply two Money objects together. ([#issue/29](http://github.com/RubyMoney/money/issues/29)) - Update Money#parse to use :subunit_to_unit ([#issue/30](http://github.com/RubyMoney/money/issues/30)) Bugfixes -------- - Downgraded required_rubygems_version to >= 1.3.6. ([#issue/26](http://github.com/RubyMoney/money/issues/26)) - Use BigDecimal when floating point calculations are needed. - Ruby 1.9.2 compatibility enhancements. Money 3.1.0 =========== Features -------- - Implemented `Money::Bank::Base`. ([#issue/14](http://github.com/RubyMoney/money/issues/14)) - Added `Money::Bank::Base#exchange_with`. - Deprecated `Money::Bank::Base#exchange`. Deprecation target set to Money 3.2.0. - Implented `Money::Bank::VariableExchange` - Deprecated `Money::VariableExchangeBank`. Deprecation target set to Money 3.2.0. - Deprecate `Money::SYMBOLS`, `Money::SEPARATORS` and `Money::DELIMITERS`. Deprecation target set to Money 3.2.0. ([#issue/16](http://github.com/RubyMoney/money/issues/16)) - Implemented `#has` for `Money` and `Money::Currency`. - Refactored test suite to conform to RSpec conventions. - Moved project from [FooBarWidget](http://github.com/FooBarWidget) to [RubyMoney](http://github.com/RubyMoney) - Added Simone Carletti to list of authors. - Moved `@rounding_method` from `Money::Bank::VariableExchange` to `Money::Bank::Base`. ([#issue/18](http://github.com/RubyMoney/money/issues/18)) - Added `#setup` to `Money::Bank::Base`. Called from `#initialize`. ([#issue/19](http://github.com/RubyMoney/money/issues/19)) - Added [google_currency](http://github.com/RubyMoney/google_currency) to list of Currency Exchange Implementations. - Added `#export_rates` to `Money::Bank::VariableExchange`. ([#issue/21](http://github.com/RubyMoney/money/issues/21)) - Added `#import_rates` to `Money::Bank::VariableExchange`. ([#issue/21](http://github.com/RubyMoney/money/issues/21)) - Removed dependency on Jeweler. - Replaced usage of hanna with yardoc. - Rewrote/reformatted all documentation. Bugfixes -------- - Fixed incorrect URLs in documentation. ([#issue/17](http://github.com/RubyMoney/money/issues/17)) - Updated `:subunit_to_unit` for HKD from 10 to 100. ([#issue/20](http://github.com/RubyMoney/money/issues/20)) - Updated Ghanaian Cedi to use correct ISO Code, GHS. ([#issue/22](http://github.com/RubyMoney/money/issues/22)) - Make `default` rake task call `spec`. ([#issue/23](http://github.com/RubyMoney/money/issues/23)) Money 3.1.0.pre3 ================ Features -------- - Added [google_currency](http://github.com/RubyMoney/google_currency) to list of Currency Exchange Implementations. - Added `#export_rates` to `Money::Bank::VariableExchange`. ([#issue/21](http://github.com/RubyMoney/money/issues/21)) - Added `#import_rates` to `Money::Bank::VariableExchange`. ([#issue/21](http://github.com/RubyMoney/money/issues/21)) Bugfixes -------- - Updated `:subunit_to_unit` for HKD from 10 to 100. ([#issue/20](http://github.com/RubyMoney/money/issues/20)) Money 3.1.0.pre2 ================ Features -------- - Moved `@rounding_method` from `Money::Bank::VariableExchange` to `Money::Bank::Base`. ([#issue/18](http://github.com/RubyMoney/money/issues/18)) - Added `#setup` to `Money::Bank::Base`. Called from `#initialize`. ([#issue/19](http://github.com/RubyMoney/money/issues/19)) Bugfixes -------- - Fixed incorrect URLs in documentation. ([#issue/17](http://github.com/RubyMoney/money/issues/17)) Money 3.1.0.pre1 ================ Features -------- - Implemented `Money::Bank::Base`. ([#issue/14](http://github.com/RubyMoney/money/issues/14)) - Added `Money::Bank::Base#exchange_with`. - Deprecated `Money::Bank::Base#exchange`. Deprecation target set to Money 3.2.0. - Implented `Money::Bank::VariableExchange` - Deprecated `Money::VariableExchangeBank`. Deprecation target set to Money 3.2.0. - Deprecate `Money::SYMBOLS`, `Money::SEPARATORS` and `Money::DELIMITERS`. Deprecation target set to Money 3.2.0. ([#issue/16](http://github.com/RubyMoney/money/issues/16)) - Implemented `#has` for `Money` and `Money::Currency`. - Refactored test suite to conform to RSpec conventions. - Moved project from [FooBarWidget](http://github.com/FooBarWidget) to [RubyMoney](http://github.com/RubyMoney) - Added Simone Carletti to list of authors. Bugfixes -------- - Fixed rounding error in `Numeric#to_money`. ([#issue/15](http://github.com/RubyMoney/money/issues/15)) Money 3.0.5 =========== Features -------- - Added `Money#abs`. - Added ability to pass a block to `VariableExchangeBank#new` or `#exchange`, specifying a custom truncation method - Added optional `currency` argument to` Numeric#to_money`. ([#issue/11](http://github.com/RubyMoney/money/issues/11)) - Added optional `currency` argument to `String#to_money`. ([#issue/11](http://github.com/RubyMoney/money/issues/11)) - Use '¤' as the default currency symbol. ([#issue/10](http://github.com/RubyMoney/money/issues/10)) Bugfixes -------- - Updated `Currency#subunit_to_unit` documentation (it's an integer not a string). - Fixed issue when exchanging currencies with different `:subunit_to_unit` values. - `Numeric#to_money` now respects `:subunit_to_unit`. ([#issue/12](http://github.com/RubyMoney/money/issues/12)) Money 3.0.4 =========== Features -------- - Use `:subunit_to_unit` in `#to_s`, `#to_f` and `#format`. - Deprecated `Money#SEPARATORS` and `Money#DELIMITERS`. Bugfixes -------- - Updated `#exchange` to avoid floating point rounding errors. - Added `:separator` and `:delimiter` to `Currency` - Updated the attributes of the Chilean Peso. Money 3.0.3 =========== Features -------- - Added `#currency_as_string` and `#currency_as_string=` for easier integration with ActiveRecord/Rails Money 3.0.2 =========== Features -------- - Added `#div`, `#divmod`, `#modulo`, `#%` and `#remainder` to `Money`. Money 3.0.1 =========== Features -------- - Added `#eql?` to `Money` - Updated `Numeric#to_money` to work with all children of `Numeric` (i.e. `BigDecimal`, `Integer`, `Fixnum`, `Float`, etc) Money 3.0.0 =========== Features -------- - Version Bump due to compatibility changes with ActiveRecord. See conversation [here](http://github.com/RubyMoney/money/issues#issue/4/comment/224880) for more information. Money 2.3.0 =========== Features -------- - Currency is now represented by a `Currency` Object instead of a `String`. Money 2.2.0 =========== Features -------- - Can now divide two Money objects by one another using `#/`. - Can now convert a Money object to a float using `#to_f`. - Users can now specify Separators and Delimiters when using `#format`. - Support for Brazilian Real `Money.new(1_00, :BRL)` - Migrated to Jeweler