You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@daffodil.apache.org by "Mike McGann (Jira)" <ji...@apache.org> on 2023/03/09 15:05:00 UTC
[jira] [Assigned] (DAFFODIL-2205) emptyValueDelimiterPolicy only works per specification for 'both'
[ https://issues.apache.org/jira/browse/DAFFODIL-2205?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Mike McGann reassigned DAFFODIL-2205:
-------------------------------------
Assignee: (was: Mike McGann)
> emptyValueDelimiterPolicy only works per specification for 'both'
> ------------------------------------------------------------------
>
> Key: DAFFODIL-2205
> URL: https://issues.apache.org/jira/browse/DAFFODIL-2205
> Project: Daffodil
> Issue Type: Bug
> Affects Versions: 2.4.0
> Environment: Daffodil 2.4 on Windows 10
> Reporter: Shashi Ramaka
> Priority: Major
> Attachments: bug01-input-fails.txt, bug01-input-works.txt, bug01.dfdl.xsd
>
>
> This bug report is based on a message Roger Costello posted to the Daffodil Users group.
> From the DFDL specification, when emptyValueDelimiterPolicy is set to 'none':
> {quote}'none' indicates that if the content region is empty neither the
> dfdl:initiator or dfdl:terminator must be present. On unparsing when
> the content region is empty nothing will be output.
> {quote}
> Based on the above, if in the schema an element has an initiator and a terminator, and if the emptyValueDelimiterPolicy is set to 'none', to represent an empty value neither the initiator nor the terminator should be present in the input.
> In the attached test case,
> * the element *MiddleName* has an initiator and a terminator
> * *emptyValueDelimiterPolicy* is set to 'none'
> * For the test input, John,,Doe we are getting the parse error: [error] Parse Error: Found out of scope delimiter: ',' ','
> * Test input John,(),Doe parses successfully
> {code:xml}
> <xs:element name="input">
> <xs:complexType>
> <xs:sequence
> dfdl:separator=","
> dfdl:separatorPosition="infix"
> dfdl:separatorSuppressionPolicy="trailingEmpty">
> <xs:element
> name="FirstName"
> type="xs:string" />
> <xs:element
> name="MiddleName"
> type="xs:string"
> dfdl:initiator="("
> dfdl:terminator=")"
> dfdlx:emptyElementParsePolicy="treatAsEmpty"
> dfdl:emptyValueDelimiterPolicy="initiator" />
> <xs:element
> name="LastName"
> type="xs:string" />
> </xs:sequence>
> </xs:complexType>
> </xs:element>
> {code}
>
> Input:
> John,(),Doe – parse successful
> John,,Doe – Parse error.
> [error] Parse Error: Found out of scope delimiter: ',' ','
>
> The files used for testing this scenario are attached.
> It also appears that it does not work for 'initiator' and 'terminator' as well so this ticket will be about implementing this feature instead of fixing a bug.
>
--
This message was sent by Atlassian Jira
(v8.20.10#820010)