From fd817904bc6089d8728ac91cf897b0daa48a9503 Mon Sep 17 00:00:00 2001 From: neurolabusc Date: Wed, 23 Oct 2024 15:38:15 -0400 Subject: [PATCH] ISO_IR 100 -> UTF8 for DeidentificationMethod (https://github.com/rordenlab/dcm2niix/issues/878) --- console/makefile | 3 +++ console/nii_dicom_batch.cpp | 37 +++++++++++++++++++++++-------------- 2 files changed, 26 insertions(+), 14 deletions(-) diff --git a/console/makefile b/console/makefile index 56b8c89f..fcb351e1 100644 --- a/console/makefile +++ b/console/makefile @@ -52,6 +52,9 @@ all: sanitize: g++ -O1 -g -fsanitize=address -fno-omit-frame-pointer $(LFLAGS) $(UFILES) +debug: + g++ -O0 $(LFLAGS) $(UFILES) + noroi: g++ $(CFLAGS) -I. $(JSFLAGS) $(JFLAGS) $(LFLAGS) $(UFILES) -DmyNoRois diff --git a/console/nii_dicom_batch.cpp b/console/nii_dicom_batch.cpp index 5925e163..6be40c84 100644 --- a/console/nii_dicom_batch.cpp +++ b/console/nii_dicom_batch.cpp @@ -1119,6 +1119,28 @@ int geProtocolBlock(const char *filename, int geOffset, int geLength, int isVerb } #endif // myReadGeProtocolBlock() +void json_StrList(FILE *fp, const char *sLabel, char *sVal) { + if (strlen(sVal) < 1) return; + fprintf(fp, "\t\"%s\": [\"", sLabel); + for (size_t i = 0; i < strlen(sVal); i++) { + if (sVal[i] != '\\') { + if (i > 0 && sVal[i-1] == '\\') { + fprintf(fp, "\", \""); + } + unsigned char ch = (unsigned char)sVal[i]; + // Convert ISO-8859-1 to UTF-8 + if (ch < 0x80) { + // ASCII range: 1-byte UTF-8 + fprintf(fp, "%c", ch); + } else { + // Non-ASCII range: 2-byte UTF-8 + fprintf(fp, "%c%c", 0xC0 | (ch >> 6), 0x80 | (ch & 0x3F)); + } + } + } + fprintf(fp, "\"],\n"); +} + void json_Str(FILE *fp, const char *sLabel, char *sVal) { // issue131,425 if (strlen(sVal) < 1) return; @@ -1464,20 +1486,7 @@ tse3d: T2*/ fprintf(fp, "\t\"NonlinearGradientCorrection\": false,\n"); if (d.isDerived) // DICOM is derived image or non-spatial file (sounds, etc) fprintf(fp, "\t\"RawImage\": false,\n"); - if (strlen(d.deidentificationMethod) > 0) { - fprintf(fp, "\t\"DeidentificationMethod\": [\""); - bool isSep = false; - for (size_t i = 0; i < strlen(d.deidentificationMethod); i++) { - if (d.deidentificationMethod[i] != '\\') { - if (isSep) - fprintf(fp, "\", \""); - isSep = false; - fprintf(fp, "%c", d.deidentificationMethod[i]); - } else - isSep = true; - } - fprintf(fp, "\"],\n"); - } + json_StrList(fp, "DeidentificationMethod", d.deidentificationMethod); if (d.deID_CS_n > 0) { char *fname = (char *)malloc(strlen(filename) + 1); strcpy(fname, filename);