Skip to content
This repository has been archived by the owner on Nov 1, 2024. It is now read-only.

Commit

Permalink
feat: support docs for libraries
Browse files Browse the repository at this point in the history
Signed-off-by: Nikolas Rimikis <[email protected]>
  • Loading branch information
Leptopoda committed Dec 28, 2023
1 parent 4d097c4 commit 3e75017
Show file tree
Hide file tree
Showing 7 changed files with 59 additions and 7 deletions.
3 changes: 2 additions & 1 deletion AUTHORS
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@
#
# Name/Organization <email address>

Google Inc.
Nikolas Rimikis <[email protected]>
Google Inc.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
## 4.10.0-wip

* Add `Library.docs` to support emitting doc comments on libraries.

## 4.9.0

* Add `Library.generatedByComment` to support emitting 'generated by' comments.
Expand Down
6 changes: 3 additions & 3 deletions lib/src/emitter.dart
Original file line number Diff line number Diff line change
Expand Up @@ -512,15 +512,15 @@ class DartEmitter extends Object
}
}

spec.docs.forEach(output.writeln);
for (var a in spec.annotations) {
visitAnnotation(a, output);
}
if (spec.name != null) {
output.write('library ${spec.name!};');
} else if (spec.annotations.isNotEmpty) {
} else if (spec.annotations.isNotEmpty || spec.docs.isNotEmpty) {
// An explicit _unnamed_ library directive is only required if there are
// annotations or doc comments on the library (though doc comments are not
// currently supported in code_builder).
// annotations or doc comments on the library.
output.write('library;');
}

Expand Down
11 changes: 9 additions & 2 deletions lib/src/specs/library.dart
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import 'package:meta/meta.dart';

import '../base.dart';
import '../mixins/annotations.dart';
import '../mixins/dartdoc.dart';
import '../visitors.dart';
import 'directive.dart';
import 'expression.dart';
Expand All @@ -16,14 +17,17 @@ part 'library.g.dart';

@immutable
abstract class Library
with HasAnnotations
with HasAnnotations, HasDartDocs
implements Built<Library, LibraryBuilder>, Spec {
factory Library([void Function(LibraryBuilder) updates]) = _$Library;
Library._();

@override
BuiltList<Expression> get annotations;

@override
BuiltList<String> get docs;

BuiltList<Directive> get directives;
BuiltList<Spec> get body;

Expand Down Expand Up @@ -53,14 +57,17 @@ abstract class Library
}

abstract class LibraryBuilder
with HasAnnotationsBuilder
with HasAnnotationsBuilder, HasDartDocsBuilder
implements Builder<Library, LibraryBuilder> {
factory LibraryBuilder() = _$LibraryBuilder;
LibraryBuilder._();

@override
ListBuilder<Expression> annotations = ListBuilder<Expression>();

@override
ListBuilder<String> docs = ListBuilder<String>();

ListBuilder<Spec> body = ListBuilder<Spec>();
ListBuilder<Directive> directives = ListBuilder<Directive>();

Expand Down
23 changes: 23 additions & 0 deletions lib/src/specs/library.g.dart

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion pubspec.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
name: code_builder
version: 4.9.0
version: 4.10.0-wip
description: >-
A fluent, builder-based library for generating valid Dart code
repository: https://github.com/dart-lang/code_builder
Expand Down
17 changes: 17 additions & 0 deletions test/specs/library_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -292,5 +292,22 @@ void main() {
''', DartEmitter(allocator: Allocator())),
);
});

test('should emit an unnamed library source file with documentation', () {
expect(
Library(
(b) => b
..docs.addAll(
const [
'/// My favorite library.',
],
),
),
equalsDart(r'''
/// My favorite library.
library;
'''),
);
});
});
}

0 comments on commit 3e75017

Please sign in to comment.