Skip to content

Latest commit

 

History

History
597 lines (385 loc) · 14.6 KB

CHANGELOG.rst

File metadata and controls

597 lines (385 loc) · 14.6 KB

Changelog

6.0.1 (unreleased)

  • Nothing changed yet.

6.0.0 (2024-12-17)

  • Announce for now that croniter dev is ended (CRA).
  • Rework timestamp_to_datetime to use whatever timezone [kiorky]
  • Make datetime_to_timestamp & timestamp_to_datetime public [kiorky]
  • Fix EPOCH calculation in case of non UTC & 32 bits based systems [kiorky]
  • Apply isort formatter [kiorky]
  • Reintegrate test_speed [kiorky]
  • Apply black formatter [evanpurkhiser, kiorky]
  • Code quality changes [evanpurkhiser, kiorky]
    • Remove unused _get_caller_globals_and_locals [evanpurkhiser]
    • Remove single-use bad_length [evanpurkhiser]
    • Remove unused days in proc_month [evanpurkhiser]
    • Use field_index over i for readability [evanpurkhiser]
    • Always use """ for docstrings [evanpurkhiser]
    • Make helper instance methods that do not use self static [evanpurkhiser]
    • Remove unusd call to sys.exc_info [evanpurkhiser]
    • Remove unused ALPHAS [evanpurkhiser]
    • Improve croniter.expand documentation [evanpurkhiser]

5.0.1 (2024-10-29)

  • Community wanted: Reintroduce 7 as DayOfWeek in deviation from standard cron (#90). [kiorky]

4.0.0 (2024-10-28)

  • Remove DayOfWeek alias 7 to DayOfWeek 0 to stick to standard cron (#90). [kiorky]
  • Fix DOW ranges calculations when lastday is a Sunday. [kiorky]

3.0.4 (2024-10-25)

  • Fix overflow on 32bits systems (#87) [kiorky]
  • Fix python2 testing (related to #93) [kiorky]
  • Modernize packaging. Special thanks to Aarni Koskela (akx) for all the inputs. [kiorky, akx]

3.0.3 (2024-07-26)

  • fix lint [kiorky]

3.0.2 (2024-07-26)

  • Fix start_time not respected in get_next/get_prev/all_next/all_prev (#86) [hesstobi, kiorky]

3.0.1 (2024-07-25)

  • Add an update_current argument to get_next/get_prev/all_next/all_prev to facilitate writing of some downstream code, see #83. [kiorky]

3.0.0 (2024-07-23)

  • Support for year field [zhouyizhen, kiorky]
  • Better support for 6 fields (second), and 7 fields crons [zhouyizhen, kiorky]
  • Better fix hashed expressions omitting some entries (#82, #42, #30) fix is retained over #42 initial fix [zhouyizhen, kiorky]
  • Ensure match return false when not time available (#81) [zhouyizhen, kiorky]

2.0.7 (2024-07-16)

  • fix doc

2.0.6 (2024-07-16)

  • Implement second_at_beginning [zhouyizhen, kiorky]
  • Support question mark as wildcard [zhouyizhen, kiorky]
  • Support to start a cron from a reference start time [mghextreme, kiorky]

2.0.5 (2024-04-20)

  • No changes, fix lint [kiorky]

2.0.4 (2024-04-20)

  • Support hashid strings in is_valid [george-kuanli-peng, kiorky]
  • Avoid over-optimization in crontab expansions [Cherie0125, liqirui <[email protected]>, kiorky]

2.0.3 (2024-03-19)

  • Add match_range function [salitaba]

2.0.2 (2024-02-29)

  • fix leap year (29 days in February) [zed2015]

2.0.1 (2023-10-11)

  • Fix release issue [kiorky]

2.0.0 (2023-10-10)

  • Add Python 3.12 support [rafsaf]
  • Make major release instructions [kiorky]

1.4.1 (2023-06-15)

  • Make a retrocompatible version of 1.4.0 change about supporting VIXIECRON bug. (fix #47) [kiorky]

1.4.0 (2023-06-15)

  • Added "implement_cron_bug" flag to make the cron parser compatible with a bug in Vixie/ISC Cron [kiorky, David White <[email protected]>] WARNING: EXPAND METHOD CHANGES RETURN VALUE

1.3.15 (2023-05-25)

  • Fix hashed expressions omitting some entries [@waltervos/Walter Vos <[email protected]>]
  • Enhance .match() precision for 6 position expressions [@szpol/szymon <[email protected]>]

1.3.14 (2023-04-12)

  • Lint

1.3.13 (2023-04-12)

  • Add check for range begin/end

1.3.12 (2023-04-12)

  • restore py2 compat

1.3.11 (2023-04-12)

  • Do not expose i into global namespace

1.3.10 (2023-04-07)

  • Fix DOW hash parsing [kiorky]
  • better error handling on py3 [kiorky]

1.3.8 (2022-11-22)

  • Add Python 3.11 support and move docs files to main folder [rafsaf]

1.3.7 (2022-09-06)

1.3.5 (2022-05-14)

  • Add Python 3.10 support [eelkevdbos]

1.3.4 (2022-02-18)

  • Really fix compat for tests under py27 [kiorky]

1.3.3 (2022-02-18)

  • Fix compat for tests under py27 [kiorky]

1.3.2 (2022-02-18)

  • Fix #12: regressions with set_current [kiorky, agateblue]

1.3.1 (2022-02-15)

  • Restore compat with python2 [kiorky]

1.3.0 (2022-02-15)

  • Add a way to make next() easier to use. This fixes #11 [kiorky]

1.2.0 (2022-01-14)

  • Enforce validation for day=1. Before this release we used to support day=0 and it was silently glided to day=1 to support having both day in day in 4th field when it came to have 6fields cron forms (second repeat). It will now raises a CroniterBadDateError. See #6 [kiorky]

1.1.0 (2021-12-03)

  • Enforce validation for month=1. Before this release we used to support month=0 and it was silently glided to month=1 to support having both day in month in 4th field when it came to have 6fields cron forms (second repeat). It will now raises a CroniterBadDateError. See #6 [kiorky]

1.0.15 (2021-06-25)

  • restore py2 [kiorky]

1.0.14 (2021-06-25)

  • better type checks [kiorky]

1.0.13 (2021-05-06)

  • Fix ZeroDivisionError with * * R/0 * * [cuu508]

1.0.12 (2021-04-13)

  • Add support for hashed/random/keyword expressions Ryan Finnie (rfinnie)
  • Review support support for hashed/random/keyword expression and add expanders reactor [ kiorky ]

1.0.11 (2021-04-07)

  • fix bug: bad case:0 6 30 3 * [zed2015(zhangchi)]
  • Add support for L in the day_of_week component. This enable expressions like * * * * L4, which means last Thursday of the month. This resolves #159. [Kintyre]
  • Create CroniterUnsupportedSyntaxError exception for situations where CRON syntax may be valid but some combinations of features is not supported. Currently, this is used when the day_of_week component has a combination of literal values and nth/last syntax at the same time. For example, 0 0 * * 1,L6 or 0 0 * * 15,sat#1 will both raise this exception because of mixing literal days of the week with nth-weekday or last-weekday syntax. This may impact existing cron expressions in prior releases, because 0 0 * * 15,sat#1 was previously allowed but incorrectly handled. [Kintyre]
  • Update croniter_range() to allow an alternate croniter class to be used. Helpful when using a custom class derived from croniter. [Kintyre]

1.0.10 (2021-03-25)

  • Remove external library natsort. Sorting of cron expression components now handled with sorted() with a custom key function. [Kintyre]

1.0.9 (2021-03-23)

  • Remove futures dependency [kiorky]

1.0.8 (2021-03-06)

  • Update _expand to lowercase each component of the expression. This is in relation to #157. With this change, croniter accepts and correctly handles * * 10-L * *. [cuu508]

1.0.7 (2021-03-02)

  • Fix _expand to reject int literals with underscores [cuu508]
  • Remove a debug statement to make flake8 happy [cuu508]

1.0.6 (2021-02-01)

  • Fix combination of star and invalid expression bugs [kiorky]

1.0.5 (2021-01-29)

  • Security fix: fix overflow when using cron ranges [kiorky]

1.0.4 (2021-01-29)

  • Spelling fix release

1.0.3 (2021-01-29)

  • Fix #155: raise CroniterBadCronError when error syntax [kiorky]

1.0.2 (2021-01-19)

  • Fix match when datetime has microseconds [kiorky]

1.0.1 (2021-01-06)

  • no changes, just to make sense with new semver2 (making croniter on a stable state) [kiorky]

0.3.37 (2020-12-31)

  • Added Python 3.8 and 3.9 support [eumiro]

0.3.36 (2020-11-02)

  • Updated docs section regarding max_years_between_matches to be more shorter and hopefully more relevant. [Kintyre]
  • Don't install tests [scop]

0.3.35 (2020-10-11)

  • Handle L in ranges. This fixes #142. [kiorky]
  • Add a new initialization parameter max_years_between_matches to support finding the next/previous date beyond the default 1 year window, if so desired. Updated README to include additional notes and example of this usage. Fixes #145. [Kintyre]
  • The croniter_range() function was updated to automatically determines the appropriate max_years_between_matches value, this preventing handling of the CroniterBadDateError exception. [Kintyre]
  • Updated exception handling classes: CroniterBadDateError now only applies during date finding operations (next/prev), and all parsing errors can now be caught using CroniterBadCronError. The CroniterNotAlphaError exception is now a subclass of CroniterBadCronError. A brief description of each exception class was added as an inline docstring. [Kintyre]
  • Updated iterable interfaces to replace the CroniterBadDateError with StopIteration if (and only if) the max_years_between_matches argument is provided. The rationale here is that if the user has specified the max tolerance between matches, then there's no need to further inform them of no additional matches. Just stop the iteration. This also keeps backwards compatibility. [Kintyre]
  • Minor docs update [Kintyre]

0.3.34 (2020-06-19)

  • Feat croniter_range(start, stop, cron) [Kintyre]
  • Optimization for poorly written cron expression [Kintyre]

0.3.33 (2020-06-15)

  • Make dateutil tz support more official [Kintyre]
  • Feat/support for day or [田口信元]

0.3.32 (2020-05-27)

  • document seconds repeats, fixes #122 [kiorky]
  • Implement match method, fixes #54 [kiorky]
  • Adding tests for #127 (test more DSTs and croniter behavior around) [kiorky]
  • Changed lag_hours comparison to absolute to manage dst boundary when getting previous [Sokkka]

0.3.31 (2020-01-02)

  • Fix get_next() when start_time less then 1s before next instant [AlexHill]

0.3.30 (2019-04-20)

  • credits

0.3.29 (2019-03-26)

  • credits
  • history stripping (security)
  • Handle -Sun notation, This fixes #119. [kiorky]
  • Handle invalid ranges correctly, This fixes #114. [kiorky]

0.3.25 (2018-08-07)

  • Pypi hygiene [hugovk]

0.3.24 (2018-06-20)

  • fix #107: microsecond threshold [kiorky]

0.3.23 (2018-05-23)

  • fix get_next while preserving the fix of get_prev in 7661c2aaa [Avikam Agur <[email protected]>]

0.3.22 (2018-05-16)

  • Don't count previous minute if now is dynamic If the code is triggered from 5-asterisk based cron get_prev based on datetime.now() is expected to return current cron iteration and not previous execution. [Igor Khrol <[email protected]>]

0.3.20 (2017-11-06)

0.3.19 (2017-08-31)

  • fix #87: backward dst changes [kiorky]

0.3.18 (2017-08-31)

0.3.17 (2017-05-22)

0.3.16 (2017-03-15)

0.3.15 (2017-02-16)

  • fix bug around multiple conditions and range_val in _get_prev_nearest_diff. [abeja-yuki@github]

0.3.14 (2017-01-25)

  • issue #69: added day_or option to change behavior when day-of-month and day-of-week is given [Andreas Vogl <[email protected]>]

0.3.13 (2016-11-01)

0.3.12 (2016-03-10)

0.3.11 (2016-01-13)

  • Bug fix: The get_prev API crashed when last day of month token was used. Some essential logic was missing. [Iddo Aviram <[email protected]>]

0.3.10 (2015-11-29)

  • The functionality of 'l' as day of month was broken, since the month variable was not properly updated [Iddo Aviram <[email protected]>]

0.3.9 (2015-11-19)

  • Don't use datetime functions python 2.6 doesn't support [petervtzand]

0.3.8 (2015-06-23)

  • Truncate microseconds by setting to 0 [Corey Wright]

0.3.7 (2015-06-01)

  • converting sun in range sun-thu transforms to int 0 which is recognized as empty string; the solution was to convert sun to string "0"

0.3.6 (2015-05-29)

  • Fix default behavior when no start_time given Default value for start_time parameter is calculated at module init time rather than call time.
  • Fix timezone support and stop depending on the system time zone

0.3.5 (2014-08-01)

  • support for 'l' (last day of month)

0.3.4 (2014-01-30)

  • Python 3 compat
  • QA Release

0.3.3 (2012-09-29)

  • proper packaging