Skip to content

Commit

Permalink
little more cleanup, delete files and pluck some more from master
Browse files Browse the repository at this point in the history
  • Loading branch information
dehall committed Nov 12, 2024
1 parent 1efac55 commit 854afe5
Show file tree
Hide file tree
Showing 10 changed files with 98 additions and 903 deletions.
9 changes: 0 additions & 9 deletions copy.sh

This file was deleted.

103 changes: 0 additions & 103 deletions deleted_modules.txt

This file was deleted.

48 changes: 0 additions & 48 deletions find_good_records.py

This file was deleted.

42 changes: 0 additions & 42 deletions select_good_records.py

This file was deleted.

45 changes: 35 additions & 10 deletions src/main/java/org/mitre/synthea/export/flexporter/Actions.java
Original file line number Diff line number Diff line change
Expand Up @@ -424,6 +424,12 @@ private static Map<String, Object> createFhirPathMapping(List<Map<String, Object
String location = (String)field.get("location");
Object valueDef = field.get("value");
String transform = (String)field.get("transform");
String ifDef = (String)field.get("if");

if (ifDef != null && !FhirPathUtils.appliesToResource(sourceResource, ifDef)) {
// The "if" condition returned falsy, so don't evaluate this value/set this field
continue;
}

if (valueDef == null) {
// do nothing, leave it null
Expand Down Expand Up @@ -457,12 +463,15 @@ private static Map<String, Object> createFhirPathMapping(List<Map<String, Object
} else if (valueDef instanceof Map<?,?>) {
Map<String,Object> valueMap = (Map<String, Object>) valueDef;

populateFhirPathMapping(fhirPathMapping, location, valueMap);
populateFhirPathMapping(fhirPathMapping, location, valueMap, sourceBundle, sourceResource,
person, fjContext);

} else if (valueDef instanceof List<?>) {
List<Object> valueList = (List<Object>) valueDef;

populateFhirPathMapping(fhirPathMapping, location, valueList);
populateFhirPathMapping(fhirPathMapping, location, valueList, sourceBundle, sourceResource,
person, fjContext);

} else {
// unexpected type here - is it even possible to get anything else?
String type = valueDef == null ? "null" : valueDef.getClass().toGenericString();
Expand All @@ -474,21 +483,32 @@ private static Map<String, Object> createFhirPathMapping(List<Map<String, Object
}

private static void populateFhirPathMapping(Map<String, Object> fhirPathMapping, String basePath,
Map<String, Object> valueMap) {
Map<String, Object> valueMap, Bundle sourceBundle, Resource sourceResource, Person person,
FlexporterJavascriptContext fjContext) {
for (Map.Entry<String,Object> entry : valueMap.entrySet()) {
String key = entry.getKey();
Object value = entry.getValue();

String path = basePath + "." + key;

if (value instanceof String) {
String valueString = (String)value;

if (valueString.startsWith("$")) {
value = getValue(sourceBundle, valueString, sourceResource, person, fjContext);
}
}

if (value instanceof String || value instanceof Base) {
fhirPathMapping.put(path, value);
} else if (value instanceof Number) {
fhirPathMapping.put(path, value.toString());
} else if (value instanceof Map<?,?>) {
populateFhirPathMapping(fhirPathMapping, path, (Map<String, Object>) value);
populateFhirPathMapping(fhirPathMapping, path, (Map<String, Object>) value, sourceBundle,
sourceResource, person, fjContext);
} else if (value instanceof List<?>) {
populateFhirPathMapping(fhirPathMapping, path, (List<Object>) value);
populateFhirPathMapping(fhirPathMapping, path, (List<Object>) value, sourceBundle,
sourceResource, person, fjContext);
} else if (value != null) {
System.err
.println("Unexpected class found in populateFhirPathMapping[map]: " + value.getClass());
Expand All @@ -497,20 +517,23 @@ private static void populateFhirPathMapping(Map<String, Object> fhirPathMapping,
}

private static void populateFhirPathMapping(Map<String, Object> fhirPathMapping, String basePath,
List<Object> valueList) {
List<Object> valueList, Bundle sourceBundle, Resource sourceResource, Person person,
FlexporterJavascriptContext fjContext) {
for (int i = 0; i < valueList.size(); i++) {
Object value = valueList.get(i);

String path = basePath + "[" + i + "]";

if (value instanceof String) {
if (value instanceof String || value instanceof Base) {
fhirPathMapping.put(path, value);
} else if (value instanceof Number) {
fhirPathMapping.put(path, value.toString());
} else if (value instanceof Map<?,?>) {
populateFhirPathMapping(fhirPathMapping, path, (Map<String, Object>) value);
populateFhirPathMapping(fhirPathMapping, path, (Map<String, Object>) value, sourceBundle,
sourceResource, person, fjContext);
} else if (value instanceof List<?>) {
populateFhirPathMapping(fhirPathMapping, path, (List<Object>) value);
populateFhirPathMapping(fhirPathMapping, path, (List<Object>) value, sourceBundle,
sourceResource, person, fjContext);
} else if (value != null) {
System.err
.println("Unexpected class found in populateFhirPathMapping[list]:" + value.getClass());
Expand Down Expand Up @@ -661,8 +684,10 @@ public static void deleteResources(Bundle bundle, List<String> list) {

Resource resource = entry.getResource();
String resourceType = resource.getResourceType().toString();

for (String applicability : list) {
if (applicability.equals(resourceType) || FhirPathUtils.appliesToResource(resource, applicability)) {
if (applicability.equals(resourceType)
|| FhirPathUtils.appliesToResource(resource, applicability)) {
deletedResourceIDs.add(resource.getId());
itr.remove();
break;
Expand Down
Loading

0 comments on commit 854afe5

Please sign in to comment.