io.github.mmm.code.api.item.CodeItem Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mmm-code-api Show documentation
Show all versions of mmm-code-api Show documentation
The API to parse, analyze, transform and generate code.
/* Copyright (c) The m-m-m Team, Licensed under the Apache License, Version 2.0
* http://www.apache.org/licenses/LICENSE-2.0 */
package io.github.mmm.code.api.item;
import io.github.mmm.code.api.language.CodeLanguage;
import io.github.mmm.code.api.language.JavaLanguage;
/**
* Abstract top-level interface for any item of code as defined by this API. It reflects code structure.
*
* @author Joerg Hohwiller (hohwille at users.sourceforge.net)
* @since 1.0.0
*/
public abstract interface CodeItem {
/** The default newline (line feed). */
String DEFAULT_NEWLINE = "\n";
/** The default indent (2 spaces). */
String DEFAULT_INDENT = " ";
/**
* @return the source-code of this item.
*/
default String write() {
StringBuilder sb = new StringBuilder();
write(sb);
return sb.toString();
}
/**
* @param sink the {@link Appendable} where to {@link Appendable#append(CharSequence) append} the
* {@link #getSourceCode() source code} from this {@link CodeItem}.
*/
default void write(Appendable sink) {
write(sink, DEFAULT_NEWLINE);
}
/**
* @param sink the {@link Appendable} where to {@link Appendable#append(CharSequence) append} the
* {@link #getSourceCode() source code} from this {@link CodeItem}.
* @param newline the newline {@link String}.
*/
default void write(Appendable sink, String newline) {
write(sink, newline, DEFAULT_INDENT);
}
/**
* @param sink the {@link Appendable} where to {@link Appendable#append(CharSequence) append} the
* {@link #getSourceCode() source code} from this {@link CodeItem}.
* @param newline the newline {@link String}.
* @param defaultIndent the {@link String} used for indentation (e.g. a number of spaces to insert per indent level).
*/
default void write(Appendable sink, String newline, String defaultIndent) {
write(sink, newline, defaultIndent, "");
}
/**
* @param sink the {@link Appendable} where to {@link Appendable#append(CharSequence) append} the
* {@link #getSourceCode() source code} from this {@link CodeItem}.
* @param newline the newline {@link String}.
* @param defaultIndent the {@link String} used for indentation (e.g. a number of spaces to insert per indent level).
* @param currentIndent the current indent (number of spaces). Initially the empty string ({@code ""}). Before a
* recursion the {@code defaultIndent} will be appended.
*/
default void write(Appendable sink, String newline, String defaultIndent, String currentIndent) {
write(sink, newline, defaultIndent, currentIndent, getLanguage());
}
/**
* @return the {@link CodeLanguage} to use.
*/
default CodeLanguage getLanguage() {
return JavaLanguage.get();
}
/**
* @param sink the {@link Appendable} where to {@link Appendable#append(CharSequence) append} the
* {@link #getSourceCode() source code} from this {@link CodeItem}.
* @param newline the newline {@link String}.
* @param defaultIndent the {@link String} used for indentation (e.g. a number of spaces to insert per indent level).
* @param currentIndent the current indent (number of spaces). Initially the empty string ({@code ""}). Before a
* recursion the {@code defaultIndent} will be appended.
* @param language the {@link CodeLanguage} to use.
*/
void write(Appendable sink, String newline, String defaultIndent, String currentIndent, CodeLanguage language);
/**
* @return the source code of this item.
* @see #write(Appendable)
*/
String getSourceCode();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy