Skip to content

Releases: usnistgov/jsfive

v0.4.0

08 Jan 20:19
Compare
Choose a tag to compare

What's Changed

Possibly breaking change:

if using a v2 filter pipeline, the filter parameters will now be found in filter_info.client_data instead of filter_info.client_data_values (consistent with the behavior of v1 filter pipelines)

Full Changelog: v0.3.14...v0.4.0

v0.3.14

30 Jan 16:02
Compare
Choose a tag to compare

Fixed

  • handling of chunked datasets when no data has been written yet (btree address not yet assigned)

v0.3.13

21 Oct 17:26
Compare
Choose a tag to compare

Fixed

  • handling of links when btree v2 is used but creation order is not specified

v0.3.12

19 Oct 18:56
Compare
Choose a tag to compare

Fixed

  • reading of V2 Btree nodes with node_level greater than 1 (deep trees)
  • handling of undefined group_order

v0.3.10

06 May 20:01
Compare
Choose a tag to compare

Changed

  • browser (IIFE) library moved to dist/browser/hdf5.js
  • ESM library moved to dist/esm/index.mjs

Added

  • CJS library added at dist/cjs/index.js

v0.3.9

02 May 16:01
Compare
Choose a tag to compare

Changed

  • Strings are all decoded with TextDecoder

Added

  • Minimal support for ENUMERATED datatype, using base type to read

Adding separate filters module

28 Jan 17:08
Compare
Choose a tag to compare

Changed

The filter pipeline is refactored to use a separate module (filters.js) from which a Filters map is exported. Users wanting to add their own filter implementation can do so by:

import * as hdf5 from "jsfive";

const filter_id = 12345; // filter identifier
const filter_fn(buf, itemsize, filter_params) {
  // do filter stuff here, return ArrayBuffer
}
hdf5.Filters.set(filter_id, filter_fn);

// then use as normal
var f = new hdf5.File(arrayBuffer, "my_file"); // ...

where the user filter function takes a single chunk of data as an ArrayBuffer and returns a processed ArrayBuffer. The itemsize parameter is for a single item of the datatype. The signature is:

type FilterFn = {
  (buf: ArrayBuffer, itemsize: number, filter_params: number[]): ArrayBuffer;
};

Remove dist artifacts

27 Jan 16:23
Compare
Choose a tag to compare

Changed

  • browser library built as IIFE
  • module compiled as ESM
  • no special import required for create-react-app, just use import * as hdf5 from 'jsfive';

Removed

  • all dist artifacts from git tracking - they will be attached as .tgz to release instead

Switch build from parcel2 to esbuild

19 Jan 15:26
Compare
Choose a tag to compare
  • Build process has been adjusted to use esbuild instead of parcel2, targeting es2020 for web
  • using pako instead of pako-es (there is now an ESM module available directly from pako)
  • removing the now-unused web_modules directory

Fix message lookup and support create-react-app

19 Aug 13:50
Compare
Choose a tag to compare

A bug was introduced when adding the BTree-V2 objects parsing: messages are read and stored with offsets relative to the global file buffer (unlike in pyfive) but the message-parsing functions were using addresses relative to the start of the message block (which is not collated in jsfive), and has been fixed.

Support for create-react-app has been added by pre-compiling the libraries with transforms for the class fields/properties. To use jsfive in this context you can npm i jsfive and then in App.js use

import * as hdf5 from 'jsfive/dist/index.js';