# HG changeset patch # User Sebastien Jodogne # Date 1546426078 -3600 # Node ID 1b05fd072c57aac5813adda31b133cbb75d2a5c3 # Parent 2df061cf2fec2073633d0250a0ea6d7e2469550f cont diff -r 2df061cf2fec -r 1b05fd072c57 OrthancServer/Search/DatabaseLookup.cpp --- a/OrthancServer/Search/DatabaseLookup.cpp Wed Jan 02 11:26:27 2019 +0100 +++ b/OrthancServer/Search/DatabaseLookup.cpp Wed Jan 02 11:47:58 2019 +0100 @@ -99,19 +99,13 @@ { assert(constraints_[i] != NULL); - DcmTagKey tag = ToDcmtkBridge::Convert(constraints_[i]->GetTag()); + const bool isOptionalConstraint = !constraints_[i]->IsMandatory(); + const DcmTagKey tag = ToDcmtkBridge::Convert(constraints_[i]->GetTag()); DcmElement* element = NULL; if (!item.findAndGetElement(tag, element).good()) { - if (constraints_[i]->IsMandatory()) - { - return false; - } - else - { - return true; - } + return isOptionalConstraint; } if (element == NULL) @@ -122,11 +116,16 @@ std::set ignoreTagLength; std::auto_ptr value(FromDcmtkBridge::ConvertLeafElement (*element, DicomToJsonFlags_None, - ORTHANC_MAXIMUM_TAG_LENGTH, encoding, ignoreTagLength)); + 0, encoding, ignoreTagLength)); - if (value->IsNull() || - value->IsBinary() || - !constraints_[i]->IsMatch(value->GetContent())) + // WARNING: Also modify "HierarchicalMatcher::Setup()" if modifying this code + if (value.get() == NULL || + value->IsNull()) + { + return isOptionalConstraint; + } + else if (value->IsBinary() || + !constraints_[i]->IsMatch(value->GetContent())) { return false; } diff -r 2df061cf2fec -r 1b05fd072c57 OrthancServer/Search/HierarchicalMatcher.cpp --- a/OrthancServer/Search/HierarchicalMatcher.cpp Wed Jan 02 11:26:27 2019 +0100 +++ b/OrthancServer/Search/HierarchicalMatcher.cpp Wed Jan 02 11:47:58 2019 +0100 @@ -117,14 +117,20 @@ } else { + flatTags_.insert(tag); + std::set ignoreTagLength; std::auto_ptr value(FromDcmtkBridge::ConvertLeafElement (*element, DicomToJsonFlags_None, - ORTHANC_MAXIMUM_TAG_LENGTH, encoding, ignoreTagLength)); + 0, encoding, ignoreTagLength)); - flatTags_.insert(tag); - - if (value->IsBinary()) + // WARNING: Also modify "DatabaseLookup::IsMatch()" if modifying this code + if (value.get() == NULL || + value->IsNull()) + { + // This is an universal constraint + } + else if (value->IsBinary()) { if (!value->GetContent().empty()) { @@ -133,8 +139,7 @@ << "It will be ignored."; } } - else if (value->IsNull() || - value->GetContent().empty()) + else if (value->GetContent().empty()) { // This is an universal matcher }