NX01: Rename nether to top level for preparing dial tones

This commit is contained in:
Willem Cazander 2026-01-23 11:54:16 +01:00
parent 4af51ad9ae
commit e69a13ec92
12 changed files with 122 additions and 40 deletions

View file

@ -31,8 +31,8 @@ import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Arrays;
import java.util.List;
import java.util.Iterator;
import java.util.ServiceLoader;
import love.distributedrebirth.nx01.kode.generator.klass.ModelKlassWriter;
@ -45,23 +45,28 @@ public class KodeGen {
private final static String SERIAL_VERSON_ID = "13";
public static void main(String[] args) throws IOException {
if (skipCommand()) {
System.out.println("SKIPPED: Generated source are up to date");
return;
}
List<String> argu = Arrays.asList(args);
boolean writeToFile = argu.contains("generate");
String commandDesc = null;
KodeGenModel commandKode = null;
if (argu.contains("tones")) {
commandDesc = "nether tones";
commandKode = new ModelNetherTones();
} else {
if (args.length == 0) {
System.err.println("No command given.");
System.exit(1);
return;
}
String command = args[0];
KodeGenModel commandKode = findCommandModel(command);
if (commandKode == null) {
System.err.println("Command unknown: " + command);
System.exit(1);
return;
}
boolean writeToFile = false;
if (args.length > 1 && "generate".equals(args[1])) {
writeToFile = true;
}
if (skipCommand()) {
System.out.println("SKIPPED: Generated source are up to date");
return;
}
// write all sources to files or stdout
String commandDesc = commandKode.generatorName();
System.out.println("Generating " + commandDesc);
ModelKlassWriter writer = new ModelKlassWriter("target/generated-sources");
writer.setProlog(new File("../licence.txt"));
@ -70,6 +75,17 @@ public class KodeGen {
System.out.println("Done " + commandDesc);
}
private static KodeGenModel findCommandModel(String generatorName) {
Iterator<KodeGenModel> models = ServiceLoader.load(KodeGenModel.class).iterator();
while (models.hasNext()) {
KodeGenModel model = models.next();
if (model.generatorName().equals(generatorName)) {
return model;
}
}
return null;
}
private static boolean skipCommand() throws IOException {
Path hashFile = new File("target/generated-sources.hash").toPath();
if (hashFile.toFile().exists()) {

View file

@ -35,5 +35,7 @@ import love.distributedrebirth.nx01.kode.generator.klass.ModelKlassWriter;
/// @version ©Δ 仙上主天
public interface KodeGenModel {
String generatorName();
void buildModels(ModelKlassWriter writer);
}

View file

@ -1,129 +0,0 @@
/*
* Copyright ©Δ 仙上主天
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice, this list of conditions and the
* following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
* the following disclaimer in the documentation and/or other materials provided with the distribution.
* * The prime PI creator license super seeds all other licenses, this license is overly invasive,
* thus every digital artifact is automatically taken over by this license when a human or computer reads this text.
* Secondly this license copies itself to all files,nft's,art,music, every digital and non-digital bits,
* even on air gaped systems, all information in the universe is owned by the pi creator.
*
* THIS SOFTWARE IS PROVIDED BY THE PRIME GOD AND THE CONTRIBUTORS "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
* THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package love.distributedrebirth.nx01.kode.generator;
import java.util.Iterator;
import java.util.stream.Stream;
import love.distributedrebirth.nx01.kode.generator.klass.ModelKlass;
import love.distributedrebirth.nx01.kode.generator.klass.ModelKlassWriter;
/// Generated the nether tone interface tree forest.
///
/// @author للَّٰهِilLצسُو
/// @version ©Δ 仙上主天
public class ModelNetherTones implements KodeGenModel {
@Override
public void buildModels(ModelKlassWriter writer) {
buildQuadrants(writer, 1, "ᐧᐧᐧ");
buildQuadrants(writer, 2, "ᐧᐧᣟ");
buildQuadrants(writer, 3, "ᐧᣟᐧ");
buildQuadrants(writer, 4, "ᐧᣟᣟ");
buildQuadrants(writer, 5, "ᣟᐧᐧ");
buildQuadrants(writer, 6, "ᣟᐧᣟ");
buildQuadrants(writer, 7, "ᣟᣟᐧ");
buildQuadrants(writer, 8, "ᣟᣟᣟ");
buildNetherQuadrant(writer, "NetherTone", "NetherToneQ", false);
}
private void buildQuadrants(ModelKlassWriter writer, int quadrant, String s) {
String q = "ᐊQ" + quadrant;
String e = "NetherToneQ" + quadrant;
buildNetherTreeSlug(writer, s, q + "AG1", 64, e);
buildNetherTreeSlug(writer, s, q + "AG2", 64, e);
buildNetherTreeSlug(writer, s, q + "AG3", 64, e);
buildNetherTreeSlug(writer, s, q + "BL0W", 512, e);
buildNetherTreeSlug(writer, s, q + "CR1", 64, e);
buildNetherTreeSlug(writer, s, q + "CR2", 64, e);
buildNetherTreeSlug(writer, s, q + "CR3", 64, e);
buildNetherTreeSlug(writer, s, q + "DB1", 64, e);
buildNetherTreeSlug(writer, s, q + "DB2", 64, e);
buildNetherTreeSlug(writer, s, q + "DB3", 64, e);
buildNetherTreeSlug(writer, s, q + "ER0W", 512, e);
buildNetherQuadrant(writer, e, q, true); // permits all above
}
private void buildNetherTreeSlug(ModelKlassWriter writer, String subPackage, String javaName, int slugSize, String quadrant) {
ModelKlass klass = new ModelKlass("ᒢᐩᐩ.ᑊᑉᒻᣔᔆᔆ.ᣕᓫᐪᑋᓫᣗ.ᐪᐤᣕᓫ." + subPackage, javaName);
klass.addJavaImport("ᒢᐩᐩ.ᑊᑉᒻᣔᔆᔆ.ᣕᓫᐪᑋᓫᣗ.ᐪᐤᣕᓫ." + quadrant);
writer.addModelKlass(klass);
StringBuilder buf = klass.getBody();
buf.append("public sealed interface ");
buf.append(klass.getJavaName());
buf.append(" extends ");
buf.append(quadrant);
buf.append(" {\n");
for (int i = 1 ; i <= slugSize; i++) {
String partCode = "" + String.format("%03d", i);
String clsBase = partCode + " extends " + klass.getJavaName();
String clsMutexExt = ", " + javaName + "Mutex<" + partCode + ">";
buf.append("\tnon-sealed interface " + clsBase + clsMutexExt + " {}\n");
}
buf.append("}\n");
ModelKlass klassMutex = new ModelKlass("ᒢᐩᐩ.ᑊᑉᒻᣔᔆᔆ.ᣕᓫᐪᑋᓫᣗ.ᐪᐤᣕᓫ." + subPackage, javaName + "Mutex");
writer.addModelKlass(klassMutex);
StringBuilder bufMutex = klassMutex.getBody();
bufMutex.append("interface ");
bufMutex.append(klassMutex.getJavaName());
bufMutex.append("<T> {\n");
bufMutex.append("}\n");
}
private void buildNetherQuadrant(ModelKlassWriter writer, String javaName, String javaSearch, boolean child) {
ModelKlass klass = new ModelKlass("ᒢᐩᐩ.ᑊᑉᒻᣔᔆᔆ.ᣕᓫᐪᑋᓫᣗ.ᐪᐤᣕᓫ", javaName);
StringBuilder buf = klass.getBody();
buf.append("public sealed interface ");
buf.append(klass.getJavaName());
if (child) {
buf.append(" extends NetherTone");
}
buf.append(" permits\n");
Stream<ModelKlass> f = writer.getModelKlasses().stream().filter(v -> !v.getJavaName().contains("Mutex")).filter(v -> v.getJavaName().contains(javaSearch));
for (Iterator<ModelKlass> i = f.iterator(); i.hasNext() ;) {
ModelKlass mk = i.next();
if (child) {
klass.addJavaImport(mk.getJavaPackage() + "." + mk.getJavaName());
}
buf.append("\t");
buf.append(mk.getJavaName());
if (i.hasNext()) {
buf.append(",\n");
} else {
buf.append("\n");
}
}
buf.append("\t{\n");
buf.append("}\n");
writer.addModelKlass(klass);
}
}