Our combined changelog and roadmap. It contains todos as well as dones.
Only project-wide changes are mentioned here. For individual function changelogs, please refer to their
respective Git histories.
Locutus does not follow SemVer as we're a work in progress - and even though we try,
we cannot guarantee BC-safety for the hundreds of contributions across the many
languages that Locutus is assimilating.
Instead, we recommend using version pinning, and inspect changes for the few particular functions you rely on
when you upgrade.
Backlog
Ideas that will be planned and find their way into a release at one point
[ ] Address the 25 remaining test failures that are currently skipped (find out which ones via npm run test:languages:noskip)
[ ] Compare example test cases for PHP against php -r to make sure they are correctly mimicking the most recent stable behavior
[ ] Have one way of checking pure JS arrays vs PHP arrays (vs: Object.prototype.toString.call(arr1) === '[object Array]', typeof retObj[p] === 'object', var asString = Object.prototype.toString.call(mixedVar) var asFunc = _getFuncName(mixedVar.constructor) if (asString === '[object Object]' && asFunc === 'Object') { )
[ ] Investigate if we can have one helper function for intersecting, and use that in all array_*diff* and array_*sort* functions. Refrain from using labels, which those functions currently still rely on
[ ] Investigate if we can have one helper function for sorting, and use that in all *sort* functions
[ ] Investigate if we can have one helper function to resolve Function/'function'/'Class::function'/[$object, 'function'], and use that in is_callable, array_walk, call_user_func_array etc.
[ ] Parse requires with AST just like Browserify does. Then we can add dependencies back to website
[ ] Port a few more tricky/inter-depending Go functions
[ ] Port a few more tricky/inter-depending Python functions
[ ] Port a few more tricky/inter-depending Ruby functions
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
- `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
- `@dependabot use these labels` will set the current labels as the default for future PRs for this repo and language
- `@dependabot use these reviewers` will set the current reviewers as the default for future PRs for this repo and language
- `@dependabot use these assignees` will set the current assignees as the default for future PRs for this repo and language
- `@dependabot use this milestone` will set the current milestone as the default for future PRs for this repo and language
You can disable automated security fix PRs for this repo from the [Security Alerts page](https://github.com/rapidpro/chpro-microsite/network/alerts).
Bumps locutus from 2.0.9 to 2.0.14.
Changelog
Sourced from locutus's changelog.
... (truncated)
Commits
ad17cd9
Release 2.0.145345e9c
warn that it's emulating php-on-linux (#424)406a4bc
refuse to escape strings with null bytes (#425)ea93f5b
Release 2.0.13a05e9e7
patch CVE-2020-13619 (#426)dd073d6
Unserialize reimplemented (#412)916f5b4
Merge pull request #422 from tcandens/bug/php-unserialize3b1a785
clean up test1d08e4f
use another case instead of normalizing datatype210a91c
fix(php/unserialize): data type to lowercaseDependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting
@dependabot rebase
.Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) - `@dependabot use these labels` will set the current labels as the default for future PRs for this repo and language - `@dependabot use these reviewers` will set the current reviewers as the default for future PRs for this repo and language - `@dependabot use these assignees` will set the current assignees as the default for future PRs for this repo and language - `@dependabot use this milestone` will set the current milestone as the default for future PRs for this repo and language You can disable automated security fix PRs for this repo from the [Security Alerts page](https://github.com/rapidpro/chpro-microsite/network/alerts).