mirror of https://github.com/AMT-Cheif/drift.git
Make schema classes public (#2749)
This commit is contained in:
parent
81d7e92d30
commit
434982ac85
|
@ -3,8 +3,8 @@ import 'package:drift/drift.dart' as i1;
|
||||||
import 'package:drift/drift.dart'; // ignore_for_file: type=lint,unused_import
|
import 'package:drift/drift.dart'; // ignore_for_file: type=lint,unused_import
|
||||||
|
|
||||||
// GENERATED BY drift_dev, DO NOT MODIFY.
|
// GENERATED BY drift_dev, DO NOT MODIFY.
|
||||||
final class _S2 extends i0.VersionedSchema {
|
final class Schema2 extends i0.VersionedSchema {
|
||||||
_S2({required super.database}) : super(version: 2);
|
Schema2({required super.database}) : super(version: 2);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
todos,
|
todos,
|
||||||
|
@ -62,8 +62,8 @@ i1.GeneratedColumn<DateTime> _column_4(String aliasedName) =>
|
||||||
i1.GeneratedColumn<DateTime>('due_date', aliasedName, true,
|
i1.GeneratedColumn<DateTime>('due_date', aliasedName, true,
|
||||||
type: i1.DriftSqlType.dateTime);
|
type: i1.DriftSqlType.dateTime);
|
||||||
|
|
||||||
final class _S3 extends i0.VersionedSchema {
|
final class Schema3 extends i0.VersionedSchema {
|
||||||
_S3({required super.database}) : super(version: 3);
|
Schema3({required super.database}) : super(version: 3);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
todos,
|
todos,
|
||||||
|
@ -107,18 +107,18 @@ i1.GeneratedColumn<int> _column_5(String aliasedName) =>
|
||||||
i1.GeneratedColumn<int>('priority', aliasedName, true,
|
i1.GeneratedColumn<int>('priority', aliasedName, true,
|
||||||
type: i1.DriftSqlType.int);
|
type: i1.DriftSqlType.int);
|
||||||
i0.MigrationStepWithVersion migrationSteps({
|
i0.MigrationStepWithVersion migrationSteps({
|
||||||
required Future<void> Function(i1.Migrator m, _S2 schema) from1To2,
|
required Future<void> Function(i1.Migrator m, Schema2 schema) from1To2,
|
||||||
required Future<void> Function(i1.Migrator m, _S3 schema) from2To3,
|
required Future<void> Function(i1.Migrator m, Schema3 schema) from2To3,
|
||||||
}) {
|
}) {
|
||||||
return (currentVersion, database) async {
|
return (currentVersion, database) async {
|
||||||
switch (currentVersion) {
|
switch (currentVersion) {
|
||||||
case 1:
|
case 1:
|
||||||
final schema = _S2(database: database);
|
final schema = Schema2(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from1To2(migrator, schema);
|
await from1To2(migrator, schema);
|
||||||
return 2;
|
return 2;
|
||||||
case 2:
|
case 2:
|
||||||
final schema = _S3(database: database);
|
final schema = Schema3(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from2To3(migrator, schema);
|
await from2To3(migrator, schema);
|
||||||
return 3;
|
return 3;
|
||||||
|
@ -129,8 +129,8 @@ i0.MigrationStepWithVersion migrationSteps({
|
||||||
}
|
}
|
||||||
|
|
||||||
i1.OnUpgrade stepByStep({
|
i1.OnUpgrade stepByStep({
|
||||||
required Future<void> Function(i1.Migrator m, _S2 schema) from1To2,
|
required Future<void> Function(i1.Migrator m, Schema2 schema) from1To2,
|
||||||
required Future<void> Function(i1.Migrator m, _S3 schema) from2To3,
|
required Future<void> Function(i1.Migrator m, Schema3 schema) from2To3,
|
||||||
}) =>
|
}) =>
|
||||||
i0.VersionedSchema.stepByStepHelper(
|
i0.VersionedSchema.stepByStepHelper(
|
||||||
step: migrationSteps(
|
step: migrationSteps(
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
of the Dart table name now supports more forms of plurals.
|
of the Dart table name now supports more forms of plurals.
|
||||||
For instance, a table without a `@DataClassName` annotation named `Categories`
|
For instance, a table without a `@DataClassName` annotation named `Categories`
|
||||||
would now generate a `Category` class instead of `Categorie`.
|
would now generate a `Category` class instead of `Categorie`.
|
||||||
|
- Make versioned schema snapshots generated by `drift_dev schema steps` public.
|
||||||
- Don't generate `const` row classes when they are extending a class which
|
- Don't generate `const` row classes when they are extending a class which
|
||||||
isn't const.
|
isn't const.
|
||||||
|
|
||||||
|
|
|
@ -75,6 +75,10 @@ class SchemaVersionWriter {
|
||||||
assert(versions.isSortedBy<num>((element) => element.version));
|
assert(versions.isSortedBy<num>((element) => element.version));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String _nameForSchemaClass(int version) {
|
||||||
|
return 'Schema$version';
|
||||||
|
}
|
||||||
|
|
||||||
/// Since not every column changes in every schema version, we prefer to re-use
|
/// Since not every column changes in every schema version, we prefer to re-use
|
||||||
/// columns with an identical definition across tables and schema versions.
|
/// columns with an identical definition across tables and schema versions.
|
||||||
///
|
///
|
||||||
|
@ -308,7 +312,7 @@ class SchemaVersionWriter {
|
||||||
text
|
text
|
||||||
..write('required Future<void> Function(')
|
..write('required Future<void> Function(')
|
||||||
..writeDriftRef('Migrator')
|
..writeDriftRef('Migrator')
|
||||||
..write(' m, _S${next.version} schema)')
|
..write(' m, ${_nameForSchemaClass(next.version)} schema)')
|
||||||
..writeln('from${current.version}To${next.version},');
|
..writeln('from${current.version}To${next.version},');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -322,7 +326,7 @@ class SchemaVersionWriter {
|
||||||
// only need them for versions targeted by migrations.
|
// only need them for versions targeted by migrations.
|
||||||
for (final version in versions.skip(1)) {
|
for (final version in versions.skip(1)) {
|
||||||
final versionNo = version.version;
|
final versionNo = version.version;
|
||||||
final versionClass = '_S$versionNo';
|
final versionClass = _nameForSchemaClass(version.version);
|
||||||
final versionScope = libraryScope.child();
|
final versionScope = libraryScope.child();
|
||||||
|
|
||||||
// Reserve all the names already in use in [VersionedSchema] and its
|
// Reserve all the names already in use in [VersionedSchema] and its
|
||||||
|
@ -336,7 +340,7 @@ class SchemaVersionWriter {
|
||||||
'runMigrationSteps',
|
'runMigrationSteps',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// Write an _S<x> class for each schema version x.
|
// Write an Schema<x> class for each schema version x.
|
||||||
versionScope.leaf()
|
versionScope.leaf()
|
||||||
..write('final class $versionClass extends ')
|
..write('final class $versionClass extends ')
|
||||||
..writeUriRef(_schemaLibrary, 'VersionedSchema')
|
..writeUriRef(_schemaLibrary, 'VersionedSchema')
|
||||||
|
@ -367,7 +371,7 @@ class SchemaVersionWriter {
|
||||||
// Write a MigrationStepWithVersion factory that takes a callback doing a
|
// Write a MigrationStepWithVersion factory that takes a callback doing a
|
||||||
// step for each schema to to the next. We supply a special migrator that
|
// step for each schema to to the next. We supply a special migrator that
|
||||||
// only considers entities from that version, as well as a typed reference
|
// only considers entities from that version, as well as a typed reference
|
||||||
// to the _S<x> class used to lookup elements.
|
// to the numbered Schema<x> class used to lookup elements.
|
||||||
final steps = libraryScope.leaf()
|
final steps = libraryScope.leaf()
|
||||||
..writeUriRef(_schemaLibrary, 'MigrationStepWithVersion')
|
..writeUriRef(_schemaLibrary, 'MigrationStepWithVersion')
|
||||||
..write(' migrationSteps({');
|
..write(' migrationSteps({');
|
||||||
|
@ -380,7 +384,8 @@ class SchemaVersionWriter {
|
||||||
for (final (current, next) in versions.withNext) {
|
for (final (current, next) in versions.withNext) {
|
||||||
steps
|
steps
|
||||||
..writeln('case ${current.version}:')
|
..writeln('case ${current.version}:')
|
||||||
..write('final schema = _S${next.version}(database: database);')
|
..write(
|
||||||
|
'final schema = ${_nameForSchemaClass(next.version)}(database: database);')
|
||||||
..write('final migrator = ')
|
..write('final migrator = ')
|
||||||
..writeDriftRef('Migrator')
|
..writeDriftRef('Migrator')
|
||||||
..writeln('(database, schema);')
|
..writeln('(database, schema);')
|
||||||
|
|
|
@ -3,8 +3,8 @@ import 'package:drift/drift.dart' as i1;
|
||||||
import 'package:drift/drift.dart'; // ignore_for_file: type=lint,unused_import
|
import 'package:drift/drift.dart'; // ignore_for_file: type=lint,unused_import
|
||||||
|
|
||||||
// GENERATED BY drift_dev, DO NOT MODIFY.
|
// GENERATED BY drift_dev, DO NOT MODIFY.
|
||||||
final class _S2 extends i0.VersionedSchema {
|
final class Schema2 extends i0.VersionedSchema {
|
||||||
_S2({required super.database}) : super(version: 2);
|
Schema2({required super.database}) : super(version: 2);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -42,8 +42,8 @@ i1.GeneratedColumn<String> _column_1(String aliasedName) =>
|
||||||
i1.GeneratedColumn<String>('name', aliasedName, false,
|
i1.GeneratedColumn<String>('name', aliasedName, false,
|
||||||
type: i1.DriftSqlType.string);
|
type: i1.DriftSqlType.string);
|
||||||
|
|
||||||
final class _S3 extends i0.VersionedSchema {
|
final class Schema3 extends i0.VersionedSchema {
|
||||||
_S3({required super.database}) : super(version: 3);
|
Schema3({required super.database}) : super(version: 3);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -109,8 +109,8 @@ i1.GeneratedColumn<int> _column_5(String aliasedName) =>
|
||||||
type: i1.DriftSqlType.int,
|
type: i1.DriftSqlType.int,
|
||||||
$customConstraints: 'NOT NULL REFERENCES users (id)');
|
$customConstraints: 'NOT NULL REFERENCES users (id)');
|
||||||
|
|
||||||
final class _S4 extends i0.VersionedSchema {
|
final class Schema4 extends i0.VersionedSchema {
|
||||||
_S4({required super.database}) : super(version: 4);
|
Schema4({required super.database}) : super(version: 4);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -152,8 +152,8 @@ i1.GeneratedColumn<String> _column_6(String aliasedName) =>
|
||||||
i1.GeneratedColumn<String>('name', aliasedName, false,
|
i1.GeneratedColumn<String>('name', aliasedName, false,
|
||||||
type: i1.DriftSqlType.string, defaultValue: const Constant('name'));
|
type: i1.DriftSqlType.string, defaultValue: const Constant('name'));
|
||||||
|
|
||||||
final class _S5 extends i0.VersionedSchema {
|
final class Schema5 extends i0.VersionedSchema {
|
||||||
_S5({required super.database}) : super(version: 5);
|
Schema5({required super.database}) : super(version: 5);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -245,8 +245,8 @@ i1.GeneratedColumn<int> _column_10(String aliasedName) =>
|
||||||
i1.GeneratedColumn<int>('group_count', aliasedName, false,
|
i1.GeneratedColumn<int>('group_count', aliasedName, false,
|
||||||
type: i1.DriftSqlType.int);
|
type: i1.DriftSqlType.int);
|
||||||
|
|
||||||
final class _S6 extends i0.VersionedSchema {
|
final class Schema6 extends i0.VersionedSchema {
|
||||||
_S6({required super.database}) : super(version: 6);
|
Schema6({required super.database}) : super(version: 6);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -332,8 +332,8 @@ class Shape5 extends i0.VersionedView {
|
||||||
columnsByName['group_count']! as i1.GeneratedColumn<int>;
|
columnsByName['group_count']! as i1.GeneratedColumn<int>;
|
||||||
}
|
}
|
||||||
|
|
||||||
final class _S7 extends i0.VersionedSchema {
|
final class Schema7 extends i0.VersionedSchema {
|
||||||
_S7({required super.database}) : super(version: 7);
|
Schema7({required super.database}) : super(version: 7);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -423,8 +423,8 @@ i1.GeneratedColumn<String> _column_14(String aliasedName) =>
|
||||||
i1.GeneratedColumn<String>('search_terms', aliasedName, false,
|
i1.GeneratedColumn<String>('search_terms', aliasedName, false,
|
||||||
type: i1.DriftSqlType.string, $customConstraints: '');
|
type: i1.DriftSqlType.string, $customConstraints: '');
|
||||||
|
|
||||||
final class _S8 extends i0.VersionedSchema {
|
final class Schema8 extends i0.VersionedSchema {
|
||||||
_S8({required super.database}) : super(version: 8);
|
Schema8({required super.database}) : super(version: 8);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -502,8 +502,8 @@ i1.GeneratedColumn<int> _column_15(String aliasedName) =>
|
||||||
defaultConstraints:
|
defaultConstraints:
|
||||||
i1.GeneratedColumn.constraintIsAlways('REFERENCES "users" ("id")'));
|
i1.GeneratedColumn.constraintIsAlways('REFERENCES "users" ("id")'));
|
||||||
|
|
||||||
final class _S9 extends i0.VersionedSchema {
|
final class Schema9 extends i0.VersionedSchema {
|
||||||
_S9({required super.database}) : super(version: 9);
|
Schema9({required super.database}) : super(version: 9);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -586,8 +586,8 @@ i1.GeneratedColumn<int> _column_17(String aliasedName) =>
|
||||||
type: i1.DriftSqlType.int,
|
type: i1.DriftSqlType.int,
|
||||||
$customConstraints: 'NOT NULL REFERENCES users(id)');
|
$customConstraints: 'NOT NULL REFERENCES users(id)');
|
||||||
|
|
||||||
final class _S10 extends i0.VersionedSchema {
|
final class Schema10 extends i0.VersionedSchema {
|
||||||
_S10({required super.database}) : super(version: 10);
|
Schema10({required super.database}) : super(version: 10);
|
||||||
@override
|
@override
|
||||||
late final List<i1.DatabaseSchemaEntity> entities = [
|
late final List<i1.DatabaseSchemaEntity> entities = [
|
||||||
users,
|
users,
|
||||||
|
@ -664,60 +664,60 @@ final class _S10 extends i0.VersionedSchema {
|
||||||
}
|
}
|
||||||
|
|
||||||
i0.MigrationStepWithVersion migrationSteps({
|
i0.MigrationStepWithVersion migrationSteps({
|
||||||
required Future<void> Function(i1.Migrator m, _S2 schema) from1To2,
|
required Future<void> Function(i1.Migrator m, Schema2 schema) from1To2,
|
||||||
required Future<void> Function(i1.Migrator m, _S3 schema) from2To3,
|
required Future<void> Function(i1.Migrator m, Schema3 schema) from2To3,
|
||||||
required Future<void> Function(i1.Migrator m, _S4 schema) from3To4,
|
required Future<void> Function(i1.Migrator m, Schema4 schema) from3To4,
|
||||||
required Future<void> Function(i1.Migrator m, _S5 schema) from4To5,
|
required Future<void> Function(i1.Migrator m, Schema5 schema) from4To5,
|
||||||
required Future<void> Function(i1.Migrator m, _S6 schema) from5To6,
|
required Future<void> Function(i1.Migrator m, Schema6 schema) from5To6,
|
||||||
required Future<void> Function(i1.Migrator m, _S7 schema) from6To7,
|
required Future<void> Function(i1.Migrator m, Schema7 schema) from6To7,
|
||||||
required Future<void> Function(i1.Migrator m, _S8 schema) from7To8,
|
required Future<void> Function(i1.Migrator m, Schema8 schema) from7To8,
|
||||||
required Future<void> Function(i1.Migrator m, _S9 schema) from8To9,
|
required Future<void> Function(i1.Migrator m, Schema9 schema) from8To9,
|
||||||
required Future<void> Function(i1.Migrator m, _S10 schema) from9To10,
|
required Future<void> Function(i1.Migrator m, Schema10 schema) from9To10,
|
||||||
}) {
|
}) {
|
||||||
return (currentVersion, database) async {
|
return (currentVersion, database) async {
|
||||||
switch (currentVersion) {
|
switch (currentVersion) {
|
||||||
case 1:
|
case 1:
|
||||||
final schema = _S2(database: database);
|
final schema = Schema2(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from1To2(migrator, schema);
|
await from1To2(migrator, schema);
|
||||||
return 2;
|
return 2;
|
||||||
case 2:
|
case 2:
|
||||||
final schema = _S3(database: database);
|
final schema = Schema3(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from2To3(migrator, schema);
|
await from2To3(migrator, schema);
|
||||||
return 3;
|
return 3;
|
||||||
case 3:
|
case 3:
|
||||||
final schema = _S4(database: database);
|
final schema = Schema4(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from3To4(migrator, schema);
|
await from3To4(migrator, schema);
|
||||||
return 4;
|
return 4;
|
||||||
case 4:
|
case 4:
|
||||||
final schema = _S5(database: database);
|
final schema = Schema5(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from4To5(migrator, schema);
|
await from4To5(migrator, schema);
|
||||||
return 5;
|
return 5;
|
||||||
case 5:
|
case 5:
|
||||||
final schema = _S6(database: database);
|
final schema = Schema6(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from5To6(migrator, schema);
|
await from5To6(migrator, schema);
|
||||||
return 6;
|
return 6;
|
||||||
case 6:
|
case 6:
|
||||||
final schema = _S7(database: database);
|
final schema = Schema7(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from6To7(migrator, schema);
|
await from6To7(migrator, schema);
|
||||||
return 7;
|
return 7;
|
||||||
case 7:
|
case 7:
|
||||||
final schema = _S8(database: database);
|
final schema = Schema8(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from7To8(migrator, schema);
|
await from7To8(migrator, schema);
|
||||||
return 8;
|
return 8;
|
||||||
case 8:
|
case 8:
|
||||||
final schema = _S9(database: database);
|
final schema = Schema9(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from8To9(migrator, schema);
|
await from8To9(migrator, schema);
|
||||||
return 9;
|
return 9;
|
||||||
case 9:
|
case 9:
|
||||||
final schema = _S10(database: database);
|
final schema = Schema10(database: database);
|
||||||
final migrator = i1.Migrator(database, schema);
|
final migrator = i1.Migrator(database, schema);
|
||||||
await from9To10(migrator, schema);
|
await from9To10(migrator, schema);
|
||||||
return 10;
|
return 10;
|
||||||
|
@ -728,15 +728,15 @@ i0.MigrationStepWithVersion migrationSteps({
|
||||||
}
|
}
|
||||||
|
|
||||||
i1.OnUpgrade stepByStep({
|
i1.OnUpgrade stepByStep({
|
||||||
required Future<void> Function(i1.Migrator m, _S2 schema) from1To2,
|
required Future<void> Function(i1.Migrator m, Schema2 schema) from1To2,
|
||||||
required Future<void> Function(i1.Migrator m, _S3 schema) from2To3,
|
required Future<void> Function(i1.Migrator m, Schema3 schema) from2To3,
|
||||||
required Future<void> Function(i1.Migrator m, _S4 schema) from3To4,
|
required Future<void> Function(i1.Migrator m, Schema4 schema) from3To4,
|
||||||
required Future<void> Function(i1.Migrator m, _S5 schema) from4To5,
|
required Future<void> Function(i1.Migrator m, Schema5 schema) from4To5,
|
||||||
required Future<void> Function(i1.Migrator m, _S6 schema) from5To6,
|
required Future<void> Function(i1.Migrator m, Schema6 schema) from5To6,
|
||||||
required Future<void> Function(i1.Migrator m, _S7 schema) from6To7,
|
required Future<void> Function(i1.Migrator m, Schema7 schema) from6To7,
|
||||||
required Future<void> Function(i1.Migrator m, _S8 schema) from7To8,
|
required Future<void> Function(i1.Migrator m, Schema8 schema) from7To8,
|
||||||
required Future<void> Function(i1.Migrator m, _S9 schema) from8To9,
|
required Future<void> Function(i1.Migrator m, Schema9 schema) from8To9,
|
||||||
required Future<void> Function(i1.Migrator m, _S10 schema) from9To10,
|
required Future<void> Function(i1.Migrator m, Schema10 schema) from9To10,
|
||||||
}) =>
|
}) =>
|
||||||
i0.VersionedSchema.stepByStepHelper(
|
i0.VersionedSchema.stepByStepHelper(
|
||||||
step: migrationSteps(
|
step: migrationSteps(
|
||||||
|
|
Loading…
Reference in New Issue