fix code generation for enums
This commit is contained in:
parent
2d59c27418
commit
a7d0b645dc
|
@ -247,6 +247,8 @@ public class PECodeGenerator {
|
||||||
org.hl7.fhir.r5.model.ValueSet vs = workerContext.fetchResource(org.hl7.fhir.r5.model.ValueSet.class, binding.getValueSet(), field.getProfile());
|
org.hl7.fhir.r5.model.ValueSet vs = workerContext.fetchResource(org.hl7.fhir.r5.model.ValueSet.class, binding.getValueSet(), field.getProfile());
|
||||||
if (vs != null) {
|
if (vs != null) {
|
||||||
ValueSetExpansionOutcome vse = workerContext.expandVS(vs, false, false);
|
ValueSetExpansionOutcome vse = workerContext.expandVS(vs, false, false);
|
||||||
|
Set<String> codes = new HashSet<>();
|
||||||
|
boolean hasDups = false;
|
||||||
if (vse.isOk()) {
|
if (vse.isOk()) {
|
||||||
String baseName = Utilities.nmtokenize(Utilities.singularise(vs.getName()));
|
String baseName = Utilities.nmtokenize(Utilities.singularise(vs.getName()));
|
||||||
String name = baseName;
|
String name = baseName;
|
||||||
|
@ -259,22 +261,36 @@ public class PECodeGenerator {
|
||||||
for (int i = 0; i < vse.getValueset().getExpansion().getContains().size(); i++) {
|
for (int i = 0; i < vse.getValueset().getExpansion().getContains().size(); i++) {
|
||||||
ValueSetExpansionContainsComponent cc = vse.getValueset().getExpansion().getContains().get(i);
|
ValueSetExpansionContainsComponent cc = vse.getValueset().getExpansion().getContains().get(i);
|
||||||
String code = Utilities.javaTokenize(cc.getCode(), true).toUpperCase();
|
String code = Utilities.javaTokenize(cc.getCode(), true).toUpperCase();
|
||||||
|
if (Utilities.isInteger(code)) {
|
||||||
|
code = "C_"+code;
|
||||||
|
}
|
||||||
if (cc.getAbstract()) {
|
if (cc.getAbstract()) {
|
||||||
code = "_"+code;
|
code = "_"+code;
|
||||||
}
|
}
|
||||||
|
if (codes.contains(code)) {
|
||||||
|
char sfx = 'A';
|
||||||
|
while (codes.contains(code+sfx)) {
|
||||||
|
sfx++;
|
||||||
|
}
|
||||||
|
code = code + sfx;
|
||||||
|
hasDups = true;
|
||||||
|
}
|
||||||
|
codes.add(code);
|
||||||
cc.setUserData(UserDataNames.java_code, code);
|
cc.setUserData(UserDataNames.java_code, code);
|
||||||
w(enums, " "+code+(i < vse.getValueset().getExpansion().getContains().size() - 1 ? "," : ";")+" // \""+cc.getDisplay()+"\" = "+cc.getSystem()+"#"+cc.getCode());
|
w(enums, " "+code+(i < vse.getValueset().getExpansion().getContains().size() - 1 ? "," : ";")+" // \""+cc.getDisplay()+"\" = "+cc.getSystem()+"#"+cc.getCode());
|
||||||
}
|
}
|
||||||
w(enums, "");
|
w(enums, "");
|
||||||
w(enums, " public static "+name+" fromCode(String s) {");
|
if (!hasDups) {
|
||||||
w(enums, " switch (s) {");
|
w(enums, " public static "+name+" fromCode(String s) {");
|
||||||
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
w(enums, " switch (s) {");
|
||||||
w(enums, " case \""+cc.getCode()+"\": return "+cc.getUserString(UserDataNames.java_code)+";");
|
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
||||||
|
w(enums, " case \""+cc.getCode()+"\": return "+cc.getUserString(UserDataNames.java_code)+";");
|
||||||
|
}
|
||||||
|
w(enums, " default: return null;");
|
||||||
|
w(enums, " }");
|
||||||
|
w(enums, " }");
|
||||||
|
w(enums, "");
|
||||||
}
|
}
|
||||||
w(enums, " default: return null;");
|
|
||||||
w(enums, " }");
|
|
||||||
w(enums, " }");
|
|
||||||
w(enums, "");
|
|
||||||
w(enums, " public static "+name+" fromCoding(Coding c) {");
|
w(enums, " public static "+name+" fromCoding(Coding c) {");
|
||||||
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
||||||
if (cc.hasVersion()) {
|
if (cc.hasVersion()) {
|
||||||
|
@ -309,15 +325,17 @@ public class PECodeGenerator {
|
||||||
w(enums, " }");
|
w(enums, " }");
|
||||||
w(enums, "");
|
w(enums, "");
|
||||||
|
|
||||||
w(enums, " public String toCode() {");
|
if (!hasDups) {
|
||||||
w(enums, " switch (this) {");
|
w(enums, " public String toCode() {");
|
||||||
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
w(enums, " switch (this) {");
|
||||||
w(enums, " case "+cc.getUserString(UserDataNames.java_code)+": return \""+cc.getCode()+"\";");
|
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
||||||
|
w(enums, " case "+cc.getUserString(UserDataNames.java_code)+": return \""+cc.getCode()+"\";");
|
||||||
|
}
|
||||||
|
w(enums, " default: return null;");
|
||||||
|
w(enums, " }");
|
||||||
|
w(enums, " }");
|
||||||
|
w(enums, "");
|
||||||
}
|
}
|
||||||
w(enums, " default: return null;");
|
|
||||||
w(enums, " }");
|
|
||||||
w(enums, " }");
|
|
||||||
w(enums, "");
|
|
||||||
w(enums, " public Coding toCoding() {");
|
w(enums, " public Coding toCoding() {");
|
||||||
w(enums, " switch (this) {");
|
w(enums, " switch (this) {");
|
||||||
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
for (ValueSetExpansionContainsComponent cc : vse.getValueset().getExpansion().getContains()) {
|
||||||
|
|
Loading…
Reference in New Issue