Document application modes (development/debug/production) Add global file drop handler, order column normalization, SPA hash fix Serve CDN assets via /_vendor/ URLs instead of merging into bundles Add production minification with license preservation Improve JSON formatting for debugging and production optimization Add CDN asset caching with CSS URL inlining for production builds Add three-mode system (development, debug, production) Update Manifest CLAUDE.md to reflect helper class architecture Refactor Manifest.php into helper classes for better organization Pre-manifest-refactor checkpoint: Add app_mode documentation 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
90 lines
2.5 KiB
Markdown
Executable File
90 lines
2.5 KiB
Markdown
Executable File
# Javascript implementation of xxHash
|
|
|
|
## Synopsis
|
|
|
|
xxHash is a very fast hashing algorithm (see the details [here](https://code.google.com/p/xxhash/)). xxhashjs is a Javascript implementation of it, written in 100% Javascript. Although not as fast as the C version, it does perform pretty well given the current Javascript limitations in handling unsigned 32 bits integers.
|
|
|
|
|
|
## Installation
|
|
|
|
In nodejs:
|
|
|
|
npm install xxhashjs
|
|
|
|
In the browser, include the following, and access the constructor with _XXH_:
|
|
|
|
```javascript
|
|
<script src="/your/path/to/xxhash.js"></script>
|
|
```
|
|
|
|
|
|
## Examples
|
|
|
|
* In one step:
|
|
```javascript
|
|
var h = XXH.h32( 'abcd', 0xABCD ).toString(16) // seed = 0xABCD
|
|
```
|
|
> 0xCDA8FAE4
|
|
|
|
* In several steps (useful in conjunction of NodeJS streams):
|
|
```javascript
|
|
var H = XXH.h32( 0xABCD ) // seed = 0xABCD
|
|
var h = H.update( 'abcd' ).digest().toString(16)
|
|
```
|
|
> 0xCDA8FAE4
|
|
|
|
* More examples in the examples directory:
|
|
* Compute xxHash from a file data
|
|
* Use xxHashjs in the browser
|
|
|
|
|
|
## Usage
|
|
|
|
* XXH makes 2 functions available for 32 bits XXH and 64 bits XXH respectively, with the same signature:
|
|
|
|
* XXH.h32
|
|
* XXH.h64
|
|
|
|
* In one step:
|
|
`XXH.h32(<data>, <seed>)`
|
|
The data can either be a string, an ArrayBuffer or a NodeJS Buffer object.
|
|
The seed can either be a number or a UINT32 object.
|
|
|
|
* In several steps:
|
|
* instantiate a new XXH object H:
|
|
`XXH.h32(<seed>)` or `XXH.h32()`
|
|
The seed can be set later on with the `init` method
|
|
|
|
* add data to the hash calculation:
|
|
`H.update(<data>)`
|
|
|
|
* finish the calculations:
|
|
`H.digest()`
|
|
|
|
The object returned can be converted to a string with `toString(<radix>)` or a number `toNumber()`.
|
|
Once `digest()` has been called, the object can be reused. The same seed will be used or it can be changed with `init(<seed>)`.
|
|
|
|
|
|
## Methods
|
|
|
|
* `XXH.h32()`
|
|
* `.init(<seed>)`
|
|
Initialize the XXH object with the given seed. The seed can either be a number or a UINT32 object.
|
|
* `.update(<data>)`
|
|
Add data for hashing. The data can either be a string, an ArrayBuffer or a NodeJS Buffer object.
|
|
|
|
* `digest()` (_UINT32_)
|
|
Finalize the hash calculations and returns an UINT32 object. The hash value can be retrieved with toString(<radix>).
|
|
|
|
* `XXH.h64()`
|
|
* `.init(<seed>)`
|
|
Initialize the XXH object with the given seed. The seed can either be a number or a UINT64 object.
|
|
* `.update(<data>)`
|
|
Add data for hashing. The data can either be a string, an ArrayBuffer or a NodeJS Buffer object.
|
|
* `.digest()` (_UINT64_)
|
|
Finalize the hash calculations and returns an UINT64 object. The hash value can be retrieved with toString(<radix>).
|
|
|
|
|
|
## License
|
|
|
|
MIT |