Reuse content action automatically inserts a <ph/> element
Post here questions and problems related to editing and publishing DITA content.
			- 
				ckabstein
- Posts: 152
- Joined: Fri Apr 24, 2015 12:28 pm
Reuse content action automatically inserts a <ph/> element
Hi,
In Oxygen 25.1, we have come across the following issue while editing DITA topics:
The "Reuse content" action automatically inserts a <ph/> element when conrefing plentry elements.
In the following example, you can see where the <ph/> element is added. In the previous Oxygen XML version 25.0, this didn't happen. Only the <pt/> and </pd> elements were added (see second <plentry> element):
We didn't make any changes to that action. We only noticed it because the <ph/> element suddenly appeared as to be translatable in our translation tool. Do you have any idea why the <ph/> element is added?
I haven't checked the latest Oxygen version yet, because we haven't had the time to update.
Thanks,
Christina
			
			
									
									In Oxygen 25.1, we have come across the following issue while editing DITA topics:
The "Reuse content" action automatically inserts a <ph/> element when conrefing plentry elements.
In the following example, you can see where the <ph/> element is added. In the previous Oxygen XML version 25.0, this didn't happen. Only the <pt/> and </pd> elements were added (see second <plentry> element):
Code: Select all
<refbody>
    <section id="section_tmf_txx_m1c">
      <fig>
        <image href="../../../_shared_picts/my_picture.png">
          <alt/>
        </image>
      </fig>
      <parml>
        <plentry conref="../_shared/my_xml_file_r.xml#my_xml_file_r/my_parameter">
          --> <pt><ph/></pt> <--
          <pd/>
        </plentry>
        <plentry conref="../_shared/my_xml_file_r.xml#my_xml_file_r/my_parameter">
          <pt/>
          <pd/>
        </plentry>I haven't checked the latest Oxygen version yet, because we haven't had the time to update.
Thanks,
Christina
oXygen XML Editor 27.1 build 2025041508
DITA OT 3.7.4
						DITA OT 3.7.4
- 
				Radu
- Posts: 9543
- Joined: Fri Jul 09, 2004 5:18 pm
Re: Reuse content action automatically inserts a <ph/> element
Hi Christina,
I could not reproduce this problem using the "Reuse content" action on my side:
The problem is benign, the actual content of the <plentry> which has a conref does not matter, it just needs to be valid.
Oxygen in general attempts to make the element which has the conref valid, meaning that for example it inserts inside the <plentry> the <pt> and <pd> elements as they are required.
I do not quite know why it also inserts the <ph> inside the <pt> on your side, maybe some framework specific configuration in the cc_config.xml file stating that the <pt> should always have a <ph> inside?
Looking in our internal issues list indeed we had an issue in Oxygen 25.1 to better generate required choice elements on the element which has the conref, based on the associated schema.
Are you also using a DITA DTD specialization?
In order to sort this out I might need to have a full sample on my side with a small DITA topic, the specialization DTD plugins, maybe even the framework configuration.
Regards,
Radu
			
			
									
									I could not reproduce this problem using the "Reuse content" action on my side:
Code: Select all
<topic id="introduction">
    <title>Introduction</title>
    <body>
        <p>hello<parml id="parml_mwz_hyc_2cc">
                <plentry id="abc">
                    <pt>hello</pt>
                    <pd>hello2</pd>
                </plentry>
            </parml></p>
        <p>
            <parml>
                <plentry conref="#./abc">
                    <pt/>
                    <pd/>
                </plentry>
            </parml>
        </p>
    </body> 
</topic>Oxygen in general attempts to make the element which has the conref valid, meaning that for example it inserts inside the <plentry> the <pt> and <pd> elements as they are required.
I do not quite know why it also inserts the <ph> inside the <pt> on your side, maybe some framework specific configuration in the cc_config.xml file stating that the <pt> should always have a <ph> inside?
Looking in our internal issues list indeed we had an issue in Oxygen 25.1 to better generate required choice elements on the element which has the conref, based on the associated schema.
Are you also using a DITA DTD specialization?
In order to sort this out I might need to have a full sample on my side with a small DITA topic, the specialization DTD plugins, maybe even the framework configuration.
Regards,
Radu
Radu Coravu 
<oXygen/> XML Editor
http://www.oxygenxml.com
						<oXygen/> XML Editor
http://www.oxygenxml.com
- 
				ckabstein
- Posts: 152
- Joined: Fri Apr 24, 2015 12:28 pm
Re: Reuse content action automatically inserts a <ph/> element
Hi Radu,
After investigating a little bit more, I've found that there is now some kind of built-in functionality that automatically inserts the first element that appears in the <choice> list in pt.content. So, for example, I've changed the <choice>-list in our RNG schema to reference "filepath" as the first element in the list instead of "ph.element". Now <filepath> is automatically inserted in the <pt> element.
Our custom programming domain RNG:
Oxygen Author mode:
As I've used exactly the same framework in 25.0 and 25.1 and didn't make any new changes in the cc-config, I'm not sure if this is really a framework-related problem. As you can see in our RNG, the <choice> elements are not required. So I wonder why one of those elements is used.
Please let me know if you still require samples and respective framework files.
Thanks,
Christina
			
			
									
									After investigating a little bit more, I've found that there is now some kind of built-in functionality that automatically inserts the first element that appears in the <choice> list in pt.content. So, for example, I've changed the <choice>-list in our RNG schema to reference "filepath" as the first element in the list instead of "ph.element". Now <filepath> is automatically inserted in the <pt> element.
