Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Javascript -- v1.2.0: Reimplement esm transpilation, and swap to it as the default. #479

Merged
merged 149 commits into from
Mar 17, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
149 commits
Select commit Hold shift + click to select a range
e0ce087
Add links to the devlog
Skenvy Sep 26, 2022
acbb5e5
Add the default package json
Skenvy Oct 3, 2022
d5bb46c
Merge branch 'main' into javascript
Skenvy Oct 12, 2022
1874a07
Merge branch 'main' into javascript
Skenvy Oct 12, 2022
58bd634
Add more details to the package.json
Skenvy Oct 15, 2022
a6f7b90
A lot of comments in the devlog
Skenvy Oct 16, 2022
bc115c2
Update the workflows and add some basic recipes and remove the exit 1…
Skenvy Oct 30, 2022
96ebaed
Add cache dependency path to subdir
Skenvy Oct 30, 2022
9ab638e
Remove caching in setup-node
Skenvy Oct 30, 2022
b82f5a5
Add dist download and single publish recipe
Skenvy Oct 30, 2022
da8652d
Uncomment publish-npm
Skenvy Oct 30, 2022
ae6bad9
Remove the NA placeholder password in the java-test workflow, codeQL …
Skenvy Oct 30, 2022
41d9c76
Merge branch 'main' into javascript
Skenvy Oct 31, 2022
9b5ee75
Fix the missing permssions for the nested codeql step and add them to…
Skenvy Oct 31, 2022
5ab3c1d
Merge branch 'main' into javascript
Skenvy Oct 31, 2022
b36cc65
Remove the trailing slash on the path, and add a release upload target
Skenvy Oct 31, 2022
165d125
Add a word to the package
Skenvy Oct 31, 2022
2867401
Merge branch 'main' into javascript
Skenvy Oct 31, 2022
5255579
Whoops, remove the clean off publish
Skenvy Oct 31, 2022
d80db40
Bump the package.json to trigger package file changed
Skenvy Oct 31, 2022
e71f36c
Merge branch 'main' into javascript
Skenvy Oct 31, 2022
ff21c00
Add missing permission for publishing a package to github
Skenvy Oct 31, 2022
d046f7c
Merge branch 'main' into javascript
Skenvy Oct 31, 2022
3118378
Add npm-gh reference in main readme
Skenvy Oct 31, 2022
8d4938a
Add module dichotomy paragraph to devlog
Skenvy Nov 5, 2022
e9632eb
Merge branch 'main' into javascript
Skenvy Nov 6, 2022
8711eda
Merge branch 'main' into javascript
Skenvy Jan 15, 2023
b5a2d7a
Add mention of typescript
Jan 15, 2023
99ec339
Added some typescript settings to run tsc for cjs and mjs
Jan 16, 2023
da486a0
Added mocha-chai test setup for unit test framework.
Mar 27, 2023
aacb7d9
Bump emojis
Skenvy Mar 27, 2023
b9bd9f5
Some further comments regarding the snyk guide
Skenvy Mar 27, 2023
ae56b7a
Bump version
Mar 27, 2023
20ad21c
Run pack to have the library up to date.
Mar 27, 2023
474a0a4
Merge branch 'main' into javascript
Mar 27, 2023
932d538
Merge branch 'main' into javascript
Skenvy Apr 7, 2023
9f521d5
WIP fuse together snippets from the julia, java, and python implement…
Apr 8, 2023
64d01b9
Print the first layer of deps installed in ci
Apr 8, 2023
d86d59d
Change the minimum node version to 14.
Apr 8, 2023
48822a6
Update engine requires and install eslint
Apr 9, 2023
fb3dbe8
Add a linting step to CI (this push will fail on linting)
Apr 9, 2023
3dc78fd
Try adding AirBnB eslint config
Apr 9, 2023
24f9b9a
Fix test issue (lint will fail)
Apr 9, 2023
08340a1
Fewer linting errors
Apr 10, 2023
3b0eb60
Linter only warning now.
Apr 10, 2023
dd008ae
Format devlog
Apr 10, 2023
d508e6a
Add the reverse function
Apr 10, 2023
9d2793c
Tested and linted the reverse function
Apr 10, 2023
c2602fd
Add a recipe to fail if the checked in JS mismatches with the checked…
Apr 10, 2023
440b71b
Clean before the new verify
Apr 10, 2023
ebd3d00
Comment about docs gene
Apr 10, 2023
3674010
Install typedoc and tsdoc lint
Apr 10, 2023
ac99b63
Add tsdoc linter and try to make comments tsdoc-ish
Apr 10, 2023
70bb9ff
Recipe for docs
Apr 10, 2023
5eeae0a
Less cleaning when doccing
Apr 10, 2023
4516a92
Comment on attempt at JSDoc
Skenvy Apr 10, 2023
d685d32
Comment about setting up the docs target branch
Apr 10, 2023
f3e7d35
Bump up the version to test the whole CICD for javascript, with the f…
Apr 10, 2023
0288570
Retranspile the js files
Apr 10, 2023
2b87172
Add the devDependencies to the docs step
Skenvy Apr 10, 2023
515fec8
Stop windows from corrupting the line endings that eslint requires
Skenvy Apr 10, 2023
c971d61
Merge branch 'main' into javascript
Skenvy Apr 11, 2023
c078d06
Merge branch 'main' into javascript
Skenvy Apr 25, 2023
c7c279e
Add words to the readme
Apr 25, 2023
d1edc65
yike the lock
Apr 25, 2023
2944619
Up the node version in CI to one that bumps npm over 8.6
Apr 25, 2023
0ba765c
version
Apr 25, 2023
57aa219
Merge branch 'main' into javascript
Skenvy Apr 25, 2023
a49b99c
Merge branch 'main' into javascript
Jun 22, 2023
b3a8d9e
npm up
Jun 22, 2023
9085688
Add stoppingTimeTerminus
Jun 22, 2023
086bf17
transpile
Jun 22, 2023
5770593
wip adding hailstone
Jun 22, 2023
4fbecdf
transpile
Jun 22, 2023
35dc605
Add make for http-server and comment regarding __namedParameters
Jun 24, 2023
57c82b0
Swap from a named interface to anonymous interfaces i.e. object liter…
Jun 25, 2023
2bb5004
line length
Jun 25, 2023
b5cbbfb
WIP tests for hailstone sequence
Jun 25, 2023
2153c0f
WIP tests for hailstone sequence
Jun 25, 2023
70f380c
Finished testing hailstones
Jun 25, 2023
d0ee908
Bump to 0.4.0
Skenvy Jun 25, 2023
d9b6e33
Merge branch 'main' into javascript
Skenvy Jun 25, 2023
982d1c4
Stopping Time
Jun 26, 2023
21bb328
split into multiple files
Jun 26, 2023
9de2615
cutover to multiple files, tests and lints work
Jun 26, 2023
9e02a65
Add coverage reports being generated into docs
Jun 26, 2023
c14422f
coverage report handled
Jun 26, 2023
b5d22e8
pkg and lib
Jun 26, 2023
7576741
Merge branch 'main' into javascript
Skenvy Jun 27, 2023
e068ede
WIP tree graph
Jun 27, 2023
5a8a23e
assign the provided empty map in the test tgn's
Jun 27, 2023
89d7fcb
swap tgn to subtree
Skenvy Jun 27, 2023
93c102b
Set up the deep equals test for tree graph
Skenvy Jun 28, 2023
5a8904f
test, lint, and verify
Skenvy Jun 28, 2023
a63ba77
bump checkout
Skenvy Jun 28, 2023
b2c3de6
Add cache, add a basic stub for demos, and add comments regarding deno
Skenvy Jun 28, 2023
dfdb501
fix wf default and add node types to demo
Skenvy Jun 28, 2023
2d953d3
fix name of needed wf job
Skenvy Jun 28, 2023
ddf96f1
dot the demo folder
Skenvy Jun 28, 2023
8ef25e5
pkg
Jun 28, 2023
6275e19
Does setting up node with the development version fix npm not running…
Skenvy Jun 28, 2023
113113a
ok, ls the dir first, but also see if strip version manually works
Skenvy Jun 28, 2023
4a43ef9
but without another thing running first it doesn't run preinstall??
Skenvy Jun 29, 2023
f554f19
Does changing from preinstall to prepare let it know to run before th…
Skenvy Jun 29, 2023
10c6ea3
Does using the full name 'install' fix it?
Skenvy Jun 29, 2023
4ec9dd8
ok clearly lifecycle scripts are fucked
Skenvy Jun 29, 2023
8066106
Add ts demos
Jun 29, 2023
fe3ffbc
remove spaces
Jun 29, 2023
7f6dcc9
bump package to first major version
Jun 29, 2023
34fde4c
Merge branch 'main' into javascript
Skenvy Jun 29, 2023
002838f
Merge branch 'main' into javascript
Skenvy Jul 5, 2023
1f2a3f1
Stop testing node on version 17 and 19
Jul 5, 2023
cbd0b4a
Merge branch 'main' into javascript
Nov 2, 2023
022eb13
Set new minor release to update allowed engines
Nov 2, 2023
db578bc
Add wraps in the make to preempt nvm use on every npm command
Nov 2, 2023
b0c0425
Add overwrite of the nvmrc for the test steps
Nov 2, 2023
3d963bf
put install recipes in conditional make vars to not use nvm on windows
Nov 2, 2023
bf0d331
Merge branch 'main' into javascript
Skenvy Nov 2, 2023
8dd8255
Install nvm and npm versions before using make publish
Nov 2, 2023
ce7066b
Merge branch 'main' into javascript
Skenvy Mar 15, 2024
bfc5f87
Merge branch 'main' into javascript
Skenvy Mar 15, 2024
6fb3992
Merge branch 'main' into javascript
Skenvy Mar 15, 2024
19d82a9
Ran npm i on the unchanged package
Skenvy Mar 16, 2024
420f022
Bump mocha, @types/mocha, @types/node
Skenvy Mar 16, 2024
9c820c4
Bump everything except chai
Skenvy Mar 16, 2024
62b89d6
Bump chai to latest 4.x
Skenvy Mar 16, 2024
616dd0d
Merge branch 'main' into javascript
Skenvy Mar 16, 2024
248f85a
Bump chai to latest
Skenvy Mar 16, 2024
9dbd209
Add a node-options loader to use esm with mocha
Skenvy Mar 16, 2024
a91a610
wip trying different things to let chai v5
Skenvy Mar 16, 2024
00a11a8
Remove the attempt to make chai v5 work
Skenvy Mar 16, 2024
61297bf
very WIP, writing about this ridiculous ecosystem
Skenvy Mar 16, 2024
197dea7
demo to assert imports of the project work
Skenvy Mar 16, 2024
31b144e
Add back the previous copy of the transpiled result so there's less d…
Skenvy Mar 16, 2024
034408a
Remove the src and tests changes to record what the errors were
Skenvy Mar 16, 2024
e65684f
Revert all the things done to fix issues to replay the errors
Skenvy Mar 16, 2024
1dd284a
make build works
Skenvy Mar 16, 2024
e3f112f
added more specificity to the demo steps, wip mjs'ing and cjs'ing the…
Skenvy Mar 17, 2024
ce86c20
the project is buildable and the demo runs!
Skenvy Mar 17, 2024
007574f
use esm tsconf for docs
Skenvy Mar 17, 2024
65a93ef
fix ems -> esm and add use of mocha tsconf in covr
Skenvy Mar 17, 2024
7326064
Update setup-node action
Skenvy Mar 17, 2024
8cc3f60
update the version
Skenvy Mar 17, 2024
56a0ea7
fixed the ems -> esm typo in the demo package
Skenvy Mar 17, 2024
c377197
Change the demo test to use the new npm script names
Skenvy Mar 17, 2024
2f1294e
Add cross-env to let the test script continue to work on windows
Skenvy Mar 17, 2024
b1164e3
Add eol spec to gitattr to stop windows runners from not liking the n…
Skenvy Mar 17, 2024
277773d
Does changing package json to autocrlf fix the windows runner not lik…
Skenvy Mar 17, 2024
10f3f1a
Just don't bother with verifying the lib checkin on the matrix of run…
Skenvy Mar 17, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fewer linting errors
  • Loading branch information
