Make schema classes public (#2749)

This commit is contained in:
Simon Binder 2023-11-27 22:48:37 +01:00
parent 81d7e92d30
commit 434982ac85
No known key found for this signature in database
GPG Key ID: 7891917E4147B8C0
4 changed files with 66 additions and 60 deletions

View File

@ -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(

View File

@ -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.

View File

@ -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);')

View File

@ -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(