Client generator now working

This commit is contained in:
jamesagnew 2014-03-13 08:00:01 -04:00
parent 360db1d296
commit 45c968532d
14 changed files with 212 additions and 15 deletions

View File

@ -57,8 +57,12 @@ public abstract class BaseRuntimeDeclaredChildDefinition extends BaseRuntimeChil
Class<?> declaringClass = myField.getDeclaringClass(); Class<?> declaringClass = myField.getDeclaringClass();
final Class<?> targetReturnType = myField.getType(); final Class<?> targetReturnType = myField.getType();
try { try {
final Method accessor = BeanUtils.findAccessor(declaringClass, targetReturnType, myElementName); String elementName = myElementName;
final Method mutator = BeanUtils.findMutator(declaringClass, targetReturnType, myElementName); if ("Class".equals(elementName)) {
elementName = "ClassElement"; // because getClass() is reserved
}
final Method accessor = BeanUtils.findAccessor(declaringClass, targetReturnType, elementName);
final Method mutator = BeanUtils.findMutator(declaringClass, targetReturnType, elementName);
if (List.class.isAssignableFrom(targetReturnType)) { if (List.class.isAssignableFrom(targetReturnType)) {
myAccessor = new ListAccessor(accessor); myAccessor = new ListAccessor(accessor);

View File

@ -0,0 +1,15 @@
package ca.uhn.fhir.model.api;
import ca.uhn.fhir.model.api.annotation.ResourceDef;
@ResourceDef(name="Binary", profile="http://hl7.org/fhir/profiles/Binary", id="binary")
public class Binary implements IResource {
// TODO: implement binary
@Override
public boolean isEmpty() {
return true;
}
}

View File

@ -6,6 +6,9 @@ public class UndeclaredExtension extends BaseElement {
private IElement myValue; private IElement myValue;
private boolean myIsModifier; private boolean myIsModifier;
public UndeclaredExtension() {
}
public UndeclaredExtension(boolean theIsModifier) { public UndeclaredExtension(boolean theIsModifier) {
myIsModifier = theIsModifier; myIsModifier = theIsModifier;
} }

View File

@ -0,0 +1,7 @@
package ca.uhn.fhir.model.dstu.composite;
public class AgeDt extends QuantityDt {
// TODO: implement restricions
}

View File

@ -0,0 +1,40 @@
package ca.uhn.fhir.model.primitive;
import ca.uhn.fhir.model.api.BasePrimitive;
import ca.uhn.fhir.model.api.IElement;
import ca.uhn.fhir.parser.DataFormatException;
public class IdrefDt extends BasePrimitive<String> {
private IElement myTarget;
private String myValue;
public IElement getTarget() {
return myTarget;
}
@Override
public String getValue() {
return myValue;
}
@Override
public String getValueAsString() throws DataFormatException {
return myValue;
}
public void setTarget(IElement theTarget) {
myTarget = theTarget;
}
@Override
public void setValue(String theValue) throws DataFormatException {
myValue = theValue;
}
@Override
public void setValueAsString(String theValue) throws DataFormatException {
myValue = theValue;
}
}

View File

@ -0,0 +1,7 @@
package ca.uhn.fhir.model.primitive;
public class OidDt extends UriDt {
// TODO: implement restrictions
}

View File

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<classpath> <classpath>
<classpathentry excluding="**/*.java" kind="src" output="target/test-classes" path="src/test/resources"/> <classpathentry excluding="**/*.java" kind="src" path="src/test/resources"/>
<classpathentry kind="src" path="target/gen"/> <classpathentry kind="src" path="target/gen"/>
<classpathentry including="**/*.java" kind="src" path="src/main/java"/> <classpathentry including="**/*.java" kind="src" path="src/main/java"/>
<classpathentry excluding="**/*.java" kind="src" path="src/main/resources"/> <classpathentry excluding="**/*.java" kind="src" path="src/main/resources"/>

View File

@ -10,7 +10,9 @@ import java.io.InputStreamReader;
import java.lang.annotation.Annotation; import java.lang.annotation.Annotation;
import java.lang.reflect.Constructor; import java.lang.reflect.Constructor;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Set;
import java.util.TreeSet; import java.util.TreeSet;
import org.apache.commons.lang3.ObjectUtils; import org.apache.commons.lang3.ObjectUtils;
@ -27,6 +29,7 @@ import ca.uhn.fhir.tinder.model.BaseElement;
import ca.uhn.fhir.tinder.model.Child; import ca.uhn.fhir.tinder.model.Child;
import ca.uhn.fhir.tinder.model.Extension; import ca.uhn.fhir.tinder.model.Extension;
import ca.uhn.fhir.tinder.model.Resource; import ca.uhn.fhir.tinder.model.Resource;
import ca.uhn.fhir.tinder.model.ResourceBlock;
import ca.uhn.fhir.tinder.model.SimpleSetter.Parameter; import ca.uhn.fhir.tinder.model.SimpleSetter.Parameter;
public abstract class BaseStructureParser { public abstract class BaseStructureParser {
@ -128,6 +131,8 @@ public abstract class BaseStructureParser {
} }
for (Resource next : myResources) { for (Resource next : myResources) {
scanForTypeNameConflicts(next);
File f = new File(theOutputDirectory, next.getName() + getFilenameSuffix() + ".java"); File f = new File(theOutputDirectory, next.getName() + getFilenameSuffix() + ".java");
try { try {
write(next, f, thePackageBase); write(next, f, thePackageBase);
@ -137,6 +142,30 @@ public abstract class BaseStructureParser {
} }
} }
private void scanForTypeNameConflicts(Resource theNext) {
Set<String> typeNames = new HashSet<String>();
typeNames.add(theNext.getName());
scanForTypeNameConflicts(theNext,typeNames);
}
private void scanForTypeNameConflicts(BaseElement theResourceBlock, Set<String> theTypeNames) {
for (BaseElement nextChild : theResourceBlock.getChildren()){
if (nextChild instanceof ResourceBlock) {
ResourceBlock resourceBlock = (ResourceBlock) nextChild;
String className = resourceBlock.getClassName();
String newClassName = className;
int index = 2;
while (theTypeNames.contains(newClassName)) {
newClassName = className + (index++);
resourceBlock.setForcedClassName(newClassName);
}
theTypeNames.add(newClassName);
scanForTypeNameConflicts(resourceBlock, theTypeNames);
}
}
}
protected abstract String getFilenameSuffix(); protected abstract String getFilenameSuffix();
private void write(Resource theResource, File theFile, String thePackageBase) throws IOException { private void write(Resource theResource, File theFile, String thePackageBase) throws IOException {

View File

@ -30,12 +30,14 @@ import ca.uhn.fhir.model.dstu.resource.Profile.StructureSearchParam;
import ca.uhn.fhir.model.dstu.valueset.DataTypeEnum; import ca.uhn.fhir.model.dstu.valueset.DataTypeEnum;
import ca.uhn.fhir.parser.DataFormatException; import ca.uhn.fhir.parser.DataFormatException;
import ca.uhn.fhir.parser.XmlParser; import ca.uhn.fhir.parser.XmlParser;
import ca.uhn.fhir.tinder.model.AnyChild;
import ca.uhn.fhir.tinder.model.BaseElement; import ca.uhn.fhir.tinder.model.BaseElement;
import ca.uhn.fhir.tinder.model.Child; import ca.uhn.fhir.tinder.model.Child;
import ca.uhn.fhir.tinder.model.Resource; import ca.uhn.fhir.tinder.model.Resource;
import ca.uhn.fhir.tinder.model.ResourceBlock; import ca.uhn.fhir.tinder.model.ResourceBlock;
import ca.uhn.fhir.tinder.model.SearchParameter; import ca.uhn.fhir.tinder.model.SearchParameter;
import ca.uhn.fhir.tinder.model.Slicing; import ca.uhn.fhir.tinder.model.Slicing;
import ca.uhn.fhir.tinder.model.UndeclaredExtensionChild;
public class ProfileParser extends BaseStructureParser { public class ProfileParser extends BaseStructureParser {
@ -46,7 +48,8 @@ public class ProfileParser extends BaseStructureParser {
// FhirContext fhirContext = new FhirContext(Profile.class); // FhirContext fhirContext = new FhirContext(Profile.class);
// XmlParser parser = fhirContext.newXmlParser(); // XmlParser parser = fhirContext.newXmlParser();
// //
// String file = IOUtils.toString(new FileReader("src/test/resources/prof/organization.xml")); // String file = IOUtils.toString(new
// FileReader("src/test/resources/prof/organization.xml"));
// Profile text = (Profile) parser.parseResource(file); // Profile text = (Profile) parser.parseResource(file);
// //
// ValueSetGenerator vsp = new ValueSetGenerator(); // ValueSetGenerator vsp = new ValueSetGenerator();
@ -54,7 +57,8 @@ public class ProfileParser extends BaseStructureParser {
// vsp.parse(); // vsp.parse();
// //
// ProfileParser p = new ProfileParser(); // ProfileParser p = new ProfileParser();
// p.parseSingleProfile(text, "http://fhir.connectinggta.ca/static/Profile/organization.xml"); // p.parseSingleProfile(text,
// "http://fhir.connectinggta.ca/static/Profile/organization.xml");
// p.bindValueSets(vsp); // p.bindValueSets(vsp);
// p.writeAll("target/generated/valuesets/ca/uhn/fhir/model/dstu/resource"); // p.writeAll("target/generated/valuesets/ca/uhn/fhir/model/dstu/resource");
// //
@ -92,8 +96,10 @@ public class ProfileParser extends BaseStructureParser {
elem = new ResourceBlock(); elem = new ResourceBlock();
// } else if (type.startsWith("@")) { // } else if (type.startsWith("@")) {
// elem = new ResourceBlockCopy(); // elem = new ResourceBlockCopy();
// } else if (type.equals("*")) { } else if (next.getDefinition().getType().get(0).getCode().getValue().equals("*")) {
// elem = new AnyChild(); elem = new AnyChild();
} else if (next.getDefinition().getType().get(0).getCode().getValue().equals("Extension")) {
elem = new UndeclaredExtensionChild();
} else { } else {
elem = new Child(); elem = new Child();
} }
@ -125,7 +131,9 @@ public class ProfileParser extends BaseStructureParser {
} }
/* /*
* Profiles come with a number of standard elements which are generally ignored because they are boilerplate, unless the definition is somehow changing their behaviour (e.g. through * Profiles come with a number of standard elements which are
* generally ignored because they are boilerplate, unless the
* definition is somehow changing their behaviour (e.g. through
* slices) * slices)
*/ */
if (next.getPath().getValue().endsWith(".contained")) { if (next.getPath().getValue().endsWith(".contained")) {
@ -258,18 +266,22 @@ public class ProfileParser extends BaseStructureParser {
} }
// for (int i = 0; i < theBaseResourceNames.size(); i++) { // for (int i = 0; i < theBaseResourceNames.size(); i++) {
// theBaseResourceNames.set(i, theBaseResourceNames.get(i).toLowerCase()); // theBaseResourceNames.set(i,
// theBaseResourceNames.get(i).toLowerCase());
// } // }
// //
// try { // try {
// //
// Bundle bundle = fhirContext.newXmlParser().parseBundle(IOUtils.toString(getClass().getResourceAsStream("/prof/allprofiles.xml"))); // Bundle bundle =
// fhirContext.newXmlParser().parseBundle(IOUtils.toString(getClass().getResourceAsStream("/prof/allprofiles.xml")));
// TreeSet<String> allProfiles = new TreeSet<String>(); // TreeSet<String> allProfiles = new TreeSet<String>();
// for (BundleEntry nextResource : bundle.getEntries() ) { // for (BundleEntry nextResource : bundle.getEntries() ) {
// Profile nextProfile = (Profile) nextResource.getResource(); // Profile nextProfile = (Profile) nextResource.getResource();
// allProfiles.add(nextProfile.getName().getValue()); // allProfiles.add(nextProfile.getName().getValue());
// if (theBaseResourceNames.contains(nextProfile.getName().getValue().toLowerCase())){ // if
// parseSingleProfile(nextProfile, bundle.getLinkBase().getValueNotNull()); // (theBaseResourceNames.contains(nextProfile.getName().getValue().toLowerCase())){
// parseSingleProfile(nextProfile,
// bundle.getLinkBase().getValueNotNull());
// } // }
// } // }
// //

View File

@ -4,6 +4,7 @@ import static org.apache.commons.lang.StringUtils.defaultString;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileReader;
import java.io.FileWriter; import java.io.FileWriter;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
@ -62,6 +63,21 @@ public class TinderClientMojo extends AbstractMojo {
public void execute() throws MojoExecutionException, MojoFailureException { public void execute() throws MojoExecutionException, MojoFailureException {
determinePaths(); determinePaths();
//
// try {
// ProfileParser pp = new ProfileParser();
// Profile prof=(Profile) new FhirContext(Profile.class).newXmlParser().parseResource(IOUtils.toString(new FileReader("src/test/resources/profile.xml")));
// pp.parseSingleProfile(prof, "http://foo");
// File resourceDir = new File(myDirectoryBase, "resource");
// resourceDir.mkdirs();
// pp.writeAll(resourceDir, myPackageBase);
// } catch (Exception e) {
// throw new MojoFailureException("Failed to load resource profile: ",e);
// }
// if (true) {
// return;
// }
FhirContext ctx = new FhirContext(Conformance.class); FhirContext ctx = new FhirContext(Conformance.class);
IRestfulClientFactory cFact = ctx.newRestfulClientFactory(); IRestfulClientFactory cFact = ctx.newRestfulClientFactory();
IBasicClient client = cFact.newClient(IBasicClient.class, "http://fhir.healthintersections.com.au/open"); IBasicClient client = cFact.newClient(IBasicClient.class, "http://fhir.healthintersections.com.au/open");

View File

@ -2,6 +2,16 @@ package ca.uhn.fhir.tinder.model;
public class AnyChild extends Child { public class AnyChild extends Child {
@Override
public String getReferenceType() {
return "IDatatype";
}
@Override
public String getAnnotationType() {
return getReferenceType();
}
@Override @Override
public String getTypeSuffix() { public String getTypeSuffix() {
return ""; return "";

View File

@ -42,6 +42,9 @@ public class Child extends BaseElement {
public String getMethodName() { public String getMethodName() {
String elementName = getElementNameSimplified(); String elementName = getElementNameSimplified();
elementName = elementName.substring(0, 1).toUpperCase() + elementName.substring(1); elementName = elementName.substring(0, 1).toUpperCase() + elementName.substring(1);
if ("Class".equals(elementName)) {
elementName = "ClassElement";
}
return elementName; return elementName;
} }
@ -95,6 +98,9 @@ public class Child extends BaseElement {
public List<String> getReferenceTypesForMultiple() { public List<String> getReferenceTypesForMultiple() {
ArrayList<String> retVal = new ArrayList<String>(); ArrayList<String> retVal = new ArrayList<String>();
for (String next : getType()) { for (String next : getType()) {
if ("Any".equals(next)) {
next = "IResource";
}
retVal.add(next); retVal.add(next);
// retVal.add(next + getTypeSuffix()); // retVal.add(next + getTypeSuffix());
} }

View File

@ -4,12 +4,18 @@ import java.util.List;
public class ResourceBlock extends Child { public class ResourceBlock extends Child {
private String myForcedClassName;
@Override @Override
public List<BaseElement> getChildren() { public List<BaseElement> getChildren() {
return super.getChildren(); return super.getChildren();
} }
public String getClassName() { public String getClassName() {
if (myForcedClassName != null) {
return myForcedClassName;
}
// return getElementName().substring(0, 1).toUpperCase() + getElementName().substring(1); // return getElementName().substring(0, 1).toUpperCase() + getElementName().substring(1);
String name = getName(); String name = getName();
return convertFhirPathNameToClassName(name); return convertFhirPathNameToClassName(name);
@ -44,4 +50,8 @@ public class ResourceBlock extends Child {
return ""; return "";
} }
public void setForcedClassName(String theClassName) {
myForcedClassName =theClassName;
}
} }

View File

@ -0,0 +1,38 @@
package ca.uhn.fhir.tinder.model;
import java.util.ArrayList;
import ca.uhn.fhir.model.api.UndeclaredExtension;
public class UndeclaredExtensionChild extends Child {
@Override
public String getReferenceType() {
if (isRepeatable()) {
return ArrayList.class.getCanonicalName() + "<" + UndeclaredExtension.class.getSimpleName()+">";
}
return UndeclaredExtension.class.getSimpleName();
}
@Override
public String getAnnotationType() {
return UndeclaredExtension.class.getSimpleName();
}
@Override
public String getSingleType() {
return UndeclaredExtension.class.getSimpleName();
}
@Override
public String getTypeSuffix() {
return "";
}
@Override
public boolean isSingleChildInstantiable() {
return true;
}
}