Skenvy committed Apr 10, 2023
commit 08340a1d3f7c0120956d0963d2089f01c5513852
14 changes: 13 additions & 1 deletion javascript/.eslintrc
Original file line number Diff line number Diff line change
Expand Up @@ -10,5 +10,17 @@
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"airbnb"
]
],
"rules": {
"max-len": ["error", { "code": 200 }],
"@typescript-eslint/no-inferrable-types": 0,
"no-unused-vars": 0,
"@typescript-eslint/no-unused-vars": 1,
"no-shadow": 0,
"@typescript-eslint/no-shadow": 2,
"object-curly-newline": ["error", {
"ObjectExpression": { "consistent": true },
"ObjectPattern": { "consistent": true }
}]
}
}
8 changes: 8 additions & 0 deletions javascript/devlog.md
Original file line number Diff line number Diff line change
Expand Up @@ -134,3 +134,11 @@ Secondary to the `.eslintrc.*` file, we can also add a `.eslintignore` to preven
I was temporarily confused as I also tried to run `eslint .` without `npx` as some sites offer in snippets, and it was not working. I was relying on the assumption that because my devDependency of TypeScript allows me to use `tsc` in the `scripts` that can be used with `npm run ...` I should be able to also use ESLint in a similar manner, but was only trying to do so in my terminal rather than adding it to my `scripts`. It took a while of googling around to stumble on [the simple answer](https://docs.npmjs.com/cli/v8/commands/npm-run-script?v=true) that `./node_modules/.bin`, which contains these invocable scripts, is added to the `PATH` when invoking `npm run ...`. Sure enough, `tsc` which has been working for while in my `npm run ...`'s also does not work as "just" `tsc` outside of `npm run ...`. So we can easily add an `npm run ...` that will use the version installed by the package lock. So we can now simply use an `npm run lint`.

As we've followed the instructions up until here, we'll swap to the recommendations of [this blog](https://khalilstemmler.com/blogs/typescript/eslint-for-typescript/), as it uses json for the `.eslintrc`, and provides an explanation for adding "rules" to it. We can also use this to try and add [Airbnb's .eslintrc](https://www.npmjs.com/package/eslint-config-airbnb). We'll use `npx install-peerdeps --dev eslint-config-airbnb`, which generates the "peerDeps" installation command `npm install eslint-config-airbnb@19.0.4 eslint@^8.2.0 eslint-plugin-import@^2.25.3 eslint-plugin-jsx-a11y@^6.5.1 eslint-plugin-react@^7.28.0 eslint-plugin-react-hooks@^4.3.0 --save-dev`.

Well, now we've got some linting set up, and using an extensive collection of recommended rules, it's time to run it and iteratively see what I've done differently from what the [Airbnb's .eslintrc](https://www.npmjs.com/package/eslint-config-airbnb) recommends. These differences can be added as modifications to the sets of rules that are extended in the `./.eslintrc` through a `"rules"` map. One that I will definitely allow is [`object-curly-newline`](https://eslint.org/docs/latest/rules/object-curly-newline). Although [`no-underscore-dangle`](https://eslint.org/docs/latest/rules/no-underscore-dangle) is something that I've avoided changing where possible, I have removed the "private" underscores from some previous implementations. One that is was a slight problem was a bunch of lines in my `./tests/index.spec.ts` popping up with;
> 23:3 error 'it' is not defined no-undef

The [`no-undef`](https://eslint.org/docs/latest/rules/no-undef) error appears to be complaining that the `it` inside the function blocks of a `describe` (as well as the `describe` in other linter errors) are not declared and or defined. An answer on [this stackoverflow question](https://stackoverflow.com/a/38667441) provides the context and a link to some ESLint docs on [Specifying Environments](https://eslint.org/docs/latest/use/configure/language-options#specifying-environments) with the context being that there are _many_ environments, and;
> An environment provides predefined global variables.

Which means we can add a `/* eslint-env mocha */` comment at the top of our `./tests/index.spec.ts` and get rid of these errors.
48 changes: 24 additions & 24 deletions javascript/lib/cjs/index.js
Original file line number Diff line number Diff line change
@@ -1,37 +1,37 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.Function = exports.__assert_sane_parameterisation = exports._CC = exports.FailedSaneParameterCheck = exports._ErrMsg = exports.__VERIFIED_MINIMUM = exports.__VERIFIED_MAXIMUM = exports._KNOWN_CYCLES = void 0;
exports.Function = exports.assertSaneParameterisation = exports.SequenceState = exports.FailedSaneParameterCheck = exports.SaneParameterErrMsg = exports.VERIFIED_MINIMUM = exports.VERIFIED_MAXIMUM = exports.KNOWN_CYCLES = void 0;
// The four known cycles (besides 0->0), for the default parameterisation.
exports._KNOWN_CYCLES = [[1n, 4n, 2n], [-1n, -2n], [-5n, -14n, -7n, -20n, -10n],
exports.KNOWN_CYCLES = [[1n, 4n, 2n], [-1n, -2n], [-5n, -14n, -7n, -20n, -10n],
[-17n, -50n, -25n, -74n, -37n, -110n, -55n, -164n, -82n, -41n, -122n, -61n, -182n, -91n, -272n, -136n, -68n, -34n]];
// The value up to which has been proven numerically, for the default parameterisation."
exports.__VERIFIED_MAXIMUM = 295147905179352825856n;
exports.VERIFIED_MAXIMUM = 295147905179352825856n;
// The value down to which has been proven numerically, for the default parameterisation."
exports.__VERIFIED_MINIMUM = -272n; // TODO: Check the actual lowest bound.
exports.VERIFIED_MINIMUM = -272n; // TODO: Check the actual lowest bound.
// Error message constant.
var _ErrMsg;
(function (_ErrMsg) {
_ErrMsg["SANE_PARAMS_P"] = "'P' should not be 0 ~ violates modulo being non-zero.";
_ErrMsg["SANE_PARAMS_A"] = "'a' should not be 0 ~ violates the reversability.";
})(_ErrMsg = exports._ErrMsg || (exports._ErrMsg = {}));
var SaneParameterErrMsg;
(function (SaneParameterErrMsg) {
SaneParameterErrMsg["SANE_PARAMS_P"] = "'P' should not be 0 ~ violates modulo being non-zero.";
SaneParameterErrMsg["SANE_PARAMS_A"] = "'a' should not be 0 ~ violates the reversability.";
})(SaneParameterErrMsg = exports.SaneParameterErrMsg || (exports.SaneParameterErrMsg = {}));
class FailedSaneParameterCheck extends Error {
constructor(message) {
super(message);
this.name = "FailedSaneParameterCheck";
this.name = 'FailedSaneParameterCheck';
}
}
exports.FailedSaneParameterCheck = FailedSaneParameterCheck;
// Cycle Control: Descriptive flags to indicate when some event occurs in the
// hailstone sequences, when set to verbose, or stopping time check.
var _CC;
(function (_CC) {
_CC["STOPPING_TIME"] = "STOPPING_TIME";
_CC["TOTAL_STOPPING_TIME"] = "TOTAL_STOPPING_TIME";
_CC["CYCLE_INIT"] = "CYCLE_INIT";
_CC["CYCLE_LENGTH"] = "CYCLE_LENGTH";
_CC["MAX_STOP_OUT_OF_BOUNDS"] = "MAX_STOP_OUT_OF_BOUNDS";
_CC["ZERO_STOP"] = "ZERO_STOP";
})(_CC = exports._CC || (exports._CC = {}));
var SequenceState;
(function (SequenceState) {
SequenceState["STOPPING_TIME"] = "STOPPING_TIME";
SequenceState["TOTAL_STOPPING_TIME"] = "TOTAL_STOPPING_TIME";
SequenceState["CYCLE_INIT"] = "CYCLE_INIT";
SequenceState["CYCLE_LENGTH"] = "CYCLE_LENGTH";
SequenceState["MAX_STOP_OUT_OF_BOUNDS"] = "MAX_STOP_OUT_OF_BOUNDS";
SequenceState["ZERO_STOP"] = "ZERO_STOP";
})(SequenceState = exports.SequenceState || (exports.SequenceState = {}));
// """
// Handles the sanity check for the parameterisation (P,a,b) required by both
// the function and reverse function.
Expand All @@ -40,7 +40,7 @@ var _CC;
// a (bigint): Factor by which to multiply n.
// b (bigint): Value to add to the scaled value of n.
// """
function __assert_sane_parameterisation(P, a, b) {
function assertSaneParameterisation(P, a, b) {
// Sanity check (P,a,b) ~ P absolutely can't be 0. a "could" be zero
// theoretically, although would violate the reversability (if ~a is 0 then a
// value of "b" as the input to the reverse function would have a pre-emptive
Expand All @@ -55,13 +55,13 @@ function __assert_sane_parameterisation(P, a, b) {
// function, but would not violate the reversability, so no check either.
// " != 0" is redundant for python assertions.
if (P === 0n) {
throw new FailedSaneParameterCheck(_ErrMsg.SANE_PARAMS_P);
throw new FailedSaneParameterCheck(SaneParameterErrMsg.SANE_PARAMS_P);
}
if (a === 0n) {
throw new FailedSaneParameterCheck(_ErrMsg.SANE_PARAMS_A);
throw new FailedSaneParameterCheck(SaneParameterErrMsg.SANE_PARAMS_A);
}
}
exports.__assert_sane_parameterisation = __assert_sane_parameterisation;
exports.assertSaneParameterisation = assertSaneParameterisation;
// """
// Returns the output of a single application of a Collatz-esque function.
// Args:
Expand All @@ -73,7 +73,7 @@ exports.__assert_sane_parameterisation = __assert_sane_parameterisation;
// b (bigint): Value to add to the scaled value of n. Default is 1.
// """
function Function({ n, P = 2n, a = 3n, b = 1n }) {
__assert_sane_parameterisation(P, a, b);
assertSaneParameterisation(P, a, b);
return n % P === 0n ? n / P : (a * n + b);
}
exports.Function = Function;
Expand Down
14 changes: 7 additions & 7 deletions javascript/lib/cjs/types/index.d.ts
Original file line number Diff line number Diff line change
@@ -1,22 +1,22 @@
export declare const _KNOWN_CYCLES: bigint[][];
export declare const __VERIFIED_MAXIMUM: bigint;
export declare const __VERIFIED_MINIMUM: bigint;
export declare enum _ErrMsg {
export declare const KNOWN_CYCLES: bigint[][];
export declare const VERIFIED_MAXIMUM: bigint;
export declare const VERIFIED_MINIMUM: bigint;
export declare enum SaneParameterErrMsg {
SANE_PARAMS_P = "'P' should not be 0 ~ violates modulo being non-zero.",
SANE_PARAMS_A = "'a' should not be 0 ~ violates the reversability."
}
export declare class FailedSaneParameterCheck extends Error {
constructor(message: _ErrMsg);
constructor(message: SaneParameterErrMsg);
}
export declare enum _CC {
export declare enum SequenceState {
STOPPING_TIME = "STOPPING_TIME",
TOTAL_STOPPING_TIME = "TOTAL_STOPPING_TIME",
CYCLE_INIT = "CYCLE_INIT",
CYCLE_LENGTH = "CYCLE_LENGTH",
MAX_STOP_OUT_OF_BOUNDS = "MAX_STOP_OUT_OF_BOUNDS",
ZERO_STOP = "ZERO_STOP"
}
export declare function __assert_sane_parameterisation(P: bigint, a: bigint, b: bigint): void;
export declare function assertSaneParameterisation(P: bigint, a: bigint, b: bigint): void;
export interface Parameterised {
n: bigint;
P?: bigint;
Expand Down
2 changes: 1 addition & 1 deletion javascript/lib/cjs/types/index.d.ts.map

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

44 changes: 22 additions & 22 deletions javascript/lib/esm/index.mjs
Original file line number Diff line number Diff line change
@@ -1,33 +1,33 @@
// The four known cycles (besides 0->0), for the default parameterisation.
export const _KNOWN_CYCLES = [[1n, 4n, 2n], [-1n, -2n], [-5n, -14n, -7n, -20n, -10n],
export const KNOWN_CYCLES = [[1n, 4n, 2n], [-1n, -2n], [-5n, -14n, -7n, -20n, -10n],
[-17n, -50n, -25n, -74n, -37n, -110n, -55n, -164n, -82n, -41n, -122n, -61n, -182n, -91n, -272n, -136n, -68n, -34n]];
// The value up to which has been proven numerically, for the default parameterisation."
export const __VERIFIED_MAXIMUM = 295147905179352825856n;
export const VERIFIED_MAXIMUM = 295147905179352825856n;
// The value down to which has been proven numerically, for the default parameterisation."
export const __VERIFIED_MINIMUM = -272n; // TODO: Check the actual lowest bound.
export const VERIFIED_MINIMUM = -272n; // TODO: Check the actual lowest bound.
// Error message constant.
export var _ErrMsg;
(function (_ErrMsg) {
_ErrMsg["SANE_PARAMS_P"] = "'P' should not be 0 ~ violates modulo being non-zero.";
_ErrMsg["SANE_PARAMS_A"] = "'a' should not be 0 ~ violates the reversability.";
})(_ErrMsg || (_ErrMsg = {}));
export var SaneParameterErrMsg;
(function (SaneParameterErrMsg) {
SaneParameterErrMsg["SANE_PARAMS_P"] = "'P' should not be 0 ~ violates modulo being non-zero.";
SaneParameterErrMsg["SANE_PARAMS_A"] = "'a' should not be 0 ~ violates the reversability.";
})(SaneParameterErrMsg || (SaneParameterErrMsg = {}));
export class FailedSaneParameterCheck extends Error {
constructor(message) {
super(message);
this.name = "FailedSaneParameterCheck";
this.name = 'FailedSaneParameterCheck';
}
}
// Cycle Control: Descriptive flags to indicate when some event occurs in the
// hailstone sequences, when set to verbose, or stopping time check.
export var _CC;
(function (_CC) {
_CC["STOPPING_TIME"] = "STOPPING_TIME";
_CC["TOTAL_STOPPING_TIME"] = "TOTAL_STOPPING_TIME";
_CC["CYCLE_INIT"] = "CYCLE_INIT";
_CC["CYCLE_LENGTH"] = "CYCLE_LENGTH";
_CC["MAX_STOP_OUT_OF_BOUNDS"] = "MAX_STOP_OUT_OF_BOUNDS";
_CC["ZERO_STOP"] = "ZERO_STOP";
})(_CC || (_CC = {}));
export var SequenceState;
(function (SequenceState) {
SequenceState["STOPPING_TIME"] = "STOPPING_TIME";
SequenceState["TOTAL_STOPPING_TIME"] = "TOTAL_STOPPING_TIME";
SequenceState["CYCLE_INIT"] = "CYCLE_INIT";
SequenceState["CYCLE_LENGTH"] = "CYCLE_LENGTH";
SequenceState["MAX_STOP_OUT_OF_BOUNDS"] = "MAX_STOP_OUT_OF_BOUNDS";
SequenceState["ZERO_STOP"] = "ZERO_STOP";
})(SequenceState || (SequenceState = {}));
// """
// Handles the sanity check for the parameterisation (P,a,b) required by both
// the function and reverse function.
Expand All @@ -36,7 +36,7 @@ export var _CC;
// a (bigint): Factor by which to multiply n.
// b (bigint): Value to add to the scaled value of n.
// """
export function __assert_sane_parameterisation(P, a, b) {
export function assertSaneParameterisation(P, a, b) {
// Sanity check (P,a,b) ~ P absolutely can't be 0. a "could" be zero
// theoretically, although would violate the reversability (if ~a is 0 then a
// value of "b" as the input to the reverse function would have a pre-emptive
Expand All @@ -51,10 +51,10 @@ export function __assert_sane_parameterisation(P, a, b) {
// function, but would not violate the reversability, so no check either.
// " != 0" is redundant for python assertions.
if (P === 0n) {
throw new FailedSaneParameterCheck(_ErrMsg.SANE_PARAMS_P);
throw new FailedSaneParameterCheck(SaneParameterErrMsg.SANE_PARAMS_P);
}
if (a === 0n) {
throw new FailedSaneParameterCheck(_ErrMsg.SANE_PARAMS_A);
throw new FailedSaneParameterCheck(SaneParameterErrMsg.SANE_PARAMS_A);
}
}
// """
Expand All @@ -68,7 +68,7 @@ export function __assert_sane_parameterisation(P, a, b) {
// b (bigint): Value to add to the scaled value of n. Default is 1.
// """
export function Function({ n, P = 2n, a = 3n, b = 1n }) {
__assert_sane_parameterisation(P, a, b);
assertSaneParameterisation(P, a, b);
return n % P === 0n ? n / P : (a * n + b);
}
export default {
Expand Down
14 changes: 7 additions & 7 deletions javascript/lib/esm/types/index.d.ts
Original file line number Diff line number Diff line change
@@ -1,22 +1,22 @@
export declare const _KNOWN_CYCLES: bigint[][];
export declare const __VERIFIED_MAXIMUM: bigint;
export declare const __VERIFIED_MINIMUM: bigint;
export declare enum _ErrMsg {
export declare const KNOWN_CYCLES: bigint[][];
export declare const VERIFIED_MAXIMUM: bigint;
export declare const VERIFIED_MINIMUM: bigint;
export declare enum SaneParameterErrMsg {
SANE_PARAMS_P = "'P' should not be 0 ~ violates modulo being non-zero.",
SANE_PARAMS_A = "'a' should not be 0 ~ violates the reversability."
}
export declare class FailedSaneParameterCheck extends Error {
constructor(message: _ErrMsg);
constructor(message: SaneParameterErrMsg);
}
export declare enum _CC {
export declare enum SequenceState {
STOPPING_TIME = "STOPPING_TIME",
TOTAL_STOPPING_TIME = "TOTAL_STOPPING_TIME",
CYCLE_INIT = "CYCLE_INIT",
CYCLE_LENGTH = "CYCLE_LENGTH",
MAX_STOP_OUT_OF_BOUNDS = "MAX_STOP_OUT_OF_BOUNDS",
ZERO_STOP = "ZERO_STOP"
}
export declare function __assert_sane_parameterisation(P: bigint, a: bigint, b: bigint): void;
export declare function assertSaneParameterisation(P: bigint, a: bigint, b: bigint): void;
export interface Parameterised {
n: bigint;
P?: bigint;
Expand Down
2 changes: 1 addition & 1 deletion javascript/lib/esm/types/index.d.ts.map

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading