summaryrefslogtreecommitdiff
path: root/CHANGELOG.rst
blob: 1f989354a8bd3fbe5ce6909251ac7f672482d441 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
XX-XX-XXXX v. X.X.X
+++++++++++++++++++

   - Formally deprecated old or misleading APIs (issue #83)
   - Documentation, packaging, and CI cleanup (thanks @jdufresne) (issues #69, #71-#80)
   - Consolidate API documentation into a single page (issue #82)
   - Add a CHANGELOG.rst to the top-level of the repository (issue #85)
   - Add back support for very old versions of setuptools (issue #84)

09-09-2018 v. 5.4.1
+++++++++++++++++++

   - Fix error in a newly added test (issues #65, #67)
   - Changed code format and quality checking infrastructure (issue #68)

09-06-2018 v. 5.4.0
+++++++++++++++++++

   - Re-expose ``natsort_key`` as "public" and remove the
     associated ``DepricationWarning``
   - Add better developer documentation
   - Refactor tests (issue #66)
   - Bump allowed ``fastnumbers`` version

07-07-2018 v. 5.3.3
+++++++++++++++++++

   - Update docs with a FAQ and quick how-it-works (issue #60)
   - Fix a StopIteration error in the testing code
   - Enable Python 3.7 support in Travis-CI (issue #61)

05-17-2018 v. 5.3.2
+++++++++++++++++++

    - Fix bug that prevented install on old versions of setuptools (issues #55, #56)
    - Revert layout from src/natsort/ back to natsort/ to make user
      testing simpler (issues #57, #58)

05-14-2018 v. 5.3.1
+++++++++++++++++++

    - No bugfixes or features, just infrastructure and installation updates
    - Move to defining dependencies with Pipfile
    - Development layout is now src/natsort/ instead of natsort/
    - Add bumpversion infrastructure
    - Extras can be installed by "[]" notation

04-20-2018 v. 5.3.0
+++++++++++++++++++

    - Fix bug in assessing ``fastnumbers`` version at import-time (thanks @hholzgra) (issues #51, #53)
    - Add ability to consider unicode-decimal numbers as numbers (issues #52, #54)

02-14-2018 v. 5.2.0
+++++++++++++++++++

    - Add ``ns.NUMAFTER`` to cause numbers to be placed after non-numbers (issues #48, #49)
    - Add ``natcmp`` function (Python 2 only) (thanks @rinslow) (issue #47)

11-11-2017 v. 5.1.1
+++++++++++++++++++

    - Added additional unicode number support for Python 3.7
    - Added information on how to install and test (issue #46)

08-19-2017 v. 5.1.0
+++++++++++++++++++

    - Fixed ``StopIteration`` warning on Python 3.6+ (thanks @lykinsbd) (issues #42, #43)
    - All Unicode input is now normalized (issue #44, #45)

04-30-2017 v. 5.0.3
+++++++++++++++++++

    - Improved development infrastructure
    - Migrated documentation to ReadTheDocs

01-02-2017 v. 5.0.2
+++++++++++++++++++

    - Added additional unicode number support for Python 3.6
    - Renamed several internal functions and variables to improve clarity
    - Improved documentation examples
    - Added a "how does it work?" section to the documentation

06-04-2016 v. 5.0.1
+++++++++++++++++++

    - The ``ns`` enum attributes can now be imported from the top-level
      namespace
    - Fixed a bug with the ``from natsort import *`` mechanism
    - Fixed bug with using ``natsort`` with ``python -OO`` (issues #38, #39)

05-08-2016 v. 5.0.0
+++++++++++++++++++

    - ``ns.LOCALE``/``humansorted`` now accounts for thousands separators (issue #36)
    - Refactored entire codebase to be more functional (as in use functions as
      units). Previously, the code was rather monolithic and difficult to follow. The
      goal is that with the code existing in smaller units, contributing will
      be easier (issue #37)
    - Deprecated ``ns.TYPESAFE`` option as it is now always on (due to a new
      iterator-based algorithm, the typesafe function is now cheap)
    - Increased speed of execution (came for free with the new functional approach
      because the new factory function paradigm eliminates most ``if`` branches
      during execution)

      - For the most cases, the code is 30-40% faster than version 4.0.4
      - If using ``ns.LOCALE`` or ``humansorted``, the code is 1100% faster than
        version 4.0.4

    - Improved clarity of documentaion with regards to locale-aware sorting
    - Added a new ``chain_functions`` function for convenience in creating
      a complex user-given ``key`` from several existing functions

11-01-2015 v. 4.0.4
+++++++++++++++++++

    - Improved coverage of unit tests
    - Unit tests use new and improved hypothesis library
    - Fixed compatibility issues with Python 3.5

06-25-2015 v. 4.0.3
+++++++++++++++++++

    - Fixed bad install on last release (sorry guys!) (issue #30)

06-24-2015 v. 4.0.2
+++++++++++++++++++

    - Added back Python 2.6 and Python 3.2 compatibility. Unit testing is now
      performed for these versions (thanks @dpetzold) (issue #29)
    - Consolidated under-the-hood compatibility functionality

06-04-2015 v. 4.0.1
+++++++++++++++++++

    - Added support for sorting NaN by internally converting to -Infinity
      or +Infinity (issue #27)

05-17-2015 v. 4.0.0
+++++++++++++++++++

    - Made default behavior of 'natsort' search for unsigned ints,
      rather than signed floats. This is a backwards-incompatible
      change but in 99% of use cases it should not require any
      end-user changes (issue #20)
    - Improved handling of locale-aware sorting on systems where the
      underlying locale library is broken (issue #34))
    - Greatly improved all unit tests by adding the hypothesis library

04-06-2015 v. 3.5.6
+++++++++++++++++++

    - Added 'UNGROUPLETTERS' algorithm to get the case-grouping behavior of
      an ordinal sort when using 'LOCALE' (issue #23)
    - Added convenience functions 'decoder', 'as_ascii', and 'as_utf8' for
      dealing with bytes types

04-04-2015 v. 3.5.5
+++++++++++++++++++

    - Added 'realsorted' and 'index_realsorted' functions for
      forward-compatibility with >= 4.0.0
    - Made explanation of when to use "TYPESAFE" more clear in the docs

04-02-2015 v. 3.5.4
+++++++++++++++++++

    - Fixed bug where a 'TypeError' was raised if a string containing a leading
      number was sorted with alpha-only strings when 'LOCALE' is used (issue #22)

03-26-2015 v. 3.5.3
+++++++++++++++++++

    - Fixed bug where '--reverse-filter' option in shell script was not
      getting checked for correctness
    - Documentation updates to better describe locale bug, and illustrate
      upcoming default behavior change
    - Internal improvements, including making test suite more granular

01-13-2015 v. 3.5.2
+++++++++++++++++++

    - Enhancement that will convert a 'pathlib.Path' object to a 'str' if
      'ns.PATH' is enabled (issue #16)

09-25-2014 v. 3.5.1
+++++++++++++++++++

    - Fixed bug that caused list/tuples to fail when using 'ns.LOWECASEFIRST'
      or 'ns.IGNORECASE' (issue #15)
    - Refactored modules so that only the public API was in natsort.py and
      ns_enum.py
    - Refactored all import statements to be absolute, not relative


09-02-2014 v. 3.5.0
+++++++++++++++++++

    - Added the 'alg' argument to the 'natsort' functions.  This argument
      accepts an enum that is used to indicate the options the user wishes
      to use.  The 'number_type', 'signed', 'exp', 'as_path', and 'py3_safe'
      options are being deprecated and will become (undocumented)
      keyword-only options in natsort version 4.0.0
    - The user can now modify how 'natsort' handles the case of non-numeric
      characters (issue #14)
    - The user can now instruct 'natsort' to use locale-aware sorting, which
      allows 'natsort' to perform true "human sorting" (issue #14)

      - The `humansorted` convenience function has been included to make this
        easier

    - Updated shell script with locale functionality

08-12-2014 v. 3.4.1
+++++++++++++++++++

    - 'natsort' will now use the 'fastnumbers' module if it is installed. This
      gives up to an extra 30% boost in speed over the previous performance
      enhancements
    - Made documentation point to more 'natsort' resources, and also added a
      new example in the examples section

07-19-2014 v. 3.4.0
+++++++++++++++++++

    - Fixed a bug that caused user's options to the 'natsort_key' to not be
      passed on to recursive calls of 'natsort_key' (issue #12)
    - Added a 'natsort_keygen' function that will generate a wrapped version
      of 'natsort_key' that is easier to call.  'natsort_key' is now set to
      deprecate at natsort version 4.0.0
    - Added an 'as_path' option to 'natsorted' & co. that will try to treat
      input strings as filepaths. This will help yield correct results for
      OS-generated inputs like
      ``['/p/q/o.x', '/p/q (1)/o.x', '/p/q (10)/o.x', '/p/q/o (1).x']`` (issue #3)
    - Massive performance enhancements for string input (1.8x-2.0x), at the expense
      of reduction in speed for numeric input (~2.0x)

      - This is a good compromise because the most common input will be strings,
        not numbers, and sorting numbers still only takes 0.6x the time of sorting
        strings.  If you are sorting only numbers, you would use 'sorted' anyway

    - Added the 'order_by_index' function to help in using the output of
      'index_natsorted' and 'index_versorted'
    - Added the 'reverse' option to 'natsorted' & co. to make it's API more
      similar to the builtin 'sorted'
    - Added more unit tests
    - Added auxillary test code that helps in profiling and stress-testing
    - Reworked the documentation, moving most of it to PyPI's hosting platform
    - Added support for coveralls.io
    - Entire codebase is now PyFlakes and PEP8 compliant

06-28-2014 v. 3.3.0
+++++++++++++++++++

    - Added a 'versorted' method for more convenient sorting of versions (issue #11)
    - Updated command-line tool --number_type option with 'version' and 'ver'
      to make it more clear how to sort version numbers
    - Moved unit-testing mechanism from being docstring-based to actual unit tests
      in actual functions (issue #10)

      - This has provided the ability determine the coverage of the unit tests (99%)
      - This also makes the pydoc documentation a bit more clear

    - Made docstrings for public functions mirror the README API
    - Connected natsort development to Travis-CI to help ensure quality releases

06-20-2014 v. 3.2.1
+++++++++++++++++++

    - Re-"Fixed" unorderable types issue on Python 3.x - this workaround
      is for when the problem occurs in the middle of the string (issue #7 again)

05-07-2014 v. 3.2.0
+++++++++++++++++++

    - "Fixed" unorderable types issue on Python 3.x with a workaround that
      attempts to replicate the Python 2.x behavior by putting all the numbers
      (or strings that begin with numbers) first (issue #7)
    - Now explicitly excluding __pycache__ from releases by adding a prune statement
      to MANIFEST.in

05-05-2014 v. 3.1.2
+++++++++++++++++++

    - Added setup.cfg to support universal wheels (issue #6)
    - Added Python 3.0 and Python 3.1 as requiring the argparse module

03-01-2014 v. 3.1.1
+++++++++++++++++++

    - Added ability to sort lists of lists (issue #5)
    - Cleaned up import statements

01-20-2014 v. 3.1.0
+++++++++++++++++++

    - Added the ``signed`` and ``exp`` options to allow finer tuning of the sorting
    - Entire codebase now works for both Python 2 and Python 3 without needing to run
      ``2to3``
    - Updated all doctests
    - Further simplified the ``natsort`` base code by removing unneeded functions.
    - Simplified documentation where possible
    - Improved the shell script code

        - Made the documentation less "path"-centric to make it clear it is not just
          for sorting file paths
        - Removed the filesystem-based options because these can be achieved better
          though a pipeline
        - Added doctests
        - Added new options that correspond to ``signed`` and ``exp``
        - The user can now specify multiple numbers to exclude or multiple ranges
          to filter by

10-01-2013 v. 3.0.2
+++++++++++++++++++

    - Made float, int, and digit searching algorithms all share the same base function
    - Fixed some outdated comments
    - Made the ``__version__`` variable available when importing the module

8-15-2013 v. 3.0.1
++++++++++++++++++

    - Added support for unicode strings (issue #2)
    - Removed extraneous ``string2int`` function
    - Fixed empty string removal function

7-13-2013 v. 3.0.0
++++++++++++++++++

    - Added a ``number_type`` argument to the sorting functions to specify how
      liberal to be when deciding what a number is
    - Reworked the documentation

6-25-2013 v. 2.2.0
++++++++++++++++++

    - Added ``key`` attribute to ``natsorted`` and ``index_natsorted`` so that
      it mimics the functionality of the built-in ``sorted`` (issue #1)
    - Added tests to reflect the new functionality, as well as tests demonstrating
      how to get similar functionality using ``natsort_key``

12-5-2012 v. 2.1.0
++++++++++++++++++

    - Reorganized package
    - Now using a platform independent shell script generator (entry_points
      from distribute)
    - Can now execute natsort from command line with ``python -m natsort``
      as well

11-30-2012 v. 2.0.2
+++++++++++++++++++

    - Added the use_2to3 option to setup.py
    - Added distribute_setup.py to the distribution
    - Added dependency to the argparse module (for python2.6)

11-21-2012 v. 2.0.1
+++++++++++++++++++

    - Reorganized directory structure
    - Added tests into the natsort.py file iteself

11-16-2012, v. 2.0.0
++++++++++++++++++++

    - Updated sorting algorithm to support floats (including exponentials) and
      basic version number support
    - Added better README documentation
    - Added doctests