hume 0.15.1 → 0.15.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.
- package/dist/cjs/Client.d.ts +3 -3
- package/dist/cjs/Client.js +8 -8
- package/dist/cjs/api/resources/index.d.ts +1 -1
- package/dist/cjs/api/resources/index.js +2 -2
- package/dist/cjs/core/index.d.ts +1 -1
- package/dist/cjs/core/index.js +1 -1
- package/dist/cjs/index.d.ts +1 -1
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/serialization/resources/index.d.ts +1 -1
- package/dist/cjs/serialization/resources/index.js +2 -2
- package/dist/cjs/version.d.ts +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/wrapper/EVIWebAudioPlayer.js +9 -9
- package/dist/cjs/wrapper/HumeClient.d.ts +2 -2
- package/dist/cjs/wrapper/HumeClient.js +4 -4
- package/dist/cjs/wrapper/expressionMeasurement/ExpressionMeasurementClient.d.ts +3 -3
- package/dist/cjs/wrapper/expressionMeasurement/ExpressionMeasurementClient.js +6 -6
- package/dist/cjs/wrapper/expressionMeasurement/batch/BatchClient.d.ts +4 -4
- package/dist/cjs/wrapper/expressionMeasurement/batch/BatchClient.js +5 -5
- package/dist/cjs/wrapper/expressionMeasurement/batch/Job.d.ts +2 -2
- package/dist/cjs/wrapper/expressionMeasurement/batch/Job.js +1 -1
- package/dist/cjs/wrapper/expressionMeasurement/streaming/StreamSocket.d.ts +1 -1
- package/dist/cjs/wrapper/expressionMeasurement/streaming/StreamSocket.js +6 -6
- package/dist/cjs/wrapper/expressionMeasurement/streaming/StreamingClient.d.ts +3 -3
- package/dist/cjs/wrapper/expressionMeasurement/streaming/StreamingClient.js +3 -3
- package/dist/cjs/wrapper/fetchAccessToken.js +2 -2
- package/dist/cjs/wrapper/index.d.ts +14 -14
- package/dist/cjs/wrapper/index.js +28 -28
- package/dist/esm/Client.d.mts +3 -3
- package/dist/esm/Client.mjs +7 -7
- package/dist/esm/api/resources/index.d.mts +1 -1
- package/dist/esm/api/resources/index.mjs +1 -1
- package/dist/esm/core/index.d.mts +1 -1
- package/dist/esm/core/index.mjs +1 -1
- package/dist/esm/index.d.mts +1 -1
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/serialization/resources/index.d.mts +1 -1
- package/dist/esm/serialization/resources/index.mjs +1 -1
- package/dist/esm/version.d.mts +1 -1
- package/dist/esm/version.mjs +1 -1
- package/dist/esm/wrapper/EVIWebAudioPlayer.mjs +3 -3
- package/dist/esm/wrapper/HumeClient.d.mts +2 -2
- package/dist/esm/wrapper/HumeClient.mjs +2 -2
- package/dist/esm/wrapper/expressionMeasurement/ExpressionMeasurementClient.d.mts +3 -3
- package/dist/esm/wrapper/expressionMeasurement/ExpressionMeasurementClient.mjs +3 -3
- package/dist/esm/wrapper/expressionMeasurement/batch/BatchClient.d.mts +4 -4
- package/dist/esm/wrapper/expressionMeasurement/batch/BatchClient.mjs +3 -3
- package/dist/esm/wrapper/expressionMeasurement/batch/Job.d.mts +2 -2
- package/dist/esm/wrapper/expressionMeasurement/batch/Job.mjs +1 -1
- package/dist/esm/wrapper/expressionMeasurement/streaming/StreamSocket.d.mts +1 -1
- package/dist/esm/wrapper/expressionMeasurement/streaming/StreamSocket.mjs +4 -4
- package/dist/esm/wrapper/expressionMeasurement/streaming/StreamingClient.d.mts +3 -3
- package/dist/esm/wrapper/expressionMeasurement/streaming/StreamingClient.mjs +2 -2
- package/dist/esm/wrapper/fetchAccessToken.mjs +1 -1
- package/dist/esm/wrapper/index.d.mts +14 -14
- package/dist/esm/wrapper/index.mjs +14 -14
- package/package.json +6 -2
- package/reference.md +709 -709
package/dist/cjs/Client.d.ts
CHANGED
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import * as environments from "./environments.js";
|
|
5
5
|
import * as core from "./core/index.js";
|
|
6
|
-
import { EmpathicVoice } from "./api/resources/empathicVoice/client/Client.js";
|
|
7
6
|
import { Tts } from "./api/resources/tts/client/Client.js";
|
|
7
|
+
import { EmpathicVoice } from "./api/resources/empathicVoice/client/Client.js";
|
|
8
8
|
import { ExpressionMeasurement } from "./api/resources/expressionMeasurement/client/Client.js";
|
|
9
9
|
export declare namespace HumeClient {
|
|
10
10
|
interface Options {
|
|
@@ -31,11 +31,11 @@ export declare namespace HumeClient {
|
|
|
31
31
|
}
|
|
32
32
|
export declare class HumeClient {
|
|
33
33
|
protected readonly _options: HumeClient.Options;
|
|
34
|
-
protected _empathicVoice: EmpathicVoice | undefined;
|
|
35
34
|
protected _tts: Tts | undefined;
|
|
35
|
+
protected _empathicVoice: EmpathicVoice | undefined;
|
|
36
36
|
protected _expressionMeasurement: ExpressionMeasurement | undefined;
|
|
37
37
|
constructor(_options?: HumeClient.Options);
|
|
38
|
-
get empathicVoice(): EmpathicVoice;
|
|
39
38
|
get tts(): Tts;
|
|
39
|
+
get empathicVoice(): EmpathicVoice;
|
|
40
40
|
get expressionMeasurement(): ExpressionMeasurement;
|
|
41
41
|
}
|
package/dist/cjs/Client.js
CHANGED
|
@@ -39,27 +39,27 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
39
39
|
exports.HumeClient = void 0;
|
|
40
40
|
const core = __importStar(require("./core/index.js"));
|
|
41
41
|
const headers_js_1 = require("./core/headers.js");
|
|
42
|
-
const Client_js_1 = require("./api/resources/
|
|
43
|
-
const Client_js_2 = require("./api/resources/
|
|
42
|
+
const Client_js_1 = require("./api/resources/tts/client/Client.js");
|
|
43
|
+
const Client_js_2 = require("./api/resources/empathicVoice/client/Client.js");
|
|
44
44
|
const Client_js_3 = require("./api/resources/expressionMeasurement/client/Client.js");
|
|
45
45
|
class HumeClient {
|
|
46
46
|
constructor(_options = {}) {
|
|
47
47
|
this._options = Object.assign(Object.assign({}, _options), { headers: (0, headers_js_1.mergeHeaders)({
|
|
48
48
|
"X-Fern-Language": "JavaScript",
|
|
49
49
|
"X-Fern-SDK-Name": "hume",
|
|
50
|
-
"X-Fern-SDK-Version": "0.15.
|
|
51
|
-
"User-Agent": "hume/0.15.
|
|
50
|
+
"X-Fern-SDK-Version": "0.15.2",
|
|
51
|
+
"User-Agent": "hume/0.15.2",
|
|
52
52
|
"X-Fern-Runtime": core.RUNTIME.type,
|
|
53
53
|
"X-Fern-Runtime-Version": core.RUNTIME.version,
|
|
54
54
|
}, _options === null || _options === void 0 ? void 0 : _options.headers) });
|
|
55
55
|
}
|
|
56
|
-
get
|
|
56
|
+
get tts() {
|
|
57
57
|
var _a;
|
|
58
|
-
return ((_a = this.
|
|
58
|
+
return ((_a = this._tts) !== null && _a !== void 0 ? _a : (this._tts = new Client_js_1.Tts(this._options)));
|
|
59
59
|
}
|
|
60
|
-
get
|
|
60
|
+
get empathicVoice() {
|
|
61
61
|
var _a;
|
|
62
|
-
return ((_a = this.
|
|
62
|
+
return ((_a = this._empathicVoice) !== null && _a !== void 0 ? _a : (this._empathicVoice = new Client_js_2.EmpathicVoice(this._options)));
|
|
63
63
|
}
|
|
64
64
|
get expressionMeasurement() {
|
|
65
65
|
var _a;
|
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.expressionMeasurement = exports.
|
|
37
|
-
exports.empathicVoice = __importStar(require("./empathicVoice/index.js"));
|
|
36
|
+
exports.expressionMeasurement = exports.empathicVoice = exports.tts = void 0;
|
|
38
37
|
exports.tts = __importStar(require("./tts/index.js"));
|
|
38
|
+
exports.empathicVoice = __importStar(require("./empathicVoice/index.js"));
|
|
39
39
|
exports.expressionMeasurement = __importStar(require("./expressionMeasurement/index.js"));
|
package/dist/cjs/core/index.d.ts
CHANGED
|
@@ -3,8 +3,8 @@ export * from "./runtime/index.js";
|
|
|
3
3
|
export * as url from "./url/index.js";
|
|
4
4
|
export * as serialization from "./schemas/index.js";
|
|
5
5
|
export * from "./websocket/index.js";
|
|
6
|
+
export * from "./stream/index.js";
|
|
6
7
|
export * from "./utils/index.js";
|
|
7
8
|
export * from "./pagination/index.js";
|
|
8
|
-
export * from "./stream/index.js";
|
|
9
9
|
export * from "./form-data-utils/index.js";
|
|
10
10
|
export * as file from "./file/index.js";
|
package/dist/cjs/core/index.js
CHANGED
|
@@ -42,8 +42,8 @@ __exportStar(require("./runtime/index.js"), exports);
|
|
|
42
42
|
exports.url = __importStar(require("./url/index.js"));
|
|
43
43
|
exports.serialization = __importStar(require("./schemas/index.js"));
|
|
44
44
|
__exportStar(require("./websocket/index.js"), exports);
|
|
45
|
+
__exportStar(require("./stream/index.js"), exports);
|
|
45
46
|
__exportStar(require("./utils/index.js"), exports);
|
|
46
47
|
__exportStar(require("./pagination/index.js"), exports);
|
|
47
|
-
__exportStar(require("./stream/index.js"), exports);
|
|
48
48
|
__exportStar(require("./form-data-utils/index.js"), exports);
|
|
49
49
|
exports.file = __importStar(require("./file/index.js"));
|
package/dist/cjs/index.d.ts
CHANGED
|
@@ -3,4 +3,4 @@ export * as serialization from "./serialization/index.js";
|
|
|
3
3
|
export { HumeError, HumeTimeoutError } from "./errors/index.js";
|
|
4
4
|
export { HumeEnvironment, HumeEnvironmentUrls } from "./environments.js";
|
|
5
5
|
export * from "./exports.js";
|
|
6
|
-
export * from "./wrapper";
|
|
6
|
+
export * from "./wrapper/index.js";
|
package/dist/cjs/index.js
CHANGED
|
@@ -45,4 +45,4 @@ Object.defineProperty(exports, "HumeTimeoutError", { enumerable: true, get: func
|
|
|
45
45
|
var environments_js_1 = require("./environments.js");
|
|
46
46
|
Object.defineProperty(exports, "HumeEnvironment", { enumerable: true, get: function () { return environments_js_1.HumeEnvironment; } });
|
|
47
47
|
__exportStar(require("./exports.js"), exports);
|
|
48
|
-
__exportStar(require("./wrapper"), exports);
|
|
48
|
+
__exportStar(require("./wrapper/index.js"), exports);
|
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.expressionMeasurement = exports.
|
|
37
|
-
exports.empathicVoice = __importStar(require("./empathicVoice/index.js"));
|
|
36
|
+
exports.expressionMeasurement = exports.empathicVoice = exports.tts = void 0;
|
|
38
37
|
exports.tts = __importStar(require("./tts/index.js"));
|
|
38
|
+
exports.empathicVoice = __importStar(require("./empathicVoice/index.js"));
|
|
39
39
|
exports.expressionMeasurement = __importStar(require("./expressionMeasurement/index.js"));
|
package/dist/cjs/version.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const SDK_VERSION = "0.15.
|
|
1
|
+
export declare const SDK_VERSION = "0.15.2";
|
package/dist/cjs/version.js
CHANGED
|
@@ -22,9 +22,9 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
22
22
|
var _EVIWebAudioPlayer_instances, _a, _EVIWebAudioPlayer_DEFAULT_WORKLET_URL, _EVIWebAudioPlayer_DEFAULT_FFT_SIZE, _EVIWebAudioPlayer_DEFAULT_FFT_INTERVAL, _EVIWebAudioPlayer_ctx, _EVIWebAudioPlayer_workletNode, _EVIWebAudioPlayer_analyserNode, _EVIWebAudioPlayer_gainNode, _EVIWebAudioPlayer_initialized, _EVIWebAudioPlayer_playing, _EVIWebAudioPlayer_muted, _EVIWebAudioPlayer_volume, _EVIWebAudioPlayer_disableAudioWorklet, _EVIWebAudioPlayer_fft, _EVIWebAudioPlayer_fftTimer, _EVIWebAudioPlayer_fftOptions, _EVIWebAudioPlayer_clipQueue, _EVIWebAudioPlayer_currentlyPlayingAudioBuffer, _EVIWebAudioPlayer_isProcessing, _EVIWebAudioPlayer_lastQueuedChunk, _EVIWebAudioPlayer_chunkBufferQueues, _EVIWebAudioPlayer_startAnalyserPollingIfEnabled, _EVIWebAudioPlayer_emitError, _EVIWebAudioPlayer_convertToAudioBuffer, _EVIWebAudioPlayer_getNextAudioBuffers, _EVIWebAudioPlayer_playNextClip;
|
|
23
23
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
24
|
exports.EVIWebAudioPlayer = void 0;
|
|
25
|
-
const
|
|
26
|
-
const
|
|
27
|
-
const
|
|
25
|
+
const convertBase64ToBlob_js_1 = require("./convertBase64ToBlob.js");
|
|
26
|
+
const convertFrequencyScale_js_1 = require("./convertFrequencyScale.js");
|
|
27
|
+
const generateEmptyFft_js_1 = require("./generateEmptyFft.js");
|
|
28
28
|
/**
|
|
29
29
|
* A sequential, glitch-free Web-Audio player for **EVI** audio output.
|
|
30
30
|
*
|
|
@@ -66,7 +66,7 @@ class EVIWebAudioPlayer extends EventTarget {
|
|
|
66
66
|
_EVIWebAudioPlayer_muted.set(this, false);
|
|
67
67
|
_EVIWebAudioPlayer_volume.set(this, void 0);
|
|
68
68
|
_EVIWebAudioPlayer_disableAudioWorklet.set(this, void 0);
|
|
69
|
-
_EVIWebAudioPlayer_fft.set(this, (0,
|
|
69
|
+
_EVIWebAudioPlayer_fft.set(this, (0, generateEmptyFft_js_1.generateEmptyFft)());
|
|
70
70
|
_EVIWebAudioPlayer_fftTimer.set(this, null);
|
|
71
71
|
_EVIWebAudioPlayer_fftOptions.set(this, null);
|
|
72
72
|
_EVIWebAudioPlayer_clipQueue.set(this, []);
|
|
@@ -85,7 +85,7 @@ class EVIWebAudioPlayer extends EventTarget {
|
|
|
85
85
|
__classPrivateFieldSet(this, _EVIWebAudioPlayer_fftOptions, {
|
|
86
86
|
size: size !== null && size !== void 0 ? size : __classPrivateFieldGet(_a, _a, "f", _EVIWebAudioPlayer_DEFAULT_FFT_SIZE),
|
|
87
87
|
interval: interval !== null && interval !== void 0 ? interval : __classPrivateFieldGet(_a, _a, "f", _EVIWebAudioPlayer_DEFAULT_FFT_INTERVAL),
|
|
88
|
-
transform: transform !== null && transform !== void 0 ? transform : ((bins, sampleRate) => (0,
|
|
88
|
+
transform: transform !== null && transform !== void 0 ? transform : ((bins, sampleRate) => (0, convertFrequencyScale_js_1.convertLinearFrequenciesToBark)(bins, sampleRate)),
|
|
89
89
|
}, "f");
|
|
90
90
|
}
|
|
91
91
|
}
|
|
@@ -212,7 +212,7 @@ class EVIWebAudioPlayer extends EventTarget {
|
|
|
212
212
|
if (!__classPrivateFieldGet(this, _EVIWebAudioPlayer_disableAudioWorklet, "f")) {
|
|
213
213
|
try {
|
|
214
214
|
const { data, id } = message;
|
|
215
|
-
const blob = (0,
|
|
215
|
+
const blob = (0, convertBase64ToBlob_js_1.convertBase64ToBlob)(data);
|
|
216
216
|
const buffer = yield blob.arrayBuffer();
|
|
217
217
|
const audio = yield __classPrivateFieldGet(this, _EVIWebAudioPlayer_ctx, "f").decodeAudioData(buffer);
|
|
218
218
|
const pcmData = audio.getChannelData(0);
|
|
@@ -343,7 +343,7 @@ class EVIWebAudioPlayer extends EventTarget {
|
|
|
343
343
|
(_h = __classPrivateFieldGet(this, _EVIWebAudioPlayer_ctx, "f")) === null || _h === void 0 ? void 0 : _h.close().catch(() => void 0);
|
|
344
344
|
__classPrivateFieldSet(this, _EVIWebAudioPlayer_initialized, false, "f");
|
|
345
345
|
__classPrivateFieldSet(this, _EVIWebAudioPlayer_playing, false, "f");
|
|
346
|
-
__classPrivateFieldSet(this, _EVIWebAudioPlayer_fft, (0,
|
|
346
|
+
__classPrivateFieldSet(this, _EVIWebAudioPlayer_fft, (0, generateEmptyFft_js_1.generateEmptyFft)(), "f");
|
|
347
347
|
}
|
|
348
348
|
}
|
|
349
349
|
exports.EVIWebAudioPlayer = EVIWebAudioPlayer;
|
|
@@ -367,7 +367,7 @@ _a = EVIWebAudioPlayer, _EVIWebAudioPlayer_ctx = new WeakMap(), _EVIWebAudioPlay
|
|
|
367
367
|
__classPrivateFieldGet(this, _EVIWebAudioPlayer_instances, "m", _EVIWebAudioPlayer_emitError).call(this, "Audio player has not been initialized");
|
|
368
368
|
return;
|
|
369
369
|
}
|
|
370
|
-
const blob = (0,
|
|
370
|
+
const blob = (0, convertBase64ToBlob_js_1.convertBase64ToBlob)(message.data);
|
|
371
371
|
const arrayBuffer = yield blob.arrayBuffer();
|
|
372
372
|
const audioBuffer = yield __classPrivateFieldGet(this, _EVIWebAudioPlayer_ctx, "f").decodeAudioData(arrayBuffer);
|
|
373
373
|
return audioBuffer;
|
|
@@ -461,7 +461,7 @@ _a = EVIWebAudioPlayer, _EVIWebAudioPlayer_ctx = new WeakMap(), _EVIWebAudioPlay
|
|
|
461
461
|
clearInterval(__classPrivateFieldGet(this, _EVIWebAudioPlayer_fftTimer, "f"));
|
|
462
462
|
__classPrivateFieldSet(this, _EVIWebAudioPlayer_fftTimer, null, "f");
|
|
463
463
|
}
|
|
464
|
-
__classPrivateFieldSet(this, _EVIWebAudioPlayer_fft, (0,
|
|
464
|
+
__classPrivateFieldSet(this, _EVIWebAudioPlayer_fft, (0, generateEmptyFft_js_1.generateEmptyFft)(), "f");
|
|
465
465
|
bufferSource.disconnect();
|
|
466
466
|
__classPrivateFieldSet(this, _EVIWebAudioPlayer_isProcessing, false, "f");
|
|
467
467
|
__classPrivateFieldSet(this, _EVIWebAudioPlayer_playing, false, "f");
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { HumeClient as FernClient } from "../Client";
|
|
1
|
+
import { HumeClient as FernClient } from "../Client.js";
|
|
2
2
|
import * as core from "../core/index.js";
|
|
3
|
-
import { ExpressionMeasurement } from "./expressionMeasurement/ExpressionMeasurementClient";
|
|
3
|
+
import { ExpressionMeasurement } from "./expressionMeasurement/ExpressionMeasurementClient.js";
|
|
4
4
|
import * as environments from "../environments.js";
|
|
5
5
|
export declare namespace HumeClient {
|
|
6
6
|
type Options = Omit<FernClient.Options, "environment"> & {
|
|
@@ -45,11 +45,11 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
|
45
45
|
};
|
|
46
46
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
47
47
|
exports.HumeClient = void 0;
|
|
48
|
-
const
|
|
48
|
+
const Client_js_1 = require("../Client.js");
|
|
49
49
|
const core = __importStar(require("../core/index.js"));
|
|
50
|
-
const
|
|
50
|
+
const ExpressionMeasurementClient_js_1 = require("./expressionMeasurement/ExpressionMeasurementClient.js");
|
|
51
51
|
const version_js_1 = require("../version.js");
|
|
52
|
-
class HumeClient extends
|
|
52
|
+
class HumeClient extends Client_js_1.HumeClient {
|
|
53
53
|
constructor(_options) {
|
|
54
54
|
var _a;
|
|
55
55
|
let options;
|
|
@@ -106,7 +106,7 @@ class HumeClient extends Client_1.HumeClient {
|
|
|
106
106
|
}
|
|
107
107
|
get expressionMeasurement() {
|
|
108
108
|
var _a;
|
|
109
|
-
return ((_a = this._expressionMeasurement) !== null && _a !== void 0 ? _a : (this._expressionMeasurement = new
|
|
109
|
+
return ((_a = this._expressionMeasurement) !== null && _a !== void 0 ? _a : (this._expressionMeasurement = new ExpressionMeasurementClient_js_1.ExpressionMeasurement(this._options)));
|
|
110
110
|
}
|
|
111
111
|
}
|
|
112
112
|
exports.HumeClient = HumeClient;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { ExpressionMeasurement as FernClient } from "../../api/resources/expressionMeasurement/client/Client";
|
|
2
|
-
import { BatchClient } from "./batch/BatchClient";
|
|
3
|
-
import { StreamClient } from "./streaming/StreamingClient";
|
|
1
|
+
import { ExpressionMeasurement as FernClient } from "../../api/resources/expressionMeasurement/client/Client.js";
|
|
2
|
+
import { BatchClient } from "./batch/BatchClient.js";
|
|
3
|
+
import { StreamClient } from "./streaming/StreamingClient.js";
|
|
4
4
|
export declare class ExpressionMeasurement extends FernClient {
|
|
5
5
|
protected _batch: BatchClient | undefined;
|
|
6
6
|
get batch(): BatchClient;
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ExpressionMeasurement = void 0;
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const
|
|
7
|
-
class ExpressionMeasurement extends
|
|
4
|
+
const Client_js_1 = require("../../api/resources/expressionMeasurement/client/Client.js");
|
|
5
|
+
const BatchClient_js_1 = require("./batch/BatchClient.js");
|
|
6
|
+
const StreamingClient_js_1 = require("./streaming/StreamingClient.js");
|
|
7
|
+
class ExpressionMeasurement extends Client_js_1.ExpressionMeasurement {
|
|
8
8
|
// BatchClient here is overridden from the generated version, we wrap expression measurement jobs in
|
|
9
9
|
// a helper that makes it easier to await the result of a job.
|
|
10
10
|
get batch() {
|
|
11
11
|
var _a;
|
|
12
|
-
return ((_a = this._batch) !== null && _a !== void 0 ? _a : (this._batch = new
|
|
12
|
+
return ((_a = this._batch) !== null && _a !== void 0 ? _a : (this._batch = new BatchClient_js_1.BatchClient(this._options)));
|
|
13
13
|
}
|
|
14
14
|
get stream() {
|
|
15
15
|
var _a;
|
|
16
|
-
return ((_a = this._stream) !== null && _a !== void 0 ? _a : (this._stream = new
|
|
16
|
+
return ((_a = this._stream) !== null && _a !== void 0 ? _a : (this._stream = new StreamingClient_js_1.StreamClient(this._options)));
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
19
|
exports.ExpressionMeasurement = ExpressionMeasurement;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Batch as FernClient } from "../../../api/resources/expressionMeasurement/resources/batch/client/Client";
|
|
2
|
-
import * as Hume from "../../../api";
|
|
3
|
-
import { Job } from "./Job";
|
|
4
|
-
import * as core from "../../../core";
|
|
1
|
+
import { Batch as FernClient } from "../../../api/resources/expressionMeasurement/resources/batch/client/Client.js";
|
|
2
|
+
import * as Hume from "../../../api/index.js";
|
|
3
|
+
import { Job } from "./Job.js";
|
|
4
|
+
import * as core from "../../../core/index.js";
|
|
5
5
|
export declare class BatchClient extends FernClient {
|
|
6
6
|
startInferenceJob(request?: Hume.expressionMeasurement.batch.InferenceBaseRequest, requestOptions?: FernClient.RequestOptions): core.HttpResponsePromise<Job>;
|
|
7
7
|
}
|
|
@@ -34,10 +34,10 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
36
|
exports.BatchClient = void 0;
|
|
37
|
-
const
|
|
38
|
-
const
|
|
39
|
-
const core = __importStar(require("../../../core"));
|
|
40
|
-
class BatchClient extends
|
|
37
|
+
const Client_js_1 = require("../../../api/resources/expressionMeasurement/resources/batch/client/Client.js");
|
|
38
|
+
const Job_js_1 = require("./Job.js");
|
|
39
|
+
const core = __importStar(require("../../../core/index.js"));
|
|
40
|
+
class BatchClient extends Client_js_1.Batch {
|
|
41
41
|
// This just wraps the return value of the base class's `startInferenceJob` method
|
|
42
42
|
// and returns a `Job` instance (has helper functions to await the job's result) instead of a raw job ID.
|
|
43
43
|
startInferenceJob(request = {}, requestOptions) {
|
|
@@ -45,7 +45,7 @@ class BatchClient extends Client_1.Batch {
|
|
|
45
45
|
.startInferenceJob(request, requestOptions)
|
|
46
46
|
.withRawResponse()
|
|
47
47
|
.then((result) => {
|
|
48
|
-
return { data: new
|
|
48
|
+
return { data: new Job_js_1.Job(result.data.jobId, this), rawResponse: result.rawResponse };
|
|
49
49
|
}));
|
|
50
50
|
}
|
|
51
51
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import * as Hume from "../../../api";
|
|
2
|
-
import { BatchClient } from "./BatchClient";
|
|
1
|
+
import * as Hume from "../../../api/index.js";
|
|
2
|
+
import { BatchClient } from "./BatchClient.js";
|
|
3
3
|
export declare class Job implements Hume.expressionMeasurement.batch.JobId {
|
|
4
4
|
readonly jobId: string;
|
|
5
5
|
private readonly client;
|
|
@@ -43,7 +43,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
43
43
|
};
|
|
44
44
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
45
|
exports.Job = void 0;
|
|
46
|
-
const errors = __importStar(require("../../../errors"));
|
|
46
|
+
const errors = __importStar(require("../../../errors/index.js"));
|
|
47
47
|
class Job {
|
|
48
48
|
constructor(jobId, client) {
|
|
49
49
|
this.jobId = jobId;
|
|
@@ -55,10 +55,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
55
55
|
exports.StreamSocket = void 0;
|
|
56
56
|
const ws_1 = __importDefault(require("ws"));
|
|
57
57
|
const uuid_1 = require("uuid");
|
|
58
|
-
const
|
|
59
|
-
const
|
|
60
|
-
const errors = __importStar(require("../../../errors"));
|
|
61
|
-
const serializers = __importStar(require("../../../serialization"));
|
|
58
|
+
const StreamingClient_js_1 = require("./StreamingClient.js");
|
|
59
|
+
const base64Encode_js_1 = require("../../base64Encode.js");
|
|
60
|
+
const errors = __importStar(require("../../../errors/index.js"));
|
|
61
|
+
const serializers = __importStar(require("../../../serialization/index.js"));
|
|
62
62
|
const fs = __importStar(require("fs"));
|
|
63
63
|
class StreamSocket {
|
|
64
64
|
constructor({ websocket, config, streamWindowMs }) {
|
|
@@ -174,7 +174,7 @@ class StreamSocket {
|
|
|
174
174
|
sendFacemesh(_a) {
|
|
175
175
|
return __awaiter(this, arguments, void 0, function* ({ landmarks, config, }) {
|
|
176
176
|
const response = this.sendText({
|
|
177
|
-
text: (0,
|
|
177
|
+
text: (0, base64Encode_js_1.base64Encode)(JSON.stringify(landmarks)),
|
|
178
178
|
config,
|
|
179
179
|
});
|
|
180
180
|
return response;
|
|
@@ -221,7 +221,7 @@ class StreamSocket {
|
|
|
221
221
|
this.websocket.send(JSON.stringify(jsonPayload));
|
|
222
222
|
const response = yield new Promise((resolve) => {
|
|
223
223
|
this.websocket.addEventListener("message", (event) => {
|
|
224
|
-
const response = (0,
|
|
224
|
+
const response = (0, StreamingClient_js_1.parse)(event.data);
|
|
225
225
|
resolve(response);
|
|
226
226
|
});
|
|
227
227
|
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import * as Hume from "../../../api";
|
|
2
|
-
import * as core from "../../../core";
|
|
3
|
-
import { StreamSocket } from "./StreamSocket";
|
|
1
|
+
import * as Hume from "../../../api/index.js";
|
|
2
|
+
import * as core from "../../../core/index.js";
|
|
3
|
+
import { StreamSocket } from "./StreamSocket.js";
|
|
4
4
|
import WebSocket from "ws";
|
|
5
5
|
export declare namespace StreamClient {
|
|
6
6
|
interface Options {
|
|
@@ -47,8 +47,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
47
47
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
48
48
|
exports.StreamClient = void 0;
|
|
49
49
|
exports.parse = parse;
|
|
50
|
-
const serializers = __importStar(require("../../../serialization"));
|
|
51
|
-
const
|
|
50
|
+
const serializers = __importStar(require("../../../serialization/index.js"));
|
|
51
|
+
const StreamSocket_js_1 = require("./StreamSocket.js");
|
|
52
52
|
const ws_1 = __importDefault(require("ws"));
|
|
53
53
|
class StreamClient {
|
|
54
54
|
constructor(_options) {
|
|
@@ -82,7 +82,7 @@ class StreamClient {
|
|
|
82
82
|
var _a;
|
|
83
83
|
(_a = args.onClose) === null || _a === void 0 ? void 0 : _a.call(args, event);
|
|
84
84
|
});
|
|
85
|
-
return new
|
|
85
|
+
return new StreamSocket_js_1.StreamSocket({
|
|
86
86
|
websocket,
|
|
87
87
|
streamWindowMs: args.streamWindowMs,
|
|
88
88
|
config: args.config,
|
|
@@ -10,7 +10,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.fetchAccessToken = void 0;
|
|
13
|
-
const
|
|
13
|
+
const base64Encode_js_1 = require("./base64Encode.js");
|
|
14
14
|
const zod_1 = require("zod");
|
|
15
15
|
/**
|
|
16
16
|
* Fetches a new access token from the Hume API using the provided API key and Secret key.
|
|
@@ -30,7 +30,7 @@ const zod_1 = require("zod");
|
|
|
30
30
|
*/
|
|
31
31
|
const fetchAccessToken = (_a) => __awaiter(void 0, [_a], void 0, function* ({ apiKey, secretKey, host = "api.hume.ai", }) {
|
|
32
32
|
const authString = `${apiKey}:${secretKey}`;
|
|
33
|
-
const encoded = (0,
|
|
33
|
+
const encoded = (0, base64Encode_js_1.base64Encode)(authString);
|
|
34
34
|
const res = yield fetch(`https://${host}/oauth2-cc/token`, {
|
|
35
35
|
method: "POST",
|
|
36
36
|
headers: {
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
export { base64Decode } from "./base64Decode";
|
|
2
|
-
export { base64Encode } from "./base64Encode";
|
|
3
|
-
export { convertBase64ToBlob } from "./convertBase64ToBlob";
|
|
4
|
-
export { convertBlobToBase64 } from "./convertBlobToBase64";
|
|
5
|
-
export { ensureSingleValidAudioTrack } from "./ensureSingleValidAudioTrack";
|
|
6
|
-
export { checkForAudioTracks } from "./checkForAudioTracks";
|
|
7
|
-
export { fetchAccessToken } from "./fetchAccessToken";
|
|
8
|
-
export { getAudioStream } from "./getAudioStream";
|
|
9
|
-
export { MimeType, getBrowserSupportedMimeType } from "./getBrowserSupportedMimeType";
|
|
10
|
-
export { HumeClient } from "./HumeClient";
|
|
11
|
-
export { ExpressionMeasurement } from "./expressionMeasurement/ExpressionMeasurementClient";
|
|
12
|
-
export { EVIWebAudioPlayer, EVIWebAudioPlayerFFTOptions, EVIWebAudioPlayerOptions } from "./EVIWebAudioPlayer";
|
|
13
|
-
export { collate } from "./collate";
|
|
14
|
-
export declare const createSilenceFiller: () => Promise<typeof import("./SilenceFiller").SilenceFiller>;
|
|
1
|
+
export { base64Decode } from "./base64Decode.js";
|
|
2
|
+
export { base64Encode } from "./base64Encode.js";
|
|
3
|
+
export { convertBase64ToBlob } from "./convertBase64ToBlob.js";
|
|
4
|
+
export { convertBlobToBase64 } from "./convertBlobToBase64.js";
|
|
5
|
+
export { ensureSingleValidAudioTrack } from "./ensureSingleValidAudioTrack.js";
|
|
6
|
+
export { checkForAudioTracks } from "./checkForAudioTracks.js";
|
|
7
|
+
export { fetchAccessToken } from "./fetchAccessToken.js";
|
|
8
|
+
export { getAudioStream } from "./getAudioStream.js";
|
|
9
|
+
export { MimeType, getBrowserSupportedMimeType } from "./getBrowserSupportedMimeType.js";
|
|
10
|
+
export { HumeClient } from "./HumeClient.js";
|
|
11
|
+
export { ExpressionMeasurement } from "./expressionMeasurement/ExpressionMeasurementClient.js";
|
|
12
|
+
export { EVIWebAudioPlayer, EVIWebAudioPlayerFFTOptions, EVIWebAudioPlayerOptions } from "./EVIWebAudioPlayer.js";
|
|
13
|
+
export { collate } from "./collate.js";
|
|
14
|
+
export declare const createSilenceFiller: () => Promise<typeof import("./SilenceFiller.js").SilenceFiller>;
|
|
@@ -43,40 +43,40 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
43
43
|
};
|
|
44
44
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
45
|
exports.createSilenceFiller = exports.collate = exports.EVIWebAudioPlayer = exports.ExpressionMeasurement = exports.HumeClient = exports.getBrowserSupportedMimeType = exports.MimeType = exports.getAudioStream = exports.fetchAccessToken = exports.checkForAudioTracks = exports.ensureSingleValidAudioTrack = exports.convertBlobToBase64 = exports.convertBase64ToBlob = exports.base64Encode = exports.base64Decode = void 0;
|
|
46
|
-
var
|
|
47
|
-
Object.defineProperty(exports, "base64Decode", { enumerable: true, get: function () { return
|
|
48
|
-
var
|
|
49
|
-
Object.defineProperty(exports, "base64Encode", { enumerable: true, get: function () { return
|
|
50
|
-
var
|
|
51
|
-
Object.defineProperty(exports, "convertBase64ToBlob", { enumerable: true, get: function () { return
|
|
52
|
-
var
|
|
53
|
-
Object.defineProperty(exports, "convertBlobToBase64", { enumerable: true, get: function () { return
|
|
54
|
-
var
|
|
55
|
-
Object.defineProperty(exports, "ensureSingleValidAudioTrack", { enumerable: true, get: function () { return
|
|
56
|
-
var
|
|
57
|
-
Object.defineProperty(exports, "checkForAudioTracks", { enumerable: true, get: function () { return
|
|
58
|
-
var
|
|
59
|
-
Object.defineProperty(exports, "fetchAccessToken", { enumerable: true, get: function () { return
|
|
60
|
-
var
|
|
61
|
-
Object.defineProperty(exports, "getAudioStream", { enumerable: true, get: function () { return
|
|
62
|
-
var
|
|
63
|
-
Object.defineProperty(exports, "MimeType", { enumerable: true, get: function () { return
|
|
64
|
-
Object.defineProperty(exports, "getBrowserSupportedMimeType", { enumerable: true, get: function () { return
|
|
65
|
-
var
|
|
66
|
-
Object.defineProperty(exports, "HumeClient", { enumerable: true, get: function () { return
|
|
67
|
-
var
|
|
68
|
-
Object.defineProperty(exports, "ExpressionMeasurement", { enumerable: true, get: function () { return
|
|
69
|
-
var
|
|
70
|
-
Object.defineProperty(exports, "EVIWebAudioPlayer", { enumerable: true, get: function () { return
|
|
71
|
-
var
|
|
72
|
-
Object.defineProperty(exports, "collate", { enumerable: true, get: function () { return
|
|
46
|
+
var base64Decode_js_1 = require("./base64Decode.js");
|
|
47
|
+
Object.defineProperty(exports, "base64Decode", { enumerable: true, get: function () { return base64Decode_js_1.base64Decode; } });
|
|
48
|
+
var base64Encode_js_1 = require("./base64Encode.js");
|
|
49
|
+
Object.defineProperty(exports, "base64Encode", { enumerable: true, get: function () { return base64Encode_js_1.base64Encode; } });
|
|
50
|
+
var convertBase64ToBlob_js_1 = require("./convertBase64ToBlob.js");
|
|
51
|
+
Object.defineProperty(exports, "convertBase64ToBlob", { enumerable: true, get: function () { return convertBase64ToBlob_js_1.convertBase64ToBlob; } });
|
|
52
|
+
var convertBlobToBase64_js_1 = require("./convertBlobToBase64.js");
|
|
53
|
+
Object.defineProperty(exports, "convertBlobToBase64", { enumerable: true, get: function () { return convertBlobToBase64_js_1.convertBlobToBase64; } });
|
|
54
|
+
var ensureSingleValidAudioTrack_js_1 = require("./ensureSingleValidAudioTrack.js");
|
|
55
|
+
Object.defineProperty(exports, "ensureSingleValidAudioTrack", { enumerable: true, get: function () { return ensureSingleValidAudioTrack_js_1.ensureSingleValidAudioTrack; } });
|
|
56
|
+
var checkForAudioTracks_js_1 = require("./checkForAudioTracks.js");
|
|
57
|
+
Object.defineProperty(exports, "checkForAudioTracks", { enumerable: true, get: function () { return checkForAudioTracks_js_1.checkForAudioTracks; } });
|
|
58
|
+
var fetchAccessToken_js_1 = require("./fetchAccessToken.js");
|
|
59
|
+
Object.defineProperty(exports, "fetchAccessToken", { enumerable: true, get: function () { return fetchAccessToken_js_1.fetchAccessToken; } });
|
|
60
|
+
var getAudioStream_js_1 = require("./getAudioStream.js");
|
|
61
|
+
Object.defineProperty(exports, "getAudioStream", { enumerable: true, get: function () { return getAudioStream_js_1.getAudioStream; } });
|
|
62
|
+
var getBrowserSupportedMimeType_js_1 = require("./getBrowserSupportedMimeType.js");
|
|
63
|
+
Object.defineProperty(exports, "MimeType", { enumerable: true, get: function () { return getBrowserSupportedMimeType_js_1.MimeType; } });
|
|
64
|
+
Object.defineProperty(exports, "getBrowserSupportedMimeType", { enumerable: true, get: function () { return getBrowserSupportedMimeType_js_1.getBrowserSupportedMimeType; } });
|
|
65
|
+
var HumeClient_js_1 = require("./HumeClient.js");
|
|
66
|
+
Object.defineProperty(exports, "HumeClient", { enumerable: true, get: function () { return HumeClient_js_1.HumeClient; } });
|
|
67
|
+
var ExpressionMeasurementClient_js_1 = require("./expressionMeasurement/ExpressionMeasurementClient.js");
|
|
68
|
+
Object.defineProperty(exports, "ExpressionMeasurement", { enumerable: true, get: function () { return ExpressionMeasurementClient_js_1.ExpressionMeasurement; } });
|
|
69
|
+
var EVIWebAudioPlayer_js_1 = require("./EVIWebAudioPlayer.js");
|
|
70
|
+
Object.defineProperty(exports, "EVIWebAudioPlayer", { enumerable: true, get: function () { return EVIWebAudioPlayer_js_1.EVIWebAudioPlayer; } });
|
|
71
|
+
var collate_js_1 = require("./collate.js");
|
|
72
|
+
Object.defineProperty(exports, "collate", { enumerable: true, get: function () { return collate_js_1.collate; } });
|
|
73
73
|
// SilenceFiller extends from Node.JS Readable -- this should not be exported in non-nodeJS environments. Otherwise the bundle will crash in the browser.
|
|
74
74
|
const createSilenceFiller = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
75
75
|
var _a;
|
|
76
76
|
if (typeof process === "undefined" || !((_a = process.versions) === null || _a === void 0 ? void 0 : _a.node)) {
|
|
77
77
|
throw new Error("SilenceFiller is only available in Node.js environments");
|
|
78
78
|
}
|
|
79
|
-
const { SilenceFiller } = yield Promise.resolve().then(() => __importStar(require("./SilenceFiller")));
|
|
79
|
+
const { SilenceFiller } = yield Promise.resolve().then(() => __importStar(require("./SilenceFiller.js")));
|
|
80
80
|
return SilenceFiller;
|
|
81
81
|
});
|
|
82
82
|
exports.createSilenceFiller = createSilenceFiller;
|
package/dist/esm/Client.d.mts
CHANGED
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import * as environments from "./environments.mjs";
|
|
5
5
|
import * as core from "./core/index.mjs";
|
|
6
|
-
import { EmpathicVoice } from "./api/resources/empathicVoice/client/Client.mjs";
|
|
7
6
|
import { Tts } from "./api/resources/tts/client/Client.mjs";
|
|
7
|
+
import { EmpathicVoice } from "./api/resources/empathicVoice/client/Client.mjs";
|
|
8
8
|
import { ExpressionMeasurement } from "./api/resources/expressionMeasurement/client/Client.mjs";
|
|
9
9
|
export declare namespace HumeClient {
|
|
10
10
|
interface Options {
|
|
@@ -31,11 +31,11 @@ export declare namespace HumeClient {
|
|
|
31
31
|
}
|
|
32
32
|
export declare class HumeClient {
|
|
33
33
|
protected readonly _options: HumeClient.Options;
|
|
34
|
-
protected _empathicVoice: EmpathicVoice | undefined;
|
|
35
34
|
protected _tts: Tts | undefined;
|
|
35
|
+
protected _empathicVoice: EmpathicVoice | undefined;
|
|
36
36
|
protected _expressionMeasurement: ExpressionMeasurement | undefined;
|
|
37
37
|
constructor(_options?: HumeClient.Options);
|
|
38
|
-
get empathicVoice(): EmpathicVoice;
|
|
39
38
|
get tts(): Tts;
|
|
39
|
+
get empathicVoice(): EmpathicVoice;
|
|
40
40
|
get expressionMeasurement(): ExpressionMeasurement;
|
|
41
41
|
}
|
package/dist/esm/Client.mjs
CHANGED
|
@@ -3,28 +3,28 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import * as core from "./core/index.mjs";
|
|
5
5
|
import { mergeHeaders } from "./core/headers.mjs";
|
|
6
|
-
import { EmpathicVoice } from "./api/resources/empathicVoice/client/Client.mjs";
|
|
7
6
|
import { Tts } from "./api/resources/tts/client/Client.mjs";
|
|
7
|
+
import { EmpathicVoice } from "./api/resources/empathicVoice/client/Client.mjs";
|
|
8
8
|
import { ExpressionMeasurement } from "./api/resources/expressionMeasurement/client/Client.mjs";
|
|
9
9
|
export class HumeClient {
|
|
10
10
|
constructor(_options = {}) {
|
|
11
11
|
this._options = Object.assign(Object.assign({}, _options), { headers: mergeHeaders({
|
|
12
12
|
"X-Fern-Language": "JavaScript",
|
|
13
13
|
"X-Fern-SDK-Name": "hume",
|
|
14
|
-
"X-Fern-SDK-Version": "0.15.
|
|
15
|
-
"User-Agent": "hume/0.15.
|
|
14
|
+
"X-Fern-SDK-Version": "0.15.2",
|
|
15
|
+
"User-Agent": "hume/0.15.2",
|
|
16
16
|
"X-Fern-Runtime": core.RUNTIME.type,
|
|
17
17
|
"X-Fern-Runtime-Version": core.RUNTIME.version,
|
|
18
18
|
}, _options === null || _options === void 0 ? void 0 : _options.headers) });
|
|
19
19
|
}
|
|
20
|
-
get empathicVoice() {
|
|
21
|
-
var _a;
|
|
22
|
-
return ((_a = this._empathicVoice) !== null && _a !== void 0 ? _a : (this._empathicVoice = new EmpathicVoice(this._options)));
|
|
23
|
-
}
|
|
24
20
|
get tts() {
|
|
25
21
|
var _a;
|
|
26
22
|
return ((_a = this._tts) !== null && _a !== void 0 ? _a : (this._tts = new Tts(this._options)));
|
|
27
23
|
}
|
|
24
|
+
get empathicVoice() {
|
|
25
|
+
var _a;
|
|
26
|
+
return ((_a = this._empathicVoice) !== null && _a !== void 0 ? _a : (this._empathicVoice = new EmpathicVoice(this._options)));
|
|
27
|
+
}
|
|
28
28
|
get expressionMeasurement() {
|
|
29
29
|
var _a;
|
|
30
30
|
return ((_a = this._expressionMeasurement) !== null && _a !== void 0 ? _a : (this._expressionMeasurement = new ExpressionMeasurement(this._options)));
|