Our custom programming domain RNG:
Code: Select all
<define name="pt.content">
          <zeroOrMore>
            <choice>              
              <ref name="filepath"/>
              <ref name="ph.element"/>
              ...Code: Select all
<parml>
        <plentry conref="../_shared/my_xml_file_r.xml#my_xml_file_r/my_parameter">
          <pt><filepath/></pt>
          <pd/>
        </plentry>Please let me know if you still require samples and respective framework files.
Thanks,
Christina
oXygen XML Editor 27.1 build 2025041508
DITA OT 3.7.4
						DITA OT 3.7.4
- 
				Radu
- Posts: 9543
- Joined: Fri Jul 09, 2004 5:18 pm
Re: Reuse content action automatically inserts a <ph/> element
Hi Christina,
Thanks for the extra details, especially about that choice used inside the RNG schema, I do not think I need more samples for now.
Indeed this looks like a side effect of an issue we fixed in Oxygen 25.1 related to schema choices and Oxygen's strive to create valid XML elements with all their required elements when inserting conrefs. But indeed when the choice is zero or more, Oxygen should not follow the choice and generate the first element inside it.
I added an internal issue on our side to look more into this, pasting the internal issue ID below for future reference:
EXM-54709 Descendants of inserted element with conref has non required child elements
In the meantime you can probably ignore the issue, the publishing should not take the extra content generated inside the element which contains the conref into account anyway.
Regards,
Radu
			
			
									
									Thanks for the extra details, especially about that choice used inside the RNG schema, I do not think I need more samples for now.
Indeed this looks like a side effect of an issue we fixed in Oxygen 25.1 related to schema choices and Oxygen's strive to create valid XML elements with all their required elements when inserting conrefs. But indeed when the choice is zero or more, Oxygen should not follow the choice and generate the first element inside it.
I added an internal issue on our side to look more into this, pasting the internal issue ID below for future reference:
EXM-54709 Descendants of inserted element with conref has non required child elements
In the meantime you can probably ignore the issue, the publishing should not take the extra content generated inside the element which contains the conref into account anyway.
Regards,
Radu
Radu Coravu 
<oXygen/> XML Editor
http://www.oxygenxml.com
						<oXygen/> XML Editor
http://www.oxygenxml.com
- 
				ckabstein
- Posts: 152
- Joined: Fri Apr 24, 2015 12:28 pm
Re: Reuse content action automatically inserts a <ph/> element
Hi Radu,
You're right. For publishing, ignoring the issue is not a problem. For localization, though, it is, because that element turns up in its own segment.
I will create a Schematron rule for this, so that authors can validate their docs to take out the element. I've already had a rule for empty <ph> elements, but it didn't apply to conrefed <plentry> elements.
Thanks!
Christina
			
			
									
									You're right. For publishing, ignoring the issue is not a problem. For localization, though, it is, because that element turns up in its own segment.

I will create a Schematron rule for this, so that authors can validate their docs to take out the element. I've already had a rule for empty <ph> elements, but it didn't apply to conrefed <plentry> elements.
Thanks!
Christina
oXygen XML Editor 27.1 build 2025041508
DITA OT 3.7.4
						DITA OT 3.7.4
- 
				Radu
- Posts: 9543
- Joined: Fri Jul 09, 2004 5:18 pm
Re: Reuse content action automatically inserts a <ph/> element
Hi Christina,
The issue is still opened, what I wrote on the issue about a year ago is that I do not know how to fix it. There is not enough information in that specific part of the code to know if a choice has zero or one or more elements and I do not want to revert the fix which lead to this side effect as before the fix there was a situation in which the generated XML content for inserting a conref could become invalid, so I prefer a case where an extra inline element is generated to the case in which an element without a required choice child is generated.
Regards,
Radu
			
			
									
									The issue is still opened, what I wrote on the issue about a year ago is that I do not know how to fix it. There is not enough information in that specific part of the code to know if a choice has zero or one or more elements and I do not want to revert the fix which lead to this side effect as before the fix there was a situation in which the generated XML content for inserting a conref could become invalid, so I prefer a case where an extra inline element is generated to the case in which an element without a required choice child is generated.
Regards,
Radu
Radu Coravu 
<oXygen/> XML Editor
http://www.oxygenxml.com
						<oXygen/> XML Editor
http://www.oxygenxml.com
Return to “DITA (Editing and Publishing DITA Content)”
			
				Jump to
				
			
		
			
			
	
	- Oxygen XML Editor/Author/Developer
- ↳ Feature Request
- ↳ Common Problems
- ↳ DITA (Editing and Publishing DITA Content)
- ↳ Artificial Intelligence (AI Positron Assistant add-on)
- ↳ SDK-API, Frameworks - Document Types
- ↳ DocBook
- ↳ TEI
- ↳ XHTML
- ↳ Other Issues
- Oxygen XML Web Author
- ↳ Feature Request
- ↳ Common Problems
- Oxygen Content Fusion
- ↳ Feature Request
- ↳ Common Problems
- Oxygen JSON Editor
- ↳ Feature Request
- ↳ Common Problems
- Oxygen PDF Chemistry
- ↳ Feature Request
- ↳ Common Problems
- Oxygen Feedback
- ↳ Feature Request
- ↳ Common Problems
- Oxygen XML WebHelp
- ↳ Feature Request
- ↳ Common Problems
- XML
- ↳ General XML Questions
- ↳ XSLT and FOP
- ↳ XML Schemas
- ↳ XQuery
- NVDL
- ↳ General NVDL Issues
- ↳ oNVDL Related Issues
- XML Services Market
- ↳ Offer a Service