History¶
v7.2.1¶
23 Apr 2024
Bugfixes¶
Refactored number_to_words toward reduced complexity.
v7.2.0¶
31 Mar 2024
Features¶
Replace pydantic with typeguard (#195)
v7.1.0¶
13 Aug 2023
Features¶
Now handle ‘pair of x’ in pl_sb_uninflected_complete (#188)
v7.0.0¶
04 Jul 2023
Features¶
Refine type hint for
singular_noun
to indicate a literal return type forFalse
. (#186)
Deprecations and Removals¶
Removed methods renamed in 0.2.0.
v6.2.0¶
03 Jul 2023
Features¶
Project now supports Pydantic 2 while retaining support for Pydantic 1. (#187)
Bugfixes¶
Added validation of user-defined words and amended the type declarations to match, allowing for null values but not empty strings. (#187)
v6.1.1¶
03 Jul 2023
Bugfixes¶
ordinal
now handles float types correctly without first coercing them to strings. (#178)
v6.1.0¶
02 Jul 2023
Features¶
Require Python 3.8 or later.
v6.0.5¶
02 Jul 2023
#187: Pin to Pydantic 1 to avoid breaking in Pydantic 2.
v6.0.4¶
05 Apr 2023
Internal cleanup.
v6.0.3¶
05 Apr 2023
v6.0.2¶
20 Oct 2022
#169: Require pydantic 1.9.1 to avoid
ValueError
.
v6.0.1¶
19 Oct 2022
Minor tweaks and packaging refresh.
v6.0.0¶
30 Jul 2022
#157:
compare
methods now validate their inputs and will raise a more meaningful exception if an empty string or None is passed. This expectation is now documented.Many public methods now perform validation on arguments. An empty string is no longer allowed for words or text. Callers are expected to pass non-empty text or trap the validation errors that are raised. The exceptions raised are
pydantic.error_wrappers.ValidationError
, which are currently a subclass ofValueError
, but since that may change, tests check for a genericException
.
v5.6.2¶
15 Jul 2022
#15: Fixes to plural edge case handling.
v5.6.1¶
09 Jul 2022
Packaging refresh and docs update.
v5.6.0¶
01 May 2022
#153: Internal refactor to simplify and unify
_plnoun
and_sinoun
.
v5.5.2¶
05 Apr 2022
Fixed badges.
v5.5.1¶
05 Apr 2022
#150: Rewrite to satisfy type checkers.
v5.5.0¶
23 Mar 2022
#147: Enhanced type annotations.
v5.4.0¶
31 Jan 2022
v5.3.0¶
02 Mar 2021
#108: Add support for pluralizing open compound nouns.
v5.2.0¶
23 Feb 2021
#121: Modernized the codebase. Added a lot of type annotations.
v5.1.0¶
#113: Add support for uncountable nouns.
v5.0.3¶
23 Feb 2021
Refreshed package metadata.
v5.0.2¶
15 Nov 2020
v5.0.1¶
14 Nov 2020
Identical release validating release process.
v5.0.0¶
14 Nov 2020
Module no longer exposes a
__version__
attribute. Instead to query the version installed, use importlib.metadata or its backport to query:importlib.metadata.version('inflect')
v4.1.1¶
14 Nov 2020
Refreshed package metadata.
v4.1.0¶
03 Feb 2020
#95: Certain operations now allow ignore arbitrary leading words.
v4.0.0¶
20 Dec 2019
Require Python 3.6 or later.
v3.0.2¶
07 Nov 2019
#88: Distribution no longer includes root
tests
package.
v3.0.1¶
27 Oct 2019
Project now builds on jaraco/skeleton for shared package management.
v3.0.0¶
19 Apr 2019
#75: Drop support for Python 3.4.
v2.1.0¶
09 Nov 2018
#29: Relicensed under the more permissive MIT License.
v2.0.1¶
21 Oct 2018
#57: Fix pluralization of taco.
v2.0.0¶
21 Oct 2018
#37: fix inconsistencies with the inflect method
We now build and parse AST to extract function arguments instead of relying on regular expressions. This also adds support for keyword arguments and built-in constants when calling functions in the string. Unfortunately, this is not backwards compatible in some cases:
Strings should now be wrapped in single or double quotes p.inflect(“singular_noun(to them)”) should now be p.inflect(“singular_noun(‘to them’)”)
Empty second argument to a function will now be parsed as None instead of ‘’. p.inflect(“num(%d,) eggs” % 2) now prints “2 eggs” instead of “ eggs” Since None, True and False are now supported, they can be passed explicitly: p.inflect(“num(%d, False) eggs” % 2) will print “ eggs” p.inflect(“num(%d, True) eggs” % 2) will print “2 eggs”
v1.0.2¶
21 Oct 2018
v1.0.1¶
23 Sep 2018
#31: fix extraneous close parentheses.
v1.0.0¶
26 Jul 2018
Dropped support for Python 3.3.
v0.3.1¶
08 May 2018
Fixed badges in readme.
v0.3.0¶
08 May 2018
Moved hosting to the jazzband project on GitHub.
v0.2.5¶
Fixed TypeError while parsing compounds (by yavarhusain)
Fixed encoding issue in setup.py on Python 3
v0.2.4¶
new maintainer (Alex Grönholm)
added Python 3 compatibility (by Thorben Krüger)
v0.2.3¶
fix a/an for dishonor, Honolulu, mpeg, onetime, Ugandan, Ukrainian, Unabomber, unanimous, US
merge in ‘subspecies’ fix by UltraNurd
add arboretum to classical plurals
prevent crash with singular_noun(‘ys’)
v0.2.2¶
change numwords to number_to_words in strings
improve some docstrings
comment out imports for unused .inflectrc
remove unused exception class
v0.2.1¶
31 Aug 2010
remove incorrect gnome_sudoku import
v0.2.0¶
05 Aug 2010
add gender() to select the gender of singular pronouns
replace short named methods with longer methods. shorted method now print a message and raise DecrecationWarning
pl -> plural
plnoun -> plural_noun
plverb -> plural_verb
pladj -> plural_adjective
sinoun -> singular_noun
prespart -> present_participle
numwords -> number_to_words
plequal -> compare
plnounequal -> compare_nouns
plverbequal -> compare_verbs
pladjequal -> compare_adjs
wordlist -> join
change classical() to only accept keyword args: only one way to do it
fix bug in numwords where hundreds was giving the wrong number when group=3
v0.1.8¶
10 Jul 2010
add line to setup showing that this provides ‘inflect’ so that inflect_dj can require it
add the rest of the tests from the Perl version
v0.1.7¶
09 Jul 2010
replace most of the regular expressions in _plnoun and _sinoun. They run several times faster now.
v0.1.6¶
03 Jul 2010
add method sinoun() to generate the singular of a plural noun. Phew!
add changes from new Perl version: 1.892
start adding tests from Perl version
add test to check sinoun(plnoun(word)) == word Can now use word lists to check these methods without needing to have a list of plurals. ;-)
fix die -> dice