On 31 Jan 2019, at 9:25, Hussein Shafie wrote:
On 01/30/2019 05:48 PM, stefan wrote:

On 2019-01-30 11:08 a.m., Gerd Wagner wrote:

In fact, it's the other way around. XXE DOES NOT preserve the
"physical contents" of an XML file, since it deletes my user-inserted line break between </p> and <pre> and joins the two lines creating the
ugly formatting </p><pre>.

I suppose the point is that XXE does not even have a notion of "physical
contents". It doesn't deal with the underlying byte stream, only with
the XML *info set*.

True.

The rest is hidden within some XML I/O library that
doesn't preserve the state that you are interested in as non-semantic
content.

Yes.

I understand and agree with the above statements. But still, the following, doesn’t immedatly make sense to me:

We also give the user a few save options related to the "XML indentation":

7.3. Save options, http://www.xmlmind.com/xmleditor/_distrib/doc/help/saveOptions.html

The "XML indentation" options, turned on by default, confirm that XXE will not preserve the "physical contents" of an XML file.

To bring in some pun and fun: Many think of 'indentation' as 'intentation'. ;-)

The topic we discuss is a little confusing. And for that reason, I would like to point out some possible sources of (language) confusion:

(1) "Whitespace (preservation)" is not equivalent to "physical contents (preservation)".

(2) Another possible source of confustion is this:

I do not find anywhere in the above documententation of XXE’s indentation settings, that XXE will not preserve 'the "physical contents" of an XML file'. Instead I read "Default: checked." Which means that XXE, by default, does indent XML code. And in that regard, I think XXE faces the folloowing communication problem: For many users, "indentation" is equivalent to "the physical contents get presevered" - and that in XXE, there is no such link between indentation and preservation. Which is confusing.

What, exactly, is the role of indentation in XXE? Just as XXE once did not have a source editor, was there, perhaps, once a time when XXE did not even perform any indentation?

Ironically, in XXE, the only way to get (I believe) reliable "indentation" (by which I mean: "code formatting that follows a logical principle") is by **disabling** indentation .... Because, when one disables indentation, XXE will format Gerd’s code example according to the requirements of the "infoset", which means that his example ends up looking as follows:

    follows:</p
   ><pre
    class="role-listing-1"
   >SELECT title

The advantage of disabling indentation is that the code formatting becomes predictable.

However, human beings (almost) never "indent" like that. Clever XML users are probably usually not even aware of the fact that it is permitted, by XML, to place whitespace between the "</p" and the ">". (Some times even editing tools become confused by the whitespace between the "</p" and the ">".)

What you are asking is to augment XXE to carry the latter
around, too. Right ?

This feature is very unlikely to be implemented in the future.

From partaking in codifying the HTML5 specification, I am used to solving problems

* EITHER by adding a syntactic feature which fixes the problem
* OR by describing the problem outright in such a way that those who care are able EITHER live with the problem OR take the necessary steps to avoid the problem. The necessary steps to avoid the problem typically include specifying specific ways to use the language, so that problem does not occur. Such documentation might also include an accurate description of the way the applicaiton behaves.

Or to put it even simpler: Either add the feature. Or, alternatively, add good documentation (by which I mean: more than a disclaimer). The "or" variant is especially useful when the feature is not likely to be implemented.

And in that regard: XXE is such a good tool, that I think that documentation of strategies for using XXE together with other tools with as few problems as possible, would be very useful. How should one configure XXE for such a task? And how should/could one configure other tools?

For instance, for use with GIT and CVS, perhaps disabling the intendeation is exactly what is needed? And/Or perhaps the additional step of post-indentating XXE’s unindented source code would be needed. As well as de-indentation, according to XXE’s requirements, when you want to re-open/re-import the code in XXE. There are many tools out there for indentation and collapsing source code. Are there any tools that are very useful when working with XXE?

By the way: When it comes to the issue of preserving the source code, then - in fact - often, my problem is not so much the way XXE stores its source code, but rather that (to me) very small changes in an external editor, can negatively impact the WYSWYG editing in XXE (because empty lines suddenly appears in the text). More than once have I had to remove "possibly significant" white-space added by an external editor simply in order to make XXE’s WYSIWYG interface not display empty lines where I do not want to see them. How about describing an algorithm for such re-import? (I guess the algorithm would, amongst other things, have to say that one should remove whitespace between socalled block elements - for instance.)

(From my, perhaps, layman’s perspective, whenever I reopen a document on which I performed som editing in another editor than XXE, the problem is often rather that XXE preserves too much rather than too little white space/physical contents.)
--
Leif Halvard Silli
--
XMLmind XML Editor Support List
xmleditor-support@xmlmind.com
http://www.xmlmind.com/mailman/listinfo/xmleditor-support

Reply via email to