
Security News
/Research
Wallet-Draining npm Package Impersonates Nodemailer to Hijack Crypto Transactions
Malicious npm package impersonates Nodemailer and drains wallets by hijacking crypto transactions across multiple blockchains.
@compassdigital/combine-lists
Advanced tools
Merge two lists, trying to preserve the order of both
This tool merges two lists, removing duplicates, and doing everything possible to maintain the order of the two lists.
This tool guarantees that the order of the first list is preserved (that is, if x comes before y in the first list, x comes before y in the returned list) and tries not to undo the order of the second list, though sometimes it is unavoidable.
For example, if we have list1 = [1, 2, 4]
and list2 = [2, 1, 3, 4]
, then the
merged list would be [1, 2, 3, 4]
, since that preserves the order of list1
while doing the best job possible of preserving the order of list2
.
A case like list1 = [1, 3]
, list2 = [3, 2, 1]
is more complicated. It's not
clear what the best merged list is, but it's probably either [2, 1, 3]
or
[1, 3, 2]
.
In general, it's not totally clear what the "best" merged list is, but there are some basic properties that anyone would expect:
list2[i]
is not in list1
, and it is possible to insert list2[i]
into
list1
without contradicting the order of list2
, then it should be inserted
in such a wayThis tool is very slow, crossing the 100ms mark with lists around 150 in length,
and growing at a rate of
O(list2.length*list2.length*(list1.length + list2.length))
from there.
Install with
npm install combine-lists
Use like so:
var combineLists = require('combine-lists');
combineLists([1, 2], [2, 3]); // [1, 2, 3]
FAQs
Merge two lists, trying to preserve the order of both
The npm package @compassdigital/combine-lists receives a total of 0 weekly downloads. As such, @compassdigital/combine-lists popularity was classified as not popular.
We found that @compassdigital/combine-lists demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 10 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
/Research
Malicious npm package impersonates Nodemailer and drains wallets by hijacking crypto transactions across multiple blockchains.
Security News
This episode explores the hard problem of reachability analysis, from static analysis limits to handling dynamic languages and massive dependency trees.
Security News
/Research
Malicious Nx npm versions stole secrets and wallet info using AI CLI tools; Socket’s AI scanner detected the supply chain attack and flagged the malware.