Changelog
All notable changes to this project will be documented in this file.
See Conventional Commits for commit guidelines.
6.0.0
1 Dec 2022
💥 BREAKING CHANGES
- Minimum supported Node version is v14.18; we’re dropping v12 support
5.1.0
12 Aug 2022
✨ Features
5.0.0
9 Sept 2021
✨ Features
- migrate to ES Modules (8c9d95d)
💥 BREAKING CHANGES
- programs now are in ES Modules and won’t work with Common JS
require()
4.1.0
24 May 2021
✨ Features
- config file based major bump blacklisting (e15f9bb)
4.0.15
11 Apr 2021
⏪ Reverts
- Revert “chore: setup refresh” (23cf206)
4.0.1
28 Jan 2021
🔧 Fixed
- add
testStats
to npmignore (f3c84e9)
4.0.0
23 Jan 2021
✨ Features
- rewrite in TS, start using named exports (7cf002e)
💥 BREAKING CHANGES
- previously:
import strFindHeadsTails from …
— nowimport { strFindHeadsTails } from …
3.17.0
28 Nov 2020
Accidental version bump during migration to SourceHut. Sorry about that.
3.16.0
26 Jan 2020
✨ Features
- rewrite a little bit, make program run three times faster (87a8689)
3.15.0
2 Oct 2019
✨ Features
- remove option checking and ordinals dep; now ~176 times faster (a827baa)
3.15.0
26 Sept 2019
- Remove
ordinal-number-suffix
andcheck-types-mini
to make operations around 176 times faster
3.14.0
20 Jan 2019
- Various documentation and setup tweaks after we migrated to monorepo
- Setup refresh: updated dependencies and all config files using automated tools
3.10.0
25 Oct 2018
- Updated all dependencies
- Restored coveralls.io reporting
- Restored unit test linting
3.9.0
11 Aug 2018
Code refresh:
- Removed conditional
if(DEBUG)
statements which previously relied on being commented-out - Updated all build parts to suit Babel 7
- Set up comments removal from built files
- Switched to
rollup-plugin-terser
to finally forget “is it ES or non-ES code” issues - Temporaroly removed code coverage,
nyc
because it broke after switching to Babel 7, latestava
andesm
combo
Repo is now living happily in BitBucket; traffic seems to be the same
3.8.0
16 Jun 2018
GitHub sold us out. In the meantime, we:
- Migrated to BitBucket (to host repo + perform CI) and Codacy (for code quality audit)
- Dropped BitHound (RIP) and Travis
3.7.0
26 May 2018
- Wired Rollup to remove comments from non-dev builds. This means we can now leave the
console.log
s in the source code — there’s no need to comment-outconsole.log
statements or care about them not spilling into production. Now it’s done automatically. - Unit tests are pointing at ES modules build, which means that code coverage is correct now, without Babel functions being missed. This is important because now code coverage is real again and now there are no excuses not to perfect it.
3.6.0
27 Apr 2018
- Set up prettier and removed
.editorconfig
- Remove
package-lock.json
- Made some error messages to display content in colour.
3.5.0
22 Jan 2018
- Improvements to error messages — now reporting index of the heads or tails in question.
3.4.0
4 Jan 2018
- Add
opts.relaxedAPI
3.3.0
4 Jan 2018
- Improvements to the algorithm. If the situation is vague and there’s overlap of tails and heads (tails slightly preceding heads), algorithm will pick heads and ignore tails in front.
3.2.0
3 Jan 2018
- Add
opts.matchHeadsAndTailsStrictlyInPairsByTheirOrder
3.1.0
2 Jan 2018
No new features, only under-bonnet improvements.
- Pinned all unit tests’ throws to exact errors. Practically, this means we test not only does it throw in particular case, but also does it raise the exact error that we intended to raise.
3.0.0
28 Dec 2017
💥 BREAKING CHANGES
- Moved fourth argument,
fromIndex
, intoopts
because it stood in the way. opts.throwWhenSomethingWrongIsDetected
– When I tapped this API myself for the first time, I noticed errors with heads and tails should bethrow
n here, at this package, not at its consumers. For example, both heads and tails are found but they’re in the opposite order. Now, the default settings will leads tothrow
n error. You can turn it off and make it behave like previous version by settingopts.throwWhenSomethingWrongIsDetected
tofalse
opts.allowWholeValueToBeOnlyHeadsOrTails
— When processing JSON data structures, it’s possible that they will contain their own config. For example, JSON will use heads and tails, but also, there will be fields that DEFINE those heads and tails as well. This is a peculiar case — whole string will be equal to heads or tails. These cases will be recognised and errors won’t bethrow
n. Unless you setopts.allowWholeValueToBeOnlyHeadsOrTails
tofalse
.optssource
— allows tothrow
errors in different name. Useful for parent libraries.
2.0.0
27 Dec 2017
Complete rewrite of the API.
- When I tried to use it, I understood that I didn’t like the
v.1
API at all. Reporting only first character indexes of heads and tails was a compromise, done only because the previous API’s did the same. However, that is witholding the information — we can and we will give user more: where each heads and tails start and end. Also, we are going to abolish this separation of heads and tails into two arrays. Each heads/tails set will be sitting in a plain object. They are both pieces of a single set. That’s why they belong together.
Example result of v.1
API:
[
[3, 15],
[9, 21],
];
now the same example in v.2
API:
[
{
headsStartAt: 3,
headsEndAt: 6,
tailsStartAt: 9,
tailsEndAt: 12,
},
{
headsStartAt: 15,
headsEndAt: 18,
tailsStartAt: 21,
tailsEndAt: 24,
},
];
1.0.0
22 Dec 2017
- First public release