Version History =============== Introduction ------------ This file holds summarized version history for code changes affecting the phonenumbers library. This file does not generally include descriptions of patch releases (vX.Y.Z => vX.Y.Z+1) unless there are significant changes to code, not just metadata changes. (Metadata updates are best checked [upstream](https://github.com/google/libphonenumber/blob/master/release_notes.txt).) What's new in 8.13.8 -------------------- Merge to [upstream commit 07cd7bbb8a2f](https://github.com/google/libphonenumber/commit/07cd7bbb8a2f); relevant code changes: - Added a check to phonenumberutil.py that the value of the `phone-context` parameter of the tel URI follows the correct syntax as defined in [RFC3966](https://www.rfc-editor.org/rfc/rfc3966#section-3). What's new in 8.13.0 -------------------- Merge to [upstream commit 185004cabd1bb4d3](https://github.com/google/libphonenumber/commit/185004cabd1bb4d3). Upstream has removed the `leading_zero_possible` field from the `PhoneMetadata` type as part of this version; however, this change is *not* mirrored in the Python code due to back-compatibility concerns. What's new in 8.12.40 --------------------- New `to_string()` methods have been added for enum-like classes, emitting strings that describe integer values known to be enum values. What's new in 8.12.32 --------------------- The library now includes `.pyi` stub files providing typing information about the API, thanks to Adam Turner. What's new in 8.12.24 --------------------- Merge to [upstream commit e9d8d84f531b](https://github.com/google/libphonenumber/commit/e9d8d84f531b); relevant code changes: - Updated As-You-Type-Formatter to exclude patterns where some digits would be dropped in the output. This also fixes the bug where an extra country code is added in some cases to the user's output. b/183053929 What's new in 8.12.29 --------------------- Merge to [upstream commit 8379f2f53bbe](https://github.com/google/libphonenumber/commit/8379f2f53bbe); relevant code changes: - Changes format_out_of_country_calling_number to always use preferred intl prefix if present, not just for numbers with a non-unique IDD. This means we will output "8~10" as the prefix if calling formatOutOfCountryCallingNumber instead of "810" for some regions that have this tilde in their prefix [designates that the user should wait before continuing to dial]. What's new in 8.12.0 --------------------- Merge to [upstream commit fbfc3639d484](https://github.com/google/libphonenumber/commit/fbfc3639d484); just metadata changes. What's new in 8.11.0 --------------------- Merge to [upstream commit ca195d5aff67](https://github.com/google/libphonenumber/commit/ca195d5aff67); just metadata changes. What's new in 8.10.8 --------------------- Merge to [upstream commit aa1e7af6d637](https://github.com/google/libphonenumber/commit/aa1e7af6d637); relevant code changes: - Making the application of alternate formats when finding phone numbers in text in strict-grouping and exact-match mode depend on the leading digits for each rule. This was always assumed but never actually done. This means that the false positive rate will decrease but also that more valid numbers are skipped. A subsequent CL will update patterns to increase recall. What's new in 8.10.3 --------------------- Merge to [upstream commit 45953266d45d](https://github.com/google/libphonenumber/commit/45953266d45d); relevant code changes: - Better documentation for length_of_national_destination_code to emphasise that not every number has one. - Removed unused code in the AsYouTypeFormatter: We no longer have numbers in formatting matching patterns, only \d. What's new in 8.10.0 --------------------- Merge to [upstream commit d62a8fb2b719](https://github.com/google/libphonenumber/commit/d62a8fb2b719); relevant code changes: - AsYouTypeFormatter changed to better choose between rules when dialling locally; previously we used the international rules when the national prefix was present since this would exclude the local-only rules. However, there are some numbers that are not internationally diallable that *do* use the national prefix, and this logic precluded formatting them correctly. What's new in 8.9.12 -------------------- Merge to [upstream commit d56bf9da349b](https://github.com/google/libphonenumber/commit/d56bf9da349b); relevant code changes: - Support Russian extension character "доб" as a valid one while parsing the numbers. What's new in 8.9.0 ------------------- Just metadata changes. What's new in 8.8.0 ------------------- Merge to [upstream commit 7e4e754bda09](https://github.com/google/libphonenumber/commit/7e4e754bda09); relevant code changes: - Improve parsing logic to be smarter about national-prefix detection & stripping based on possible-lengths (`IS_POSSIBLE_LOCAL_ONLY` and `INVALID_LENGTH`). Enables e.g. adding Iran short-codes starting with "096" without the need to hack IR's national prefix parsing config. What's new in 8.7.1 ------------------- Merge to [upstream commit fb9aa53ecfa3](https://github.com/google/libphonenumber/commit/fb9aa53ecfa3); relevant code changes: - Documentation fix for `number_type` What's new in 8.7.0 ------------------- Merge to [upstream commit 1ad92eb35a44](https://github.com/google/libphonenumber/commit/1ad92eb35a44); relevant code changes: - New method `supported_calling_codes()` API to return all the calling codes that the library considers valid, both for geographical and non-geographical entities. - Added `is_sms_service_for_region(numobj, region_dialing_from)` API in short number info library. An SMS service is where the primary or only intended usage is to receive and/or send text messages (SMSs). This includes MMS as MMS numbers downgrade to SMS if the other party isn't MMS-capable. The `is_sms_service` metadata is also serialized for the first time. - Documentation update for private variables `_VALID_PUNCTUATION` and `_SINGLE_INTERNATIONAL_PREFIX`, also renaming the latter from `_UNIQUE_INTERNATIONAL_PREFIX`. What's new in 8.6.0 ------------------- Merge to [upstream commit 242a186f1fbf](https://github.com/google/libphonenumber/commit/242a186f1fbf); relevant code changes: - Removing `leading_zero_possible` from the metadata and all the places it is referenced in the build and prod code. Will be removed from the metadata proto itself in a subsequent release. This should not affect users of the library - the only place it was used was `format_in_original_format`, and only initially to try and avoid modifying the input number by removing/adding digits inadvertently. Now this is checked at the end of the method anyway. However slight formatting differences with this method on invalid numbers starting with 0s may be noticed in some countries. - Updated the documentation for the `is_number_geographical` API. - Small comment improvements for `parse()` method to point users at `keep_raw_input` parameter. - Added a new enum for `CountryCodeSource` called `UNSPECIFIED`. This is used as a default value, and will be returned if someone calls `parse(keep_raw_input=False)` and then `.country_code_sourc` on the result. If users want an actual value for this then they should call `parse(keep_raw_input=True)` instead; the values that were previously returned after calling this method will not change. - Deletion of the possible number pattern in the phonemetadata.proto file and all generated code. This has not been used for a long time. What's new in 8.5.0 ------------------- Merge to [upstream commit 52cff9d8837f](https://github.com/google/libphonenumber/commit/52cff9d8837f); relevant code changes: - Add `can_be_internationally_dialled` public API; This was already in JS. What's new in 8.4.2 ------------------- Merge to [upstream commit 9923d9211432](https://github.com/google/libphonenumber/commit/9923d9211432); relevant code changes: - Small fix for possible out-of-bounds exception on RFC3966 input where no phone context was actually provided. What's new in 8.4.1 ------------------- Merge to [upstream commit 02dbc0921cf5](https://github.com/google/libphonenumber/commit/02dbc0921cf5); relevant code changes: - Changing `is_possible_with_reason` to return the enums `INVALID_LENGTH` and `IS_POSSIBLE_LOCAL_ONLY`, where these apply. `is_possible_number` continues to consider `IS_POSSIBLE` or `IS_POSSIBLE_LOCAL_ONLY` numbers as possible to dial. Announcement: - Doc updates for `region_code_for_number` to clarify that it does not work for short-codes or invalid numbers. What's new in 8.4.0 ------------------- Merge to [upstream commit 77affd08f65f](https://github.com/google/libphonenumber/commit/77affd08f65f); relevant code changes: - Doc changes to update references to ISO country codes to CLDR region codes, which are what we actually use. Notice in some of the mapper files the country code is still the ISO one, because it's used as part of a description of a language only (e.g. zh-TW vs zh-CN). Edited the language comments there since they can be two *or* three letters (c.f. fil for filipino). Also edited the comment for leadingDigits at the territory level in the `phonemetadata.proto` file. - New API methods: `is_possible_number_for_type` and `is_possible_number_for_type_with_reason`, along with `supported_types_for_region` and `supported_types_for_non_geo_entity`. These allow you to query which types (e.g. Mobile) exist for a particular region, and work out if a number is possible for that type (this is a simple length check) rather than for the region as a whole. What's new in 8.3.3 ------------------- Merge to [upstream commit 46a38545ba01](https://github.com/google/libphonenumber/commit/46a38545ba01); relevant code changes: - Doc fix for `geocoder.py` to explain the cases where an empty string might be returned. What's new in 8.3.2 ------------------- Metadata changes only. What's new in 8.3.1 ------------------- Merge to [upstream commit 5507fdbf623f](https://github.com/google/libphonenumber/commit/5507fdbf623f); relevant code changes: - Making `national_significant_number` more robust in the face of malicious input. This now ignores the `number_of_leading_zeros` if they are less than zero. What's new in 8.3.0 ------------------- Merge to [upstream commit ad297a10ba19](https://github.com/google/libphonenumber/commit/ad297a10ba19); relevant code changes: - Added two new enum values to `ValidationResult` - `IS_POSSIBLE_LOCAL_ONLY` and `INVALID_LENGTH`. Added more documentation to the existing values; see the docstrings for when these are going to be used. Note that the API for `is_possible_number_with_reason` has not yet been changed to return these values. `IS_POSSIBLE_LOCAL_ONLY` will be returned for some values which currently return `IS_POSSIBLE`, and `INVALID_LENGTH` will be returned for some values which currently return `TOO_LONG`. - Fix for `is_number_match` to ignore the `number_of_leading_zeros` field when comparing numbers unless `italian_leading_zero` is `True`, and to consider default values to match the same value when explicitly set for these two fields. This fix shouldn't be needed for anyone correctly creating phone numbers using "parse" as recommended. What's new in 8.2.0 ------------------- Merge to [upstream commit 3b16d6b06497](https://github.com/google/libphonenumber/commit/3b16d6b06497); relevant code changes: - Exported `normalize_diallable_chars_only`. This method is already public in the C++ implementation. It has also now been added to the Javascript implementation. What's new in 8.1.0 ------------------- Merge to [upstream commit c210dbca4e93](https://github.com/google/libphonenumber/commit/c210dbca4e93); relevant code changes: - Introduced new `is_carrier_specific_for_region` API in `shortnumberinfo`. This determines whether the provided short code is carrier-specific or not when dialed from the given region. What's new in 8.0.0 ------------------- Merge to [upstream commit 1eb06f31e1dd](https://github.com/google/libphonenumber/commit/1eb06f31e1dd); relevant code changes: - Removing the ability for `.._for_region` methods in `shortnumberinfo.py` to work on strings, as well of phone number objects. These have been marked deprecated for months. Any users of these methods should call `phonenumbers.parse` first to create a `PhoneNumber` object, and pass this in. - Support semicolon as extension character while parsing phone numbers. This is not applicable when you are trying to find the phone numbers. What's new in 7.7.5 ------------------- Merge to [upstream commit e905483f87cf](https://github.com/google/libphonenumber/commit/e905483f87cf); relevant code changes: - Removing all references to `possible_number_pattern` other than in the metadata itself. What's new in 7.7.4 ------------------- Merge to [upstream commit fedbc7020703](https://github.com/google/libphonenumber/commit/fedbc7020703); code changes: - GitHub project changes: - Changed tag to `vX.Y.Z` from `release-X.Y.Z`; this may affect ports and derived projects. - Metadata structure changes in XML file: - Mobile and Fixed-Line blocks are no longer assumed to inherit missing data from the GeneralDesc, but are treated like every other phone number type. This means that for the non-geographical country codes, like +800, the example number has been moved from generalDesc to the relevant number types, and the code in getExampleNumberForNonGeoEntity has been changed to look at these sub-types for an example number. This also means that the "NA" and "-1" blocks present in the metadata to indicate that no mobile or fixed-line numbers appear for the entity have been removed. There should no longer be an `exampleNumber` at the `generalDesc` level, but it should be present at every `PhoneNumberDesc` with data. - Code changes: - Using new `possibleLengthInfo` to decide whether a short number is the right length or not. This could result in more specific results; whereas before, a number from length 3 to length 6 may have been deemed possible, now we may exclude a number of length 5. - Add hash (#) as a diallable character. Numbers with # in them will no longer have formatting applied in `format_n_original_format`, and `normalize_diallable_chars_only` now retains the # symbol. - `example_number_for_non_geo_entity` has been changed to look at the specific number types, not just the generalDesc, for the example numbers; this is a necessary change after the metadata structure change detailed above. What's new in 7.7.3 ------------------- Merge to [upstream commit ad0ce0c94501](https://github.com/google/libphonenumber/commit/ad0ce0c94501); code changes: - Fixed `phonemetadata.py` not to merge from a `NumberFormat`'s unset bool `national_prefix_optional_when_formatting`. What's new in 7.7.2 ------------------- Merge to [upstream commit 2d0d216f6032](https://github.com/google/libphonenumber/commit/2d0d216f6032); code changes: - Stop setting empty `preferred_domestic_carrier_code`, and if we are passed such a number then treat the empty field as if unset. What's new in 7.7.1 ------------------- Merge to [upstream commit 8c37310deb49](https://github.com/google/libphonenumber/commit/8c37310deb49); code changes: - Switching the internal implementation of `is_possible_number` and related functions to use the new `possibleLengths` metadata. This affects a lot of countries, making `is_possible_number` more restrictive as more precise data is available. It also affects parsing ambiguous and invalid numbers, as we decide whether to strip a possible national prefix (1) or country code based on the length of the number and whether it is possible before or after this. - Formatting, naming and comment tweaks to follow style guide - Removal of unneeded `_can_be_geocoded` method in the `timezone.py` file, using `phonenumberutil.py` instead What's new in 7.7.0 ------------------- Merge to [upstream commit 1ec4d341c3cd](https://github.com/google/libphonenumber/commit/1ec4d341c3cd); no code changes that affect the Python version so this is just a version bump to stay in sync with upstream. What's new in 7.6.1 ------------------- Merge to [upstream commit 7cc500f588db](https://github.com/google/libphonenumber/commit/7cc500f588db); code changes: - `phonemetadata.py` has two more fields to represent possible lengths of phone numbers. Changed `buildmetadatafromxml.py` to alter the way that metadata about possible-lengths information is consumed when constructing metadata to populate these. [Discussion list email](https://groups.google.com/forum/#!topic/libphonenumber-discuss/75TOpTFVi08) What's new in 7.6.0 ------------------- Merge to [upstream commit ddf60b1c175e](https://github.com/google/libphonenumber/commit/ddf60b1c175e); code changes: - Made `is_number_geographical()` public and added `is_number_type_geographical()`, and changed the geocoder to use this when checking whether to give a detailed answer or country-level only. What's new in 7.5.0 ------------------- Merge to [upstream commit 3f83454ed62b](https://github.com/google/libphonenumber/commit/3f83454ed62b); no code changes that affect the Python version so this is just a version bump to stay in sync with upstream. What's new in 7.4.0 ------------------- Merge to [upstream commit 598b9a4f89d6](https://github.com/google/libphonenumber/commit/598b9a4f89d6); no code changes that affect the Python version so this is just a version bump to stay in sync with upstream. What's new in 7.3.0 ------------------- Merge to [upstream commit d933631fbf15](https://github.com/google/libphonenumber/commit/d933631fbf15); code changes: - Added support for `region_code of None in example_number_for_type()` - Added `invalid_example_number()` - Improvements to docstring for parse method - Update `is_number_geographical` to return true for geographical mobile numbers. What's new in 7.2.0 ------------------- Merge to [upstream commit ab5e61acc087ec9f5](https://github.com/google/libphonenumber/commit/ab5e61acc087ec9f5), which is 7.2.1 (7.2.0 had an immediate problem on release); upstream changelog mentions no code changes, but the Java implementation includes a change to use nano protobufs. What's new in 7.1.0 ------------------- Merge to [upstream commit 903ac5de5b6e1112](https://github.com/google/libphonenumber/commit/903ac5de5b6e1112); upstream code changelog: - Only upstream code change doesn't affect python version (New `MetadataSource` implementation that reads from a single metadata file with all regions' phone number metadata.) What's new in 7.0.0 ------------------- Merge to upstream Subversion revision 715; upstream code changelog: - New APIs for ShortNumberInfo. The old APIs have been deprecated and will be removed in an upcoming release. What's new in 6.3.0 ------------------- Merge to upstream Subversion revision 703; upstream code changelog: - Changing the offline geocoder to not return any country at all if the number could belong to multiple countries - Removing obsolete code that treated countries with no metadata as valid. What's new in 6.2.0 ------------------- Merge to upstream Subversion revision 674; upstream code changelog: - Better exclusion of dates when matching phone numbers from text. - Handle phone input in RFC3966 with missing tel: prefix What's new in 6.1.0 ------------------- Merge to upstream Subversion revision 656; upstream code changelog: - Adding MetadataLoader support to allow custom metadata loading from alternative sources (should have no visible impact to users). - Fixing bug where digits could be lost in as-you-type formatting and formatting patterns incorrectly applied. What's new in 6.0.0a -------------------- Split geographic metadata into chunks. Generate separate `phonenumbers-lite` package. (No upstream changes.) What's new in 6.0.0 ------------------- Removed beta status. Merge up to upstream Subversion revision 650; upstream code changelog: - Better support for detecting phone numbers in text that are beside each other - Change to how Japanese numbers beginning with "00" are modelled, with the side-effect that the maximum possible number length has been extended by 1. - Handle `StringIndexOutOfBoundsException` in the `AsYouTypeFormatter` when the national prefix that was extracted was not found in the prefix. This affected countries with very long carrier codes, such as Korea. - Removal of some of the author attributions - contributions to be tracked in CONTRIBUTORS file. What's new in 5.9b1 ------------------- The codebase now supports Python 2.5-2.7 and Python 3.x out of the box, without needing 2to3 conversion. The top-level module no longer exports the following functions: - `country_name_for_number` - `description_for_number` - `description_for_valid_number` These functions now need to be imported via the `phonenumbers.geocoder` submodule. The short number functions have been renamed: - `is_possible_short_number_object` becomes `is_possible_short_number` - `is_possible_short_number` becomes `is_possible_short_number_for_object` - `is_valid_short_number_object` becomes `is_valid_short_number` - `is_valid_short_number` becomes `is_valid_short_number_for_object` - `expected_cost` becomes `expected_cost_for_region`, and there's a new `expected_cost` function that takes a `PhoneNumber` object. Merge up to upstream Subversion revision 622; upstream code changelog: - Adding support for numbers with multiple Italian leading zeros, by adding a field to the phone number proto to allow an arbitrary number of leading zeros, and supporting this when parsing, validating and formatting. - Adding more functionality to `ShortNumberInfo` -> such as `GetExpectedCostForRegion`. - Fix for parsing short numbers that start with the national prefix. - Updating `FormatNumberForMobileDialing` to work with short numbers. - Stop finding Israeli 4-digit "star" numbers in text when no star is in fact present. - Bug fix for finding phone numbers where the area code was also part of the country calling code. What's new in 5.8b1 ------------------- Rename `shortnumberutil.py` to `shortnumberinfo.py`. Merge up to upstream Subversion revision 603; upstream code changelog: - Renamed `ShortNumberUtil` to `ShortNumberInfo` -> the former class is now deprecated and will be deleted in a later release. At the moment it just delegates to `ShortNumberInfo`. - New methods in the `ShortNumberInfo` API - `isCarrierSpecific`, singleton interface, `isPossibleShortNumber`, `isValidShortNumber`, `getShortNumberCost`. Note this is an experimental API at the moment and subject to change. - Bug fixes: - AsYouTypeFormatting: 3-digit numbers can be formatted as a group where appropriate - AsYouTypeFormatting: Countries with an optional national prefix were considered before to have always entered it, resulting in bugs where numbers without the national prefix were not properly formatted. - Numbers in Chile that overlap with emergency numbers are no longer marked as connecting to them - Not requiring the NDC to be alone for countries where there is no national prefix in strict grouping when extracting phone numbers What's new in 5.7b2 ------------------- Fix `setup.py` to include new `.shortdata` sub-package. What's new in 5.7b1 ------------------- Merge up to upstream Subversion revision 594; upstream code changelog: - Improve phone number extraction recall. - Add support for loading short number metadata. What's new in 5.6b1 ------------------- Merge up to upstream Subversion revision 579; upstream code changelog: - Fix for as-you-type-formatting bug affecting countries with no national prefix formatting rule, such as China. What's new in 5.5b1 ------------------- Merge up to upstream Subversion revision 574; upstream code changelog: - Changed internal initialization code and made more fields final. Note that we now throw an exception if an attempt is made to set the metadata more than once (which should only happen during testing). - Fix problem with `formatNumberForMobileDialing` for HU and CL. What's new in 5.4b1 ------------------- Load metadata on demand rather than all at start of day. Merge up to upstream Subversion revision 557; upstream code changelog: - Switch `formatNumberForMobileDialing` to prefer national format to international format when the number is dialed from the same region the phone number is from. What's new in 5.3b1 ------------------- Merge up to upstream Subversion revision 550; upstream code changelog: - Handling UAN numbers in Argentina better when dialling them locally from a mobile What's new in 5.2b1 ------------------- Merge up to upstream Subversion revision 532. What's new in 5.1b1 ------------------- Merge up to upstream Subversion revision 516. What's new in 5.0b2 ------------------- Merge up to upstream Subversion revision 500. The upstream metadata at r489 didn't match the generated Java code in 5.0; this upstream revision fixed the mismatch. What's new in 5.0b1 ------------------- Merge up to upstream Subversion revision 492. What's new in 4.9b1 ------------------- Merge up to upstream Subversion revision 469. What's new in 4.8b1 ------------------- Merge up to upstream Subversion revision 441. What's new in 4.7b1 ------------------- Merge up to upstream Subversion revision 431. What's new in 4.6b1 ------------------- Merge up to upstream Subversion revision 426. Reinstated Python 2.5 support, accidentally broken since 4.3. What's new in 4.5b1 ------------------- Merge up to upstream Subversion revision 419. What's new in 4.4b1 ------------------- Merge up to upstream Subversion revision 411. What's new in 4.3b1 ------------------- Merge up to upstream Subversion revision 396. Adjust codebase to allow 2to3 generation of Python 3.x version. What's new in 4.2b1 ------------------- Merge up to upstream Subversion revision 383. What's new in 4.1b1 ------------------- Merge up to upstream Subversion revision 374. What's new in 4.0b1 ------------------- Merge up to upstream Subversion revision 362. What's new in 3.9b1 ------------------- Merge up to upstream Subversion revision 353. What's new in 3.8b1 ------------------- Merge up to upstream Subversion revision 325. Includes initial simplistic implementation of geocoding functionality. What's new in 3.7b1 ------------------- Merge up to upstream Subversion revision 289 (but geocoding functionality not yet ported). What's new in 3.6b1 ------------------- Merge up to upstream Subversion revision 277 (but geocoding functionality not yet ported). Require Python 2.5, to allow import unicodedata. What's new in 3.5b2 ------------------- Fix GH-3: crash in `parse()` for number with blank metadata What's new in 3.5b1 ------------------- Merge up to upstream Subversion revision 213. What's new in 3.4b1 ------------------- Merge up to upstream Subversion revision 205. Changed version marker from a to b. More unit test coverage What's new in 3.3a1 ------------------- Merge up to upstream Subversion revision 190. What's new in 3.2a1 ------------------- Merge up to upstream version 3.3, Subversion revision 171. What's new in 3.1a1 ------------------- Initial port of libphonenumber, from This version based on upstream version 3.2, Subversion revision 166 of: