-
Notifications
You must be signed in to change notification settings - Fork 210
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Finalize design for phases API #67
Comments
So, thinking about this a bit more it does seem a bit unfortunate to have to make all |
What if we used the builder pattern, and did something like this? // USAGE
class FakeBuilder implements Builder {
Future build(_) async => throw new UnimplementedError();
List<AssetId> declareOutputs(AssetId input) => throw new UnimplementedError();
}
main() async {
var builder = new FakeBuilder();
var fooLibInputs = new InputSet('foo', const ['lib/**/*.dart']);
var barLibInputs = new InputSet('bar', const ['lib/**/*.dart']);
var bazLibInputs = new InputSet('baz', const ['lib/**/*.dart']);
// Shorthand for the simple case.
await build(new PhaseGroup.singleAction(builder, fooLibInputs));
// Alternative version of the simple case.
var singlePhase = new Phase()..addAction(builder, fooLibInputs);
await build(new PhaseGroup()..addPhase(singlePhase));
// A Phase with multiple concurrent actions
var parallelPhase = new Phase()
..addAction(builder, fooLibInputs)
..addAction(builder, barLibInputs)
..addAction(builder, bazLibInputs);
await build(new PhaseGroup()..addPhase(parallelPhase));
// Multiple phases that run sequentially
await build(new PhaseGroup()..addPhase(singlePhase)..addPhase(parallelPhase));
}
// IMPLEMENTATION
class BuildAction {
final Builder builder;
final InputSet inputSet;
BuildAction(this.builder, this.inputSet);
}
class Phase {
final _actions = <BuildAction>[];
List<BuildAction> get actions => new List.unmodifiable(_actions);
addAction(Builder builder, InputSet inputSet) {
_actions.add(new BuildAction(builder, inputSet));
}
}
class PhaseGroup {
final _phases = <Phase>[];
List<List<BuildAction>> get buildActions =>
new List.unmodifiable(_phases.map((phase) => phase.actions));
PhaseGroup();
// Could add additional constructors which take lists of phases, etc later on.
factory PhaseGroup.singleAction(Builder builder, InputSet inputSet) =>
new PhaseGroup().newPhase().addAction(builder, inputSet);
Phase newPhase() {
var phase = new Phase();
_phases.add(phase);
return phase;
}
void addPhase(Phase phase) {
_phases.add(phase);
}
String toString() {
var buffer = new StringBuffer();
for (int i = 0; i < _phases.length; i++) {
buffer.writeln('Phase $i:');
for (var action in _phases[i].actions) {
buffer
..writeln(' Action:')
..writeln(' Builder: ${action.builder}')
..writeln(' InputSet:${action.inputSet}');
}
}
return buffer.toString();
}
} It is a bit more boilerplate but I think its also more readable. This also has the advantage of allowing you to pass a |
cc @nex3 @munificent what do you think about the last option I posted? |
Another option would be to make the top level |
The example code seems pretty reasonable to me. |
Your follow-up. |
The text was updated successfully, but these errors were encountered: