@livestore/common 0.3.2-dev.9 → 0.4.0-dev.1
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/.tsbuildinfo +1 -1
- package/dist/ClientSessionLeaderThreadProxy.d.ts +2 -2
- package/dist/ClientSessionLeaderThreadProxy.d.ts.map +1 -1
- package/dist/adapter-types.d.ts +4 -4
- package/dist/adapter-types.d.ts.map +1 -1
- package/dist/debug-info.d.ts +17 -17
- package/dist/devtools/devtools-messages-client-session.d.ts +38 -38
- package/dist/devtools/devtools-messages-common.d.ts +6 -6
- package/dist/devtools/devtools-messages-leader.d.ts +28 -28
- package/dist/devtools/devtools-messages-leader.d.ts.map +1 -1
- package/dist/devtools/devtools-messages-leader.js.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.js +3 -1
- package/dist/leader-thread/LeaderSyncProcessor.js.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.js +21 -4
- package/dist/leader-thread/make-leader-thread-layer.js.map +1 -1
- package/dist/leader-thread/shutdown-channel.d.ts +2 -2
- package/dist/leader-thread/shutdown-channel.d.ts.map +1 -1
- package/dist/leader-thread/shutdown-channel.js +2 -2
- package/dist/leader-thread/shutdown-channel.js.map +1 -1
- package/dist/leader-thread/types.d.ts +1 -1
- package/dist/leader-thread/types.d.ts.map +1 -1
- package/dist/materializer-helper.d.ts +3 -3
- package/dist/materializer-helper.d.ts.map +1 -1
- package/dist/materializer-helper.js +2 -2
- package/dist/materializer-helper.js.map +1 -1
- package/dist/rematerialize-from-eventlog.js +1 -1
- package/dist/rematerialize-from-eventlog.js.map +1 -1
- package/dist/schema/EventDef.d.ts +104 -178
- package/dist/schema/EventSequenceNumber.d.ts +5 -0
- package/dist/schema/EventSequenceNumber.d.ts.map +1 -1
- package/dist/schema/EventSequenceNumber.js +7 -2
- package/dist/schema/EventSequenceNumber.js.map +1 -1
- package/dist/schema/EventSequenceNumber.test.js +2 -2
- package/dist/schema/LiveStoreEvent.d.ts +6 -5
- package/dist/schema/LiveStoreEvent.d.ts.map +1 -1
- package/dist/schema/LiveStoreEvent.js +5 -0
- package/dist/schema/LiveStoreEvent.js.map +1 -1
- package/dist/schema/schema.d.ts +3 -0
- package/dist/schema/schema.d.ts.map +1 -1
- package/dist/schema/schema.js.map +1 -1
- package/dist/schema/state/sqlite/client-document-def.d.ts +3 -2
- package/dist/schema/state/sqlite/client-document-def.d.ts.map +1 -1
- package/dist/schema/state/sqlite/client-document-def.js +6 -4
- package/dist/schema/state/sqlite/client-document-def.js.map +1 -1
- package/dist/schema/state/sqlite/client-document-def.test.js +76 -1
- package/dist/schema/state/sqlite/client-document-def.test.js.map +1 -1
- package/dist/schema/state/sqlite/column-annotations.d.ts +34 -0
- package/dist/schema/state/sqlite/column-annotations.d.ts.map +1 -0
- package/dist/schema/state/sqlite/column-annotations.js +50 -0
- package/dist/schema/state/sqlite/column-annotations.js.map +1 -0
- package/dist/schema/state/sqlite/column-annotations.test.d.ts +2 -0
- package/dist/schema/state/sqlite/column-annotations.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/column-annotations.test.js +179 -0
- package/dist/schema/state/sqlite/column-annotations.test.js.map +1 -0
- package/dist/schema/state/sqlite/column-def.d.ts +15 -0
- package/dist/schema/state/sqlite/column-def.d.ts.map +1 -0
- package/dist/schema/state/sqlite/column-def.js +242 -0
- package/dist/schema/state/sqlite/column-def.js.map +1 -0
- package/dist/schema/state/sqlite/column-def.test.d.ts +2 -0
- package/dist/schema/state/sqlite/column-def.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/column-def.test.js +529 -0
- package/dist/schema/state/sqlite/column-def.test.js.map +1 -0
- package/dist/schema/state/sqlite/column-spec.d.ts +11 -0
- package/dist/schema/state/sqlite/column-spec.d.ts.map +1 -0
- package/dist/schema/state/sqlite/column-spec.js +39 -0
- package/dist/schema/state/sqlite/column-spec.js.map +1 -0
- package/dist/schema/state/sqlite/column-spec.test.d.ts +2 -0
- package/dist/schema/state/sqlite/column-spec.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/column-spec.test.js +146 -0
- package/dist/schema/state/sqlite/column-spec.test.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts.map +1 -1
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.js +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.js.map +1 -1
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts +17 -4
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts.map +1 -1
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js +2 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js.map +1 -1
- package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts +65 -165
- package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts.map +1 -1
- package/dist/schema/state/sqlite/db-schema/dsl/mod.js +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.js.map +1 -1
- package/dist/schema/state/sqlite/mod.d.ts +2 -0
- package/dist/schema/state/sqlite/mod.d.ts.map +1 -1
- package/dist/schema/state/sqlite/mod.js +2 -0
- package/dist/schema/state/sqlite/mod.js.map +1 -1
- package/dist/schema/state/sqlite/query-builder/api.d.ts +309 -560
- package/dist/schema/state/sqlite/query-builder/api.d.ts.map +1 -1
- package/dist/schema/state/sqlite/query-builder/astToSql.d.ts +1 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.d.ts.map +1 -1
- package/dist/schema/state/sqlite/query-builder/astToSql.js +8 -6
- package/dist/schema/state/sqlite/query-builder/astToSql.js.map +1 -1
- package/dist/schema/state/sqlite/system-tables.d.ts +464 -46
- package/dist/schema/state/sqlite/system-tables.d.ts.map +1 -1
- package/dist/schema/state/sqlite/table-def.d.ts +159 -152
- package/dist/schema/state/sqlite/table-def.d.ts.map +1 -1
- package/dist/schema/state/sqlite/table-def.js +45 -6
- package/dist/schema/state/sqlite/table-def.js.map +1 -1
- package/dist/schema/state/sqlite/table-def.test.d.ts +2 -0
- package/dist/schema/state/sqlite/table-def.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/table-def.test.js +192 -0
- package/dist/schema/state/sqlite/table-def.test.js.map +1 -0
- package/dist/schema-management/common.d.ts +1 -1
- package/dist/schema-management/common.d.ts.map +1 -1
- package/dist/schema-management/common.js +11 -2
- package/dist/schema-management/common.js.map +1 -1
- package/dist/schema-management/migrations.d.ts +0 -1
- package/dist/schema-management/migrations.d.ts.map +1 -1
- package/dist/schema-management/migrations.js +4 -30
- package/dist/schema-management/migrations.js.map +1 -1
- package/dist/schema-management/migrations.test.d.ts +2 -0
- package/dist/schema-management/migrations.test.d.ts.map +1 -0
- package/dist/schema-management/migrations.test.js +52 -0
- package/dist/schema-management/migrations.test.js.map +1 -0
- package/dist/sql-queries/types.d.ts +37 -133
- package/dist/sqlite-db-helper.d.ts +3 -1
- package/dist/sqlite-db-helper.d.ts.map +1 -1
- package/dist/sqlite-db-helper.js +16 -0
- package/dist/sqlite-db-helper.js.map +1 -1
- package/dist/sqlite-types.d.ts +4 -4
- package/dist/sqlite-types.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.d.ts +2 -2
- package/dist/sync/ClientSessionSyncProcessor.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.js +8 -7
- package/dist/sync/ClientSessionSyncProcessor.js.map +1 -1
- package/dist/sync/sync.d.ts.map +1 -1
- package/dist/sync/sync.js.map +1 -1
- package/dist/util.d.ts +3 -3
- package/dist/util.d.ts.map +1 -1
- package/dist/util.js.map +1 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/package.json +4 -4
- package/src/ClientSessionLeaderThreadProxy.ts +2 -2
- package/src/adapter-types.ts +6 -4
- package/src/devtools/devtools-messages-leader.ts +3 -3
- package/src/leader-thread/LeaderSyncProcessor.ts +3 -1
- package/src/leader-thread/make-leader-thread-layer.ts +26 -7
- package/src/leader-thread/shutdown-channel.ts +2 -2
- package/src/leader-thread/types.ts +1 -1
- package/src/materializer-helper.ts +5 -11
- package/src/rematerialize-from-eventlog.ts +2 -2
- package/src/schema/EventSequenceNumber.test.ts +2 -2
- package/src/schema/EventSequenceNumber.ts +8 -2
- package/src/schema/LiveStoreEvent.ts +7 -1
- package/src/schema/schema.ts +4 -0
- package/src/schema/state/sqlite/client-document-def.test.ts +89 -1
- package/src/schema/state/sqlite/client-document-def.ts +7 -4
- package/src/schema/state/sqlite/column-annotations.test.ts +212 -0
- package/src/schema/state/sqlite/column-annotations.ts +77 -0
- package/src/schema/state/sqlite/column-def.test.ts +665 -0
- package/src/schema/state/sqlite/column-def.ts +290 -0
- package/src/schema/state/sqlite/column-spec.test.ts +223 -0
- package/src/schema/state/sqlite/column-spec.ts +42 -0
- package/src/schema/state/sqlite/db-schema/ast/sqlite.ts +2 -0
- package/src/schema/state/sqlite/db-schema/dsl/__snapshots__/field-defs.test.ts.snap +15 -0
- package/src/schema/state/sqlite/db-schema/dsl/field-defs.ts +20 -2
- package/src/schema/state/sqlite/db-schema/dsl/mod.ts +1 -0
- package/src/schema/state/sqlite/mod.ts +2 -0
- package/src/schema/state/sqlite/query-builder/api.ts +4 -3
- package/src/schema/state/sqlite/query-builder/astToSql.ts +9 -7
- package/src/schema/state/sqlite/table-def.test.ts +241 -0
- package/src/schema/state/sqlite/table-def.ts +222 -16
- package/src/schema-management/common.ts +10 -3
- package/src/schema-management/migrations.ts +4 -33
- package/src/sqlite-db-helper.ts +19 -1
- package/src/sqlite-types.ts +4 -4
- package/src/sync/ClientSessionSyncProcessor.ts +13 -8
- package/src/sync/sync.ts +2 -0
- package/src/util.ts +7 -2
- package/src/version.ts +1 -1
@@ -0,0 +1,529 @@
|
|
1
|
+
import { Schema } from '@livestore/utils/effect';
|
2
|
+
import { describe, expect, it } from 'vitest';
|
3
|
+
import * as State from "../mod.js";
|
4
|
+
import { withAutoIncrement, withColumnType, withDefault, withPrimaryKey, withUnique } from "./column-annotations.js";
|
5
|
+
describe('getColumnDefForSchema', () => {
|
6
|
+
describe('basic types', () => {
|
7
|
+
it('should map Schema.String to text column', () => {
|
8
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.String);
|
9
|
+
expect(columnDef.columnType).toBe('text');
|
10
|
+
});
|
11
|
+
it('should map Schema.Number to real column', () => {
|
12
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Number);
|
13
|
+
expect(columnDef.columnType).toBe('real');
|
14
|
+
});
|
15
|
+
it('should map Schema.Boolean to integer column', () => {
|
16
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Boolean);
|
17
|
+
expect(columnDef.columnType).toBe('integer');
|
18
|
+
});
|
19
|
+
it('should map Schema.Date to text column', () => {
|
20
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Date);
|
21
|
+
expect(columnDef.columnType).toBe('text');
|
22
|
+
});
|
23
|
+
it('should map Schema.BigInt to text column', () => {
|
24
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.BigInt);
|
25
|
+
expect(columnDef.columnType).toBe('text');
|
26
|
+
});
|
27
|
+
});
|
28
|
+
describe('refinements', () => {
|
29
|
+
it('should map Schema.Int to integer column', () => {
|
30
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Int);
|
31
|
+
expect(columnDef.columnType).toBe('integer');
|
32
|
+
});
|
33
|
+
it('should map string refinements to text column', () => {
|
34
|
+
const refinements = [
|
35
|
+
{ schema: Schema.NonEmptyString, name: 'NonEmptyString' },
|
36
|
+
{ schema: Schema.Trim, name: 'Trim' },
|
37
|
+
{ schema: Schema.UUID, name: 'UUID' },
|
38
|
+
{ schema: Schema.ULID, name: 'ULID' },
|
39
|
+
{ schema: Schema.String.pipe(Schema.minLength(5)), name: 'minLength' },
|
40
|
+
{
|
41
|
+
schema: Schema.String.pipe(Schema.pattern(/^[A-Z]+$/)),
|
42
|
+
name: 'pattern',
|
43
|
+
},
|
44
|
+
];
|
45
|
+
for (const { schema, name } of refinements) {
|
46
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
47
|
+
expect(columnDef.columnType, `${name} should map to text`).toBe('text');
|
48
|
+
}
|
49
|
+
});
|
50
|
+
it('should map number refinements to real column', () => {
|
51
|
+
const refinements = [
|
52
|
+
{ schema: Schema.Finite, name: 'Finite' },
|
53
|
+
{ schema: Schema.Number.pipe(Schema.positive()), name: 'positive' },
|
54
|
+
{ schema: Schema.Number.pipe(Schema.between(0, 100)), name: 'between' },
|
55
|
+
];
|
56
|
+
for (const { schema, name } of refinements) {
|
57
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
58
|
+
expect(columnDef.columnType, `${name} should map to real`).toBe('real');
|
59
|
+
}
|
60
|
+
});
|
61
|
+
});
|
62
|
+
describe('literal types', () => {
|
63
|
+
it('should map string literals to text column', () => {
|
64
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Literal('active'));
|
65
|
+
expect(columnDef.columnType).toBe('text');
|
66
|
+
});
|
67
|
+
it('should map number literals to real column', () => {
|
68
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Literal(42));
|
69
|
+
expect(columnDef.columnType).toBe('real');
|
70
|
+
});
|
71
|
+
it('should map boolean literals to integer column', () => {
|
72
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Literal(true));
|
73
|
+
expect(columnDef.columnType).toBe('integer');
|
74
|
+
});
|
75
|
+
});
|
76
|
+
describe('transformations', () => {
|
77
|
+
it('should map transformations based on target type', () => {
|
78
|
+
const StringToNumber = Schema.String.pipe(Schema.transform(Schema.Number, {
|
79
|
+
decode: Number.parseFloat,
|
80
|
+
encode: String,
|
81
|
+
}));
|
82
|
+
const columnDef = State.SQLite.getColumnDefForSchema(StringToNumber);
|
83
|
+
expect(columnDef.columnType).toBe('real'); // Based on the target type (Number)
|
84
|
+
});
|
85
|
+
it('should handle Date transformations', () => {
|
86
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Date);
|
87
|
+
expect(columnDef.columnType).toBe('text');
|
88
|
+
});
|
89
|
+
});
|
90
|
+
describe('complex types', () => {
|
91
|
+
it('should map structs to json column', () => {
|
92
|
+
const UserSchema = Schema.Struct({
|
93
|
+
name: Schema.String,
|
94
|
+
age: Schema.Number,
|
95
|
+
});
|
96
|
+
const columnDef = State.SQLite.getColumnDefForSchema(UserSchema);
|
97
|
+
expect(columnDef.columnType).toBe('text');
|
98
|
+
});
|
99
|
+
it('should map arrays to json column', () => {
|
100
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Array(Schema.String));
|
101
|
+
expect(columnDef.columnType).toBe('text');
|
102
|
+
});
|
103
|
+
it('should map records to json column', () => {
|
104
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Record({ key: Schema.String, value: Schema.Number }));
|
105
|
+
expect(columnDef.columnType).toBe('text');
|
106
|
+
});
|
107
|
+
it('should map tuples to json column', () => {
|
108
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Tuple(Schema.String, Schema.Number));
|
109
|
+
expect(columnDef.columnType).toBe('text');
|
110
|
+
});
|
111
|
+
it('should map tagged unions to json column', () => {
|
112
|
+
const ResultSchema = Schema.Union(Schema.Struct({
|
113
|
+
_tag: Schema.Literal('success'),
|
114
|
+
value: Schema.String,
|
115
|
+
}), Schema.Struct({ _tag: Schema.Literal('error'), error: Schema.String }));
|
116
|
+
const columnDef = State.SQLite.getColumnDefForSchema(ResultSchema);
|
117
|
+
expect(columnDef.columnType).toBe('text');
|
118
|
+
});
|
119
|
+
});
|
120
|
+
describe('nested schemas', () => {
|
121
|
+
it('should handle deeply nested schemas', () => {
|
122
|
+
const NestedSchema = Schema.Struct({
|
123
|
+
level1: Schema.Struct({
|
124
|
+
level2: Schema.Struct({
|
125
|
+
value: Schema.String,
|
126
|
+
}),
|
127
|
+
}),
|
128
|
+
});
|
129
|
+
const columnDef = State.SQLite.getColumnDefForSchema(NestedSchema);
|
130
|
+
expect(columnDef.columnType).toBe('text');
|
131
|
+
});
|
132
|
+
it('should handle optional nested schemas', () => {
|
133
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Union(Schema.Struct({ name: Schema.String }), Schema.Undefined));
|
134
|
+
expect(columnDef.columnType).toBe('text');
|
135
|
+
});
|
136
|
+
});
|
137
|
+
describe('edge cases', () => {
|
138
|
+
it('should default to json column for unhandled types', () => {
|
139
|
+
// Test various edge cases that all result in JSON columns
|
140
|
+
const edgeCases = [
|
141
|
+
{ schema: Schema.Unknown, name: 'Unknown' },
|
142
|
+
{ schema: Schema.Any, name: 'Any' },
|
143
|
+
{ schema: Schema.Null, name: 'Null' },
|
144
|
+
{ schema: Schema.Undefined, name: 'Undefined' },
|
145
|
+
{ schema: Schema.Void, name: 'Void' },
|
146
|
+
];
|
147
|
+
for (const { schema, name } of edgeCases) {
|
148
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
149
|
+
expect(columnDef.columnType, `${name} should map to text (JSON storage)`).toBe('text');
|
150
|
+
}
|
151
|
+
});
|
152
|
+
it('should handle never schema', () => {
|
153
|
+
// Create a schema that should never validate
|
154
|
+
const neverSchema = Schema.String.pipe(Schema.filter(() => false, { message: () => 'Always fails' }));
|
155
|
+
const columnDef = State.SQLite.getColumnDefForSchema(neverSchema);
|
156
|
+
expect(columnDef.columnType).toBe('text');
|
157
|
+
});
|
158
|
+
it('should handle symbol schema', () => {
|
159
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Symbol);
|
160
|
+
expect(columnDef.columnType).toBe('text');
|
161
|
+
});
|
162
|
+
});
|
163
|
+
describe('custom schemas', () => {
|
164
|
+
it('should handle Schema.extend', () => {
|
165
|
+
const BaseSchema = Schema.Struct({
|
166
|
+
id: Schema.String,
|
167
|
+
createdAt: Schema.Date,
|
168
|
+
});
|
169
|
+
const ExtendedSchema = Schema.Struct({
|
170
|
+
...BaseSchema.fields,
|
171
|
+
name: Schema.String,
|
172
|
+
updatedAt: Schema.Date,
|
173
|
+
});
|
174
|
+
const columnDef = State.SQLite.getColumnDefForSchema(ExtendedSchema);
|
175
|
+
expect(columnDef.columnType).toBe('text');
|
176
|
+
});
|
177
|
+
it('should handle Schema.pick', () => {
|
178
|
+
const UserSchema = Schema.Struct({
|
179
|
+
id: Schema.String,
|
180
|
+
name: Schema.String,
|
181
|
+
email: Schema.String,
|
182
|
+
});
|
183
|
+
const PickedSchema = UserSchema.pipe(Schema.pick('id', 'name'));
|
184
|
+
const columnDef = State.SQLite.getColumnDefForSchema(PickedSchema);
|
185
|
+
expect(columnDef.columnType).toBe('text');
|
186
|
+
});
|
187
|
+
it('should handle Schema.omit', () => {
|
188
|
+
const UserSchema = Schema.Struct({
|
189
|
+
id: Schema.String,
|
190
|
+
name: Schema.String,
|
191
|
+
password: Schema.String,
|
192
|
+
});
|
193
|
+
const PublicUserSchema = UserSchema.pipe(Schema.omit('password'));
|
194
|
+
const columnDef = State.SQLite.getColumnDefForSchema(PublicUserSchema);
|
195
|
+
expect(columnDef.columnType).toBe('text');
|
196
|
+
});
|
197
|
+
});
|
198
|
+
describe('annotations', () => {
|
199
|
+
it('should handle schemas with custom annotations', () => {
|
200
|
+
const AnnotatedString = Schema.String.annotations({
|
201
|
+
description: 'A special string',
|
202
|
+
});
|
203
|
+
const AnnotatedNumber = Schema.Number.annotations({ min: 0, max: 100 });
|
204
|
+
expect(State.SQLite.getColumnDefForSchema(AnnotatedString).columnType).toBe('text');
|
205
|
+
expect(State.SQLite.getColumnDefForSchema(AnnotatedNumber).columnType).toBe('real');
|
206
|
+
});
|
207
|
+
});
|
208
|
+
describe('enums and literal unions', () => {
|
209
|
+
it('should handle enums and literal unions as text', () => {
|
210
|
+
const StatusEnum = Schema.Enums({
|
211
|
+
PENDING: 'pending',
|
212
|
+
ACTIVE: 'active',
|
213
|
+
INACTIVE: 'inactive',
|
214
|
+
});
|
215
|
+
const StatusUnion = Schema.Union(Schema.Literal('pending'), Schema.Literal('active'), Schema.Literal('inactive'));
|
216
|
+
expect(State.SQLite.getColumnDefForSchema(StatusEnum).columnType).toBe('text');
|
217
|
+
expect(State.SQLite.getColumnDefForSchema(StatusUnion).columnType).toBe('text');
|
218
|
+
});
|
219
|
+
});
|
220
|
+
describe('binary data', () => {
|
221
|
+
it('should handle Uint8Array as blob column', () => {
|
222
|
+
const columnDef = State.SQLite.getColumnDefForSchema(Schema.Uint8Array);
|
223
|
+
expect(columnDef.columnType).toBe('text'); // Stored as JSON
|
224
|
+
});
|
225
|
+
});
|
226
|
+
describe('recursive schemas', () => {
|
227
|
+
it('should handle recursive schemas as json', () => {
|
228
|
+
const TreeNode = Schema.Struct({
|
229
|
+
value: Schema.String,
|
230
|
+
children: Schema.Array(Schema.suspend(() => TreeNode)),
|
231
|
+
});
|
232
|
+
const columnDef = State.SQLite.getColumnDefForSchema(TreeNode);
|
233
|
+
expect(columnDef.columnType).toBe('text'); // Complex type stored as JSON
|
234
|
+
});
|
235
|
+
});
|
236
|
+
describe('annotations', () => {
|
237
|
+
describe('withColumnType', () => {
|
238
|
+
it('should respect column type annotation for text', () => {
|
239
|
+
const schema = Schema.Number.pipe(withColumnType('text'));
|
240
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
241
|
+
expect(columnDef.columnType).toBe('text');
|
242
|
+
});
|
243
|
+
it('should respect column type annotation for integer', () => {
|
244
|
+
const schema = Schema.String.pipe(withColumnType('integer'));
|
245
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
246
|
+
expect(columnDef.columnType).toBe('integer');
|
247
|
+
});
|
248
|
+
it('should respect column type annotation for real', () => {
|
249
|
+
const schema = Schema.Boolean.pipe(withColumnType('real'));
|
250
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
251
|
+
expect(columnDef.columnType).toBe('real');
|
252
|
+
});
|
253
|
+
it('should respect column type annotation for blob', () => {
|
254
|
+
const schema = Schema.String.pipe(withColumnType('blob'));
|
255
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
256
|
+
expect(columnDef.columnType).toBe('blob');
|
257
|
+
});
|
258
|
+
it('should override default type mapping', () => {
|
259
|
+
// Number normally maps to real, but we override to text
|
260
|
+
const schema = Schema.Number.pipe(withColumnType('text'));
|
261
|
+
const columnDef = State.SQLite.getColumnDefForSchema(schema);
|
262
|
+
expect(columnDef.columnType).toBe('text');
|
263
|
+
});
|
264
|
+
it('should work with dual API', () => {
|
265
|
+
// Test both forms of the dual API
|
266
|
+
const schema1 = withColumnType(Schema.String, 'integer');
|
267
|
+
const schema2 = Schema.String.pipe(withColumnType('integer'));
|
268
|
+
const columnDef1 = State.SQLite.getColumnDefForSchema(schema1);
|
269
|
+
const columnDef2 = State.SQLite.getColumnDefForSchema(schema2);
|
270
|
+
expect(columnDef1.columnType).toBe('integer');
|
271
|
+
expect(columnDef2.columnType).toBe('integer');
|
272
|
+
});
|
273
|
+
});
|
274
|
+
describe('withPrimaryKey', () => {
|
275
|
+
it('should add primary key annotation to schema', () => {
|
276
|
+
const UserSchema = Schema.Struct({
|
277
|
+
id: Schema.String.pipe(withPrimaryKey),
|
278
|
+
name: Schema.String,
|
279
|
+
email: Schema.optional(Schema.String),
|
280
|
+
nullable: Schema.NullOr(Schema.Int),
|
281
|
+
optionalComplex: Schema.optional(Schema.Struct({ color: Schema.String })),
|
282
|
+
optionalNullableText: Schema.optional(Schema.NullOr(Schema.String)),
|
283
|
+
optionalNullableComplex: Schema.optional(Schema.NullOr(Schema.Struct({ color: Schema.String }))),
|
284
|
+
});
|
285
|
+
const userTable = State.SQLite.table({
|
286
|
+
name: 'users',
|
287
|
+
schema: UserSchema,
|
288
|
+
});
|
289
|
+
expect(userTable.sqliteDef.columns.id.primaryKey).toBe(true);
|
290
|
+
expect(userTable.sqliteDef.columns.id.nullable).toBe(false);
|
291
|
+
expect(userTable.sqliteDef.columns.name.primaryKey).toBe(false);
|
292
|
+
expect(userTable.sqliteDef.columns.email.primaryKey).toBe(false);
|
293
|
+
expect(userTable.sqliteDef.columns.email.nullable).toBe(true);
|
294
|
+
expect(userTable.sqliteDef.columns.nullable.primaryKey).toBe(false);
|
295
|
+
expect(userTable.sqliteDef.columns.nullable.nullable).toBe(true);
|
296
|
+
expect(userTable.sqliteDef.columns.optionalComplex.nullable).toBe(true);
|
297
|
+
expect(userTable.rowSchema.fields.email.toString()).toBe('string | undefined');
|
298
|
+
expect(userTable.rowSchema.fields.nullable.toString()).toBe('Int | null');
|
299
|
+
expect(userTable.rowSchema.fields.optionalComplex.toString()).toBe('(parseJson <-> { readonly color: string } | undefined)');
|
300
|
+
});
|
301
|
+
it('should handle Schema.NullOr with complex types', () => {
|
302
|
+
const schema = Schema.Struct({
|
303
|
+
data: Schema.NullOr(Schema.Struct({ value: Schema.Number })),
|
304
|
+
}).annotations({ title: 'test' });
|
305
|
+
const table = State.SQLite.table({ schema });
|
306
|
+
expect(table.sqliteDef.columns.data.nullable).toBe(true);
|
307
|
+
expect(table.sqliteDef.columns.data.columnType).toBe('text');
|
308
|
+
expect(table.rowSchema.fields.data.toString()).toBe('{ readonly value: number } | null');
|
309
|
+
});
|
310
|
+
it('should handle mixed nullable and optional fields', () => {
|
311
|
+
const schema = Schema.Struct({
|
312
|
+
nullableText: Schema.NullOr(Schema.String),
|
313
|
+
optionalText: Schema.optional(Schema.String),
|
314
|
+
optionalJson: Schema.optional(Schema.Struct({ x: Schema.Number })),
|
315
|
+
}).annotations({ title: 'test' });
|
316
|
+
const table = State.SQLite.table({ schema });
|
317
|
+
// Both should be nullable at column level
|
318
|
+
expect(table.sqliteDef.columns.nullableText.nullable).toBe(true);
|
319
|
+
expect(table.sqliteDef.columns.optionalText.nullable).toBe(true);
|
320
|
+
expect(table.sqliteDef.columns.optionalJson.nullable).toBe(true);
|
321
|
+
// But different schema representations
|
322
|
+
expect(table.rowSchema.fields.nullableText.toString()).toBe('string | null');
|
323
|
+
expect(table.rowSchema.fields.optionalText.toString()).toBe('string | undefined');
|
324
|
+
expect(table.rowSchema.fields.optionalJson.toString()).toBe('(parseJson <-> { readonly x: number } | undefined)');
|
325
|
+
});
|
326
|
+
it('should handle lossy Schema.optional(Schema.NullOr(...)) with JSON encoding', () => {
|
327
|
+
const schema = Schema.Struct({
|
328
|
+
id: Schema.String,
|
329
|
+
lossyText: Schema.optional(Schema.NullOr(Schema.String)),
|
330
|
+
lossyComplex: Schema.optional(Schema.NullOr(Schema.Struct({ value: Schema.Number }))),
|
331
|
+
}).annotations({ title: 'lossy_test' });
|
332
|
+
const table = State.SQLite.table({ schema });
|
333
|
+
// Check column definitions for lossy fields
|
334
|
+
expect(table.sqliteDef.columns.lossyText.nullable).toBe(true);
|
335
|
+
expect(table.sqliteDef.columns.lossyText.columnType).toBe('text');
|
336
|
+
expect(table.sqliteDef.columns.lossyComplex.nullable).toBe(true);
|
337
|
+
expect(table.sqliteDef.columns.lossyComplex.columnType).toBe('text');
|
338
|
+
// Check schema representations - should use parseJson for lossless encoding
|
339
|
+
expect(table.rowSchema.fields.lossyText.toString()).toBe('(parseJson <-> string | null | undefined)');
|
340
|
+
expect(table.rowSchema.fields.lossyComplex.toString()).toBe('(parseJson <-> { readonly value: number } | null | undefined)');
|
341
|
+
// Test actual data round-tripping to ensure losslessness
|
342
|
+
// Note: Missing field case is challenging with current Effect Schema design
|
343
|
+
// as optional fields are handled at struct level, not field level
|
344
|
+
const testCases = [
|
345
|
+
// For now, test only cases where both lossy fields are present
|
346
|
+
{ name: 'both explicit null', data: { id: '2', lossyText: null, lossyComplex: null } },
|
347
|
+
{ name: 'text value, complex null', data: { id: '3', lossyText: 'hello', lossyComplex: null } },
|
348
|
+
{ name: 'text null, complex value', data: { id: '4', lossyText: null, lossyComplex: { value: 42 } } },
|
349
|
+
{ name: 'both values', data: { id: '5', lossyText: 'world', lossyComplex: { value: 42 } } },
|
350
|
+
];
|
351
|
+
testCases.forEach((testCase) => {
|
352
|
+
// Encode through insert schema
|
353
|
+
const encoded = Schema.encodeSync(table.insertSchema)(testCase.data);
|
354
|
+
// Decode through row schema
|
355
|
+
const decoded = Schema.decodeSync(table.rowSchema)(encoded);
|
356
|
+
// Check for losslessness
|
357
|
+
expect(decoded).toEqual(testCase.data);
|
358
|
+
});
|
359
|
+
});
|
360
|
+
it('should throw when primary key is used with optional schema', () => {
|
361
|
+
// Note: Schema.optional returns a property signature, not a schema, so we can't pipe it
|
362
|
+
// Instead, we use Schema.Union to create an optional schema that can be piped
|
363
|
+
const optionalString = Schema.Union(Schema.String, Schema.Undefined);
|
364
|
+
const UserSchema = Schema.Struct({
|
365
|
+
id: optionalString.pipe(withPrimaryKey),
|
366
|
+
name: Schema.String,
|
367
|
+
});
|
368
|
+
expect(() => State.SQLite.table({
|
369
|
+
name: 'users',
|
370
|
+
schema: UserSchema,
|
371
|
+
})).toThrow('Primary key columns cannot be nullable');
|
372
|
+
});
|
373
|
+
it('should throw when primary key is used with NullOr schema', () => {
|
374
|
+
const UserSchema = Schema.Struct({
|
375
|
+
id: Schema.NullOr(Schema.String).pipe(withPrimaryKey),
|
376
|
+
name: Schema.String,
|
377
|
+
});
|
378
|
+
expect(() => State.SQLite.table({
|
379
|
+
name: 'users',
|
380
|
+
schema: UserSchema,
|
381
|
+
})).toThrow('Primary key columns cannot be nullable');
|
382
|
+
});
|
383
|
+
it('should work with column type annotation', () => {
|
384
|
+
const UserSchema = Schema.Struct({
|
385
|
+
id: Schema.Number.pipe(withColumnType('integer')).pipe(withPrimaryKey),
|
386
|
+
name: Schema.String,
|
387
|
+
});
|
388
|
+
const userTable = State.SQLite.table({
|
389
|
+
name: 'users',
|
390
|
+
schema: UserSchema,
|
391
|
+
});
|
392
|
+
expect(userTable.sqliteDef.columns.id.columnType).toBe('integer');
|
393
|
+
expect(userTable.sqliteDef.columns.id.primaryKey).toBe(true);
|
394
|
+
});
|
395
|
+
it('should work with Schema.Int and primary key', () => {
|
396
|
+
const UserSchema = Schema.Struct({
|
397
|
+
id: Schema.Int.pipe(withPrimaryKey),
|
398
|
+
name: Schema.String,
|
399
|
+
});
|
400
|
+
const userTable = State.SQLite.table({
|
401
|
+
name: 'users',
|
402
|
+
schema: UserSchema,
|
403
|
+
});
|
404
|
+
expect(userTable.sqliteDef.columns.id.columnType).toBe('integer');
|
405
|
+
expect(userTable.sqliteDef.columns.id.primaryKey).toBe(true);
|
406
|
+
});
|
407
|
+
});
|
408
|
+
describe('withAutoIncrement', () => {
|
409
|
+
it('should add autoIncrement annotation to schema', () => {
|
410
|
+
const UserSchema = Schema.Struct({
|
411
|
+
id: Schema.Int.pipe(withPrimaryKey).pipe(withAutoIncrement),
|
412
|
+
name: Schema.String,
|
413
|
+
});
|
414
|
+
const userTable = State.SQLite.table({
|
415
|
+
name: 'users',
|
416
|
+
schema: UserSchema,
|
417
|
+
});
|
418
|
+
expect(userTable.sqliteDef.columns.id.autoIncrement).toBe(true);
|
419
|
+
expect(userTable.sqliteDef.columns.id.primaryKey).toBe(true);
|
420
|
+
expect(userTable.sqliteDef.columns.id.columnType).toBe('integer');
|
421
|
+
});
|
422
|
+
});
|
423
|
+
describe('withDefault', () => {
|
424
|
+
it('should add default value annotation to schema', () => {
|
425
|
+
const UserSchema = Schema.Struct({
|
426
|
+
id: Schema.String,
|
427
|
+
active: Schema.Boolean.pipe(withDefault(true)),
|
428
|
+
createdAt: Schema.String.pipe(withDefault('CURRENT_TIMESTAMP')),
|
429
|
+
});
|
430
|
+
const userTable = State.SQLite.table({
|
431
|
+
name: 'users',
|
432
|
+
schema: UserSchema,
|
433
|
+
});
|
434
|
+
expect(userTable.sqliteDef.columns.active.default._tag).toBe('Some');
|
435
|
+
expect(userTable.sqliteDef.columns.active.default._tag === 'Some' &&
|
436
|
+
userTable.sqliteDef.columns.active.default.value).toBe(true);
|
437
|
+
expect(userTable.sqliteDef.columns.createdAt.default._tag).toBe('Some');
|
438
|
+
expect(userTable.sqliteDef.columns.createdAt.default._tag === 'Some' &&
|
439
|
+
userTable.sqliteDef.columns.createdAt.default.value).toBe('CURRENT_TIMESTAMP');
|
440
|
+
});
|
441
|
+
it('should work with dual API', () => {
|
442
|
+
const schema1 = withDefault(Schema.Int, 0);
|
443
|
+
const schema2 = Schema.Int.pipe(withDefault(0));
|
444
|
+
const UserSchema1 = Schema.Struct({ count: schema1 });
|
445
|
+
const UserSchema2 = Schema.Struct({ count: schema2 });
|
446
|
+
const table1 = State.SQLite.table({ name: 't1', schema: UserSchema1 });
|
447
|
+
const table2 = State.SQLite.table({ name: 't2', schema: UserSchema2 });
|
448
|
+
expect(table1.sqliteDef.columns.count.default._tag).toBe('Some');
|
449
|
+
expect(table1.sqliteDef.columns.count.default._tag === 'Some' && table1.sqliteDef.columns.count.default.value).toBe(0);
|
450
|
+
expect(table2.sqliteDef.columns.count.default._tag).toBe('Some');
|
451
|
+
expect(table2.sqliteDef.columns.count.default._tag === 'Some' && table2.sqliteDef.columns.count.default.value).toBe(0);
|
452
|
+
});
|
453
|
+
});
|
454
|
+
describe('withUnique', () => {
|
455
|
+
it('should create unique index for column with unique annotation', () => {
|
456
|
+
const UserSchema = Schema.Struct({
|
457
|
+
id: Schema.String,
|
458
|
+
email: Schema.String.pipe(withUnique),
|
459
|
+
username: Schema.String.pipe(withUnique),
|
460
|
+
});
|
461
|
+
const userTable = State.SQLite.table({
|
462
|
+
name: 'users',
|
463
|
+
schema: UserSchema,
|
464
|
+
});
|
465
|
+
// Check that unique indexes were created
|
466
|
+
const uniqueIndexes = userTable.sqliteDef.indexes?.filter((idx) => idx.isUnique) || [];
|
467
|
+
expect(uniqueIndexes).toHaveLength(2);
|
468
|
+
expect(uniqueIndexes.some((idx) => idx.name === 'idx_users_email_unique' && idx.columns.includes('email'))).toBe(true);
|
469
|
+
expect(uniqueIndexes.some((idx) => idx.name === 'idx_users_username_unique' && idx.columns.includes('username'))).toBe(true);
|
470
|
+
});
|
471
|
+
it('should combine unique indexes with user-provided indexes', () => {
|
472
|
+
const UserSchema = Schema.Struct({
|
473
|
+
id: Schema.String,
|
474
|
+
email: Schema.String.pipe(withUnique),
|
475
|
+
});
|
476
|
+
const userTable = State.SQLite.table({
|
477
|
+
name: 'users',
|
478
|
+
schema: UserSchema,
|
479
|
+
indexes: [{ name: 'idx_custom', columns: ['id', 'email'] }],
|
480
|
+
});
|
481
|
+
// Should have both custom index and unique index
|
482
|
+
expect(userTable.sqliteDef.indexes).toHaveLength(2);
|
483
|
+
expect(userTable.sqliteDef.indexes?.some((idx) => idx.name === 'idx_custom')).toBe(true);
|
484
|
+
expect(userTable.sqliteDef.indexes?.some((idx) => idx.name === 'idx_users_email_unique')).toBe(true);
|
485
|
+
});
|
486
|
+
});
|
487
|
+
describe('combined annotations', () => {
|
488
|
+
it('should work with multiple annotations', () => {
|
489
|
+
const schema = Schema.Uint8ArrayFromBase64.pipe(withColumnType('blob')).pipe(withPrimaryKey);
|
490
|
+
const UserSchema = Schema.Struct({
|
491
|
+
id: schema,
|
492
|
+
name: Schema.String,
|
493
|
+
});
|
494
|
+
const userTable = State.SQLite.table({
|
495
|
+
name: 'users',
|
496
|
+
schema: UserSchema,
|
497
|
+
});
|
498
|
+
expect(userTable.sqliteDef.columns.id.columnType).toBe('blob');
|
499
|
+
expect(userTable.sqliteDef.columns.id.primaryKey).toBe(true);
|
500
|
+
});
|
501
|
+
it('should combine all annotations', () => {
|
502
|
+
const UserSchema = Schema.Struct({
|
503
|
+
id: Schema.Int.pipe(withPrimaryKey).pipe(withAutoIncrement),
|
504
|
+
email: Schema.String.pipe(withUnique),
|
505
|
+
status: Schema.String.pipe(withDefault('active')),
|
506
|
+
metadata: Schema.Unknown.pipe(withColumnType('text')),
|
507
|
+
});
|
508
|
+
const userTable = State.SQLite.table({
|
509
|
+
name: 'users',
|
510
|
+
schema: UserSchema,
|
511
|
+
});
|
512
|
+
// Check id column
|
513
|
+
expect(userTable.sqliteDef.columns.id.primaryKey).toBe(true);
|
514
|
+
expect(userTable.sqliteDef.columns.id.autoIncrement).toBe(true);
|
515
|
+
expect(userTable.sqliteDef.columns.id.columnType).toBe('integer');
|
516
|
+
// Check email column and unique index
|
517
|
+
expect(userTable.sqliteDef.columns.email.columnType).toBe('text');
|
518
|
+
expect(userTable.sqliteDef.indexes?.some((idx) => idx.name === 'idx_users_email_unique' && idx.isUnique)).toBe(true);
|
519
|
+
// Check status column
|
520
|
+
expect(userTable.sqliteDef.columns.status.default._tag).toBe('Some');
|
521
|
+
expect(userTable.sqliteDef.columns.status.default._tag === 'Some' &&
|
522
|
+
userTable.sqliteDef.columns.status.default.value).toBe('active');
|
523
|
+
// Check metadata column
|
524
|
+
expect(userTable.sqliteDef.columns.metadata.columnType).toBe('text');
|
525
|
+
});
|
526
|
+
});
|
527
|
+
});
|
528
|
+
});
|
529
|
+
//# sourceMappingURL=column-def.test.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"column-def.test.js","sourceRoot":"","sources":["../../../../src/schema/state/sqlite/column-def.test.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import { type SqliteAst } from './db-schema/mod.ts';
|
2
|
+
/**
|
3
|
+
* Returns a SQLite column specification string for a table's column definitions.
|
4
|
+
*
|
5
|
+
* Example:
|
6
|
+
* ```
|
7
|
+
* 'id' integer not null autoincrement , 'email' text not null , 'username' text not null , 'created_at' text default CURRENT_TIMESTAMP, PRIMARY KEY ('id')
|
8
|
+
* ```
|
9
|
+
*/
|
10
|
+
export declare const makeColumnSpec: (tableAst: SqliteAst.Table) => string;
|
11
|
+
//# sourceMappingURL=column-spec.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"column-spec.d.ts","sourceRoot":"","sources":["../../../../src/schema/state/sqlite/column-spec.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,SAAS,EAAa,MAAM,oBAAoB,CAAA;AAE9D;;;;;;;GAOG;AACH,eAAO,MAAM,cAAc,GAAI,UAAU,SAAS,CAAC,KAAK,WASvD,CAAA"}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import { Schema } from '@livestore/utils/effect';
|
2
|
+
import { SqliteDsl } from "./db-schema/mod.js";
|
3
|
+
/**
|
4
|
+
* Returns a SQLite column specification string for a table's column definitions.
|
5
|
+
*
|
6
|
+
* Example:
|
7
|
+
* ```
|
8
|
+
* 'id' integer not null autoincrement , 'email' text not null , 'username' text not null , 'created_at' text default CURRENT_TIMESTAMP, PRIMARY KEY ('id')
|
9
|
+
* ```
|
10
|
+
*/
|
11
|
+
export const makeColumnSpec = (tableAst) => {
|
12
|
+
const primaryKeys = tableAst.columns.filter((_) => _.primaryKey).map((_) => `'${_.name}'`);
|
13
|
+
const columnDefStrs = tableAst.columns.map(toSqliteColumnSpec);
|
14
|
+
if (primaryKeys.length > 0) {
|
15
|
+
columnDefStrs.push(`PRIMARY KEY (${primaryKeys.join(', ')})`);
|
16
|
+
}
|
17
|
+
return columnDefStrs.join(', ');
|
18
|
+
};
|
19
|
+
/** NOTE primary keys are applied on a table level not on a column level to account for multi-column primary keys */
|
20
|
+
const toSqliteColumnSpec = (column) => {
|
21
|
+
const columnTypeStr = column.type._tag;
|
22
|
+
const nullableStr = column.nullable === false ? 'not null' : '';
|
23
|
+
const autoIncrementStr = column.autoIncrement ? 'autoincrement' : '';
|
24
|
+
const defaultValueStr = (() => {
|
25
|
+
if (column.default._tag === 'None')
|
26
|
+
return '';
|
27
|
+
if (column.default.value === null)
|
28
|
+
return 'default null';
|
29
|
+
if (SqliteDsl.isSqlDefaultValue(column.default.value))
|
30
|
+
return `default ${column.default.value.sql}`;
|
31
|
+
const encodeValue = Schema.encodeSync(column.schema);
|
32
|
+
const encodedDefaultValue = encodeValue(column.default.value);
|
33
|
+
if (columnTypeStr === 'text')
|
34
|
+
return `default '${encodedDefaultValue}'`;
|
35
|
+
return `default ${encodedDefaultValue}`;
|
36
|
+
})();
|
37
|
+
return `'${column.name}' ${columnTypeStr} ${nullableStr} ${autoIncrementStr} ${defaultValueStr}`;
|
38
|
+
};
|
39
|
+
//# sourceMappingURL=column-spec.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"column-spec.js","sourceRoot":"","sources":["../../../../src/schema/state/sqlite/column-spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAChD,OAAO,EAAkB,SAAS,EAAE,MAAM,oBAAoB,CAAA;AAE9D;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,QAAyB,EAAE,EAAE;IAC1D,MAAM,WAAW,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAA;IAC1F,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;IAE9D,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,aAAa,CAAC,IAAI,CAAC,gBAAgB,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAC/D,CAAC;IAED,OAAO,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACjC,CAAC,CAAA;AAED,oHAAoH;AACpH,MAAM,kBAAkB,GAAG,CAAC,MAAwB,EAAE,EAAE;IACtD,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAA;IACtC,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAA;IAC/D,MAAM,gBAAgB,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAA;IACpE,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE;QAC5B,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,KAAK,MAAM;YAAE,OAAO,EAAE,CAAA;QAE7C,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,KAAK,IAAI;YAAE,OAAO,cAAc,CAAA;QACxD,IAAI,SAAS,CAAC,iBAAiB,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;YAAE,OAAO,WAAW,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,CAAA;QAEnG,MAAM,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACpD,MAAM,mBAAmB,GAAG,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;QAE7D,IAAI,aAAa,KAAK,MAAM;YAAE,OAAO,YAAY,mBAAmB,GAAG,CAAA;QACvE,OAAO,WAAW,mBAAmB,EAAE,CAAA;IACzC,CAAC,CAAC,EAAE,CAAA;IAEJ,OAAO,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,IAAI,WAAW,IAAI,gBAAgB,IAAI,eAAe,EAAE,CAAA;AAClG,CAAC,CAAA"}
|