Java のフォーマット文字列の構文は、次のように複雑になる可能性があります。
"|%1$-10s|%2$-10s|%3$-20s|\n"
これらのフォーマット文字列の構築を支援する流暢な DSL を作成する機は熟しているように思われます ( Jooqが SQL に対して行っているのと同様)。
そのようなものは存在しますか?
このような API は、 jOOQ のAPI とjOOQ の基礎となる API 設計手法fluflu
に触発された流暢な API ジェネレーターを使用して作成できます。
Fluflu は、API 実装から流暢な API を生成するために APT ツールを使用して処理されるアノテーションを提供します。注釈は、有限状態マシンをモデル化します。彼らのウィキからの例を次に示します。
@Fluentize(className = "CoreClass", startState = "State0", startMethod = "start")
public abstract class ToBeFluentized implements Cloneable {
@Transitions({
@Transition(from = "State0", end = true),
@Transition(from = "State1", end = true)
})
public void end() {
}
protected String with = null;
protected List<byte[]> b = new LinkedList<>();
@Transition(from = { "State0", "State1" }, to = "State0")
public abstract ToBeFluentized with(
@AssignTo("with") String a, @AddTo("b") byte[] b
);
@Transition(from = "State1", to = "State0")
public ToBeFluentized z() {
return this;
}
Set<Integer> j = new HashSet<>();
@Transition(from = "State1", to = "State1", name="a")
public abstract ToBeFluentized z(@AddTo("j") int j);
@Transition(from = "State0", to = "State1")
public ToBeFluentized a() {
return this;
}
@Transition(from = "State0", to = "State1")
public ToBeFluentized b() {
return this;
}
@Transition(from = "State0", to = "State1")
public ToBeFluentized vari(String... strings) {
return this;
}
}
これは、次のように使用できます。
State0 c = CoreClass.start().a().z();
State0 d = c.b().with("z", "z".getBytes());
State0 e = c.b().with("q", new byte[]{0,0,1});
d.end();
e.end();
もちろん、まだ実装を書く必要があります:-)