@duckdb/duckdb-wasm 1.13.1-dev98.0 → 1.14.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/README.md +68 -4
  2. package/dist/duckdb-browser-blocking.cjs +15 -45
  3. package/dist/duckdb-browser-blocking.cjs.map +3 -3
  4. package/dist/duckdb-browser-blocking.mjs +15 -45
  5. package/dist/duckdb-browser-blocking.mjs.map +3 -3
  6. package/dist/duckdb-browser-coi.pthread.worker.js +14 -43
  7. package/dist/duckdb-browser-coi.pthread.worker.js.map +3 -3
  8. package/dist/duckdb-browser-coi.worker.js +18 -25
  9. package/dist/duckdb-browser-coi.worker.js.map +3 -3
  10. package/dist/duckdb-browser-eh.worker.js +16 -23
  11. package/dist/duckdb-browser-eh.worker.js.map +3 -3
  12. package/dist/duckdb-browser-mvp.worker.js +18 -25
  13. package/dist/duckdb-browser-mvp.worker.js.map +3 -3
  14. package/dist/duckdb-browser.cjs +1 -31
  15. package/dist/duckdb-browser.cjs.map +3 -3
  16. package/dist/duckdb-browser.mjs +1 -31
  17. package/dist/duckdb-browser.mjs.map +3 -3
  18. package/dist/duckdb-coi.wasm +0 -0
  19. package/dist/duckdb-eh.wasm +0 -0
  20. package/dist/duckdb-mvp.wasm +0 -0
  21. package/dist/duckdb-node-blocking.cjs +4 -4
  22. package/dist/duckdb-node-blocking.cjs.map +3 -3
  23. package/dist/duckdb-node-eh.worker.cjs +4 -4
  24. package/dist/duckdb-node-eh.worker.cjs.map +3 -3
  25. package/dist/duckdb-node-mvp.worker.cjs +3 -3
  26. package/dist/duckdb-node-mvp.worker.cjs.map +3 -3
  27. package/dist/duckdb-node.cjs +1 -1
  28. package/dist/duckdb-node.cjs.map +3 -3
  29. package/dist/img/duckdb.svg +8 -0
  30. package/dist/img/duckdb_version_badge.svg +1 -1
  31. package/dist/tests-browser.js +12905 -16221
  32. package/dist/tests-browser.js.map +3 -3
  33. package/dist/tests-node.cjs +1820 -1588
  34. package/dist/tests-node.cjs.map +3 -3
  35. package/dist/types/src/bindings/config.d.ts +0 -2
  36. package/dist/types/src/bindings/insert_options.d.ts +3 -3
  37. package/dist/types/src/bindings/progress.d.ts +1 -0
  38. package/dist/types/src/bindings/runtime.d.ts +1 -1
  39. package/dist/types/src/bindings/udf_function.d.ts +2 -2
  40. package/dist/types/src/bindings/udf_runtime.d.ts +1 -1
  41. package/dist/types/src/json_typedef.d.ts +17 -0
  42. package/dist/types/src/log.d.ts +2 -0
  43. package/dist/types/src/platform.d.ts +3 -0
  44. package/dist/types/src/targets/duckdb-browser-blocking.d.ts +1 -0
  45. package/dist/types/src/targets/duckdb-node-blocking.d.ts +1 -0
  46. package/dist/types/src/targets/duckdb.d.ts +1 -0
  47. package/dist/types/src/utils/s3_helper.d.ts +1 -0
  48. package/package.json +24 -24
  49. package/dist/types/src/flat_arrow.d.ts +0 -15
@@ -9,12 +9,10 @@ export interface DuckDBQueryConfig {
9
9
  castTimestampToDate?: boolean;
10
10
  /**
11
11
  * Cast Timestamp to Date64?
12
- * Note that this is currently enabled by default
13
12
  */
14
13
  castDurationToTime64?: boolean;
15
14
  /**
16
15
  * Cast Decimal to Double?
17
- * Note that casting decimals to floating point respresentation will have impre
18
16
  */
19
17
  castDecimalToDouble?: boolean;
20
18
  }
@@ -1,5 +1,5 @@
1
1
  import * as arrow from 'apache-arrow';
2
- import { FlatArrowField } from '../flat_arrow';
2
+ import { SQLField } from '../json_typedef';
3
3
  export declare enum JSONTableShape {
4
4
  ROW_ARRAY = "row-array",
5
5
  COLUMN_OBJECT = "column-object"
@@ -12,7 +12,7 @@ export interface JSONInsertOptions {
12
12
  columns?: {
13
13
  [key: string]: arrow.DataType;
14
14
  };
15
- columnsFlat?: FlatArrowField[];
15
+ columnsFlat?: SQLField[];
16
16
  }
17
17
  export interface CSVInsertOptions {
18
18
  name: string;
@@ -29,7 +29,7 @@ export interface CSVInsertOptions {
29
29
  columns?: {
30
30
  [key: string]: arrow.DataType;
31
31
  };
32
- columnsFlat?: FlatArrowField[];
32
+ columnsFlat?: SQLField[];
33
33
  }
34
34
  export interface ArrowInsertOptions {
35
35
  name: string;
@@ -1,6 +1,7 @@
1
1
  /** An instantiation progress */
2
2
  export interface InstantiationProgress {
3
3
  startedAt: Date;
4
+ updatedAt: Date;
4
5
  bytesTotal: number;
5
6
  bytesLoaded: number;
6
7
  }
@@ -74,6 +74,6 @@ export interface DuckDBRuntime {
74
74
  moveFile(mod: DuckDBModule, fromPtr: number, fromLen: number, toPtr: number, toLen: number): void;
75
75
  checkFile(mod: DuckDBModule, pathPtr: number, pathLen: number): boolean;
76
76
  removeFile(mod: DuckDBModule, pathPtr: number, pathLen: number): void;
77
- callScalarUDF(mod: DuckDBModule, response: number, funcId: number, bufferPtr: number, bufferSize: number): void;
77
+ callScalarUDF(mod: DuckDBModule, response: number, funcId: number, descPtr: number, descSize: number, ptrsPtr: number, ptrsSize: number): void;
78
78
  }
79
79
  export declare const DEFAULT_RUNTIME: DuckDBRuntime;
@@ -1,9 +1,9 @@
1
- import { FlatArrowType } from '../flat_arrow';
1
+ import { SQLType } from '../json_typedef';
2
2
  import * as arrow from 'apache-arrow';
3
3
  export interface UDFFunctionDeclaration {
4
4
  functionId: number;
5
5
  name: string;
6
- returnType: FlatArrowType;
6
+ returnType: SQLType;
7
7
  }
8
8
  export interface UDFFunction {
9
9
  functionId: number;
@@ -1,3 +1,3 @@
1
1
  import { DuckDBRuntime } from './runtime';
2
2
  import { DuckDBModule } from './duckdb_module';
3
- export declare function callScalarUDF(runtime: DuckDBRuntime, mod: DuckDBModule, response: number, funcId: number, bufferPtr: number, bufferSize: number): void;
3
+ export declare function callScalarUDF(runtime: DuckDBRuntime, mod: DuckDBModule, response: number, funcId: number, descPtr: number, descSize: number, ptrsPtr: number, ptrsSize: number): void;
@@ -0,0 +1,17 @@
1
+ import * as arrow from 'apache-arrow';
2
+ export interface SQLType {
3
+ sqlType: string;
4
+ nullable?: boolean;
5
+ precision?: number;
6
+ scale?: number;
7
+ timezone?: string;
8
+ byteWidth?: number;
9
+ keyType?: SQLType;
10
+ valueType?: SQLType;
11
+ fields?: SQLField[];
12
+ }
13
+ export declare function arrowToSQLType(type: arrow.DataType): SQLType;
14
+ export declare type SQLField = SQLType & {
15
+ name: string;
16
+ };
17
+ export declare function arrowToSQLField(name: string, type: arrow.DataType): SQLField;
@@ -44,6 +44,8 @@ export declare class VoidLogger implements Logger {
44
44
  log(_entry: LogEntryVariant): void;
45
45
  }
46
46
  export declare class ConsoleLogger implements Logger {
47
+ protected level: LogLevel;
48
+ constructor(level?: LogLevel);
47
49
  log(entry: LogEntryVariant): void;
48
50
  }
49
51
  export declare function getLogLevelLabel(level: LogLevel): string;
@@ -1,3 +1,6 @@
1
+ export declare const isNode: () => boolean;
2
+ export declare const isFirefox: () => boolean;
3
+ export declare const isSafari: () => boolean;
1
4
  export interface DuckDBBundles {
2
5
  mvp: {
3
6
  mainModule: string;
@@ -2,6 +2,7 @@ export * from '../bindings';
2
2
  export * from '../log';
3
3
  export * from '../platform';
4
4
  export * from '../status';
5
+ export * from '../version';
5
6
  export { DEFAULT_RUNTIME } from '../bindings/runtime';
6
7
  export { BROWSER_RUNTIME } from '../bindings/runtime_browser';
7
8
  import { Logger } from '../log';
@@ -2,6 +2,7 @@ export * from '../bindings';
2
2
  export * from '../log';
3
3
  export * from '../platform';
4
4
  export * from '../status';
5
+ export * from '../version';
5
6
  export { DEFAULT_RUNTIME } from '../bindings/runtime';
6
7
  export { NODE_RUNTIME } from '../bindings/runtime_node';
7
8
  import { Logger } from '../log';
@@ -1,3 +1,4 @@
1
+ export * from '../bindings/config';
1
2
  export * from '../log';
2
3
  export * from '../status';
3
4
  export * from '../parallel';
@@ -16,6 +16,7 @@ export interface S3PayloadParams {
16
16
  contentHash: string | null;
17
17
  contentType: string | null;
18
18
  }
19
+ export declare function getS3Params(config: S3Config | undefined, url: string, method: string): S3Params;
19
20
  export declare function uriEncode(input: string, encode_slash?: boolean): string;
20
21
  export declare function createS3Headers(params: S3Params, payloadParams?: S3PayloadParams | null): Map<string, string>;
21
22
  export declare function addS3Headers(xhr: XMLHttpRequest, config: S3Config | undefined, url: string, method: string, contentType?: string | null, payload?: Uint8Array | null): void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@duckdb/duckdb-wasm",
3
- "version": "1.13.1-dev98.0",
3
+ "version": "1.14.2",
4
4
  "description": "DuckDB powered by WebAssembly",
5
5
  "license": "MPL-2.0",
6
6
  "repository": {
@@ -23,40 +23,40 @@
23
23
  "csv"
24
24
  ],
25
25
  "dependencies": {
26
- "apache-arrow": "^6.0.1",
27
- "wasm-feature-detect": "^1.2.11",
28
- "fast-glob": "^3.2.11",
29
- "web-worker": "^1.2.0",
30
- "@types/emscripten": "^1.39.6",
31
- "js-sha256": "^0.9.0"
26
+ "apache-arrow": "^8.0.0"
32
27
  },
33
28
  "devDependencies": {
34
- "@types/jasmine": "^3.10.3",
35
- "@typescript-eslint/eslint-plugin": "^5.10.0",
36
- "@typescript-eslint/parser": "^5.10.0",
37
- "esbuild": "^0.14.12",
38
- "eslint": "^8.7.0",
29
+ "@types/emscripten": "^1.39.6",
30
+ "@types/jasmine": "^4.0.3",
31
+ "@typescript-eslint/eslint-plugin": "^5.23.0",
32
+ "@typescript-eslint/parser": "^5.23.0",
33
+ "esbuild": "^0.14.39",
34
+ "eslint": "^8.15.0",
39
35
  "eslint-plugin-jasmine": "^4.1.3",
40
- "eslint-plugin-react": "^7.28.0",
41
- "jasmine": "^4.0.2",
42
- "jasmine-core": "^4.0.0",
36
+ "eslint-plugin-react": "^7.29.4",
37
+ "fast-glob": "^3.2.11",
38
+ "jasmine": "^4.1.0",
39
+ "jasmine-core": "^4.1.1",
43
40
  "jasmine-spec-reporter": "^7.0.0",
44
- "karma": "^6.3.11",
45
- "karma-chrome-launcher": "^3.1.0",
46
- "karma-coverage": "^2.1.0",
41
+ "js-sha256": "^0.9.0",
42
+ "karma": "^6.3.20",
43
+ "karma-chrome-launcher": "^3.1.1",
44
+ "karma-coverage": "^2.2.0",
47
45
  "karma-firefox-launcher": "^2.1.2",
48
- "karma-jasmine": "^4.0.1",
46
+ "karma-jasmine": "^5.0.1",
49
47
  "karma-jasmine-html-reporter": "^1.7.0",
50
48
  "karma-sourcemap-loader": "^0.3.8",
51
- "karma-spec-reporter": "^0.0.33",
49
+ "karma-spec-reporter": "^0.0.34",
52
50
  "make-dir": "^3.1.0",
53
51
  "nyc": "^15.1.0",
54
- "prettier": "^2.5.1",
55
- "puppeteer": "^13.1.1",
52
+ "prettier": "^2.6.2",
53
+ "puppeteer": "^14.0.0",
56
54
  "rimraf": "^3.0.2",
57
55
  "s3rver": "^3.7.1",
58
- "typedoc": "^0.22.11",
59
- "typescript": "^4.5.5"
56
+ "typedoc": "^0.22.15",
57
+ "typescript": "^4.6.4",
58
+ "wasm-feature-detect": "^1.2.11",
59
+ "web-worker": "^1.2.0"
60
60
  },
61
61
  "scripts": {
62
62
  "build:debug": "node bundle.mjs debug && tsc --emitDeclarationOnly",
@@ -1,15 +0,0 @@
1
- import * as arrow from 'apache-arrow';
2
- export interface FlatArrowType {
3
- type: string;
4
- nullable?: boolean;
5
- precision?: number;
6
- scale?: number;
7
- timezone?: string;
8
- byteWidth?: number;
9
- children?: FlatArrowField[];
10
- }
11
- export declare function flattenArrowType(type: arrow.DataType): FlatArrowType;
12
- export declare type FlatArrowField = FlatArrowType & {
13
- name: string;
14
- };
15
- export declare function flattenArrowField(name: string, type: arrow.DataType): FlatArrowField;