-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathfloat32.ts
More file actions
83 lines (66 loc) · 1.86 KB
/
float32.ts
File metadata and controls
83 lines (66 loc) · 1.86 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import type { DataType } from '@apache-arrow/esnext-esm';
import { Float32 as ArrowFloat32 } from '@apache-arrow/esnext-esm';
import { FormatError } from '../errors/errors.js';
import type { Nullable } from '../schema/types.js';
import type { Scalar } from './scalar.js';
import { isInvalid, NULL_VALUE } from './util.js';
export class Float32 implements Scalar<Nullable<number>> {
private _valid = false;
private _value: Nullable<number> = null;
public constructor(v?: unknown) {
this.value = v;
return this;
}
public get dataType(): DataType {
return new ArrowFloat32();
}
public get valid(): boolean {
return this._valid;
}
public get value(): Nullable<number> {
if (!this._valid) {
return null;
}
return this._value;
}
public set value(value: unknown) {
if (isInvalid(value)) {
this._valid = false;
return;
}
if (value instanceof Float32) {
this._valid = value.valid;
this._value = value.value;
return;
}
if (typeof value === 'number') {
if (!this.validFloat32(value)) {
throw new TypeError(`Value '${value}' cannot be safely converted to Float32`);
}
this._value = value;
this._valid = true;
return;
}
const floatValue = Number.parseFloat(String(value));
if (!Number.isNaN(floatValue)) {
if (!this.validFloat32(floatValue)) {
throw new TypeError(`Value '${value}' cannot be safely converted to Float32`);
}
this._value = floatValue;
this._valid = true;
return;
}
throw new FormatError(`Unable to set Float32 from value`, { props: { value } });
}
public toString() {
if (this._valid) {
return String(this._value!);
}
return NULL_VALUE;
}
validFloat32(n: number) {
const float32 = new Float32Array(1);
float32[0] = n;
return float32[0] === n;
}
}