Sample code for 30+ languages & platforms
Delphi DLL

Auto-Trim XML Content when Loading

See more XML Examples

This example explains the "autoTrim" argument that is passed to a method such as LoadXml2.

Chilkat Delphi DLL Downloads

Delphi DLL
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Xml;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
xml: HCkXml;
autoTrim: Boolean;

begin
success := False;

xml := CkXml_Create();

// If autoTrim is True, then the content inside an leaf element is trimmed.
// For example:
autoTrim := True;
CkXml_LoadXml2(xml,'<abc><xyz>  123   </xyz></abc>',autoTrim);
Memo1.Lines.Add(CkXml__getXml(xml));

// Output is:
// (notice the SPACE chars before and after "xyz" are trimmed)

// <?xml version="1.0" encoding="utf-8" ?>
// <abc>
//     <xyz>123</xyz>
// </abc>

// If autoTrim is False, then the content inside leaf elements are not trimmed.
autoTrim := False;
CkXml_LoadXml2(xml,'<abc><xyz>  123   </xyz></abc>',autoTrim);
Memo1.Lines.Add(CkXml__getXml(xml));

// Output is:

// <?xml version="1.0" encoding="utf-8" ?>
// <abc>
//     <xyz>  123   </xyz>
// </abc>

// --------------------------------------------------------------------
// The EmitCompact property controls whether XML is emitted indented (pretty-printed)
// or compact.  For example:

// Auto-trim + emit compact:
autoTrim := True;
CkXml_LoadXml2(xml,'<abc><xyz>  123   </xyz></abc>',autoTrim);
CkXml_putEmitCompact(xml,True);
Memo1.Lines.Add(CkXml__getXml(xml));

// Output is:

// <?xml version="1.0" encoding="utf-8" ?>
// <abc><xyz>123</xyz></abc>

// No Auto-trim + emit compact:
autoTrim := False;
CkXml_LoadXml2(xml,'<abc><xyz>  123   </xyz></abc>',autoTrim);
CkXml_putEmitCompact(xml,True);
Memo1.Lines.Add(CkXml__getXml(xml));

// Output is:

// <?xml version="1.0" encoding="utf-8" ?>
// <abc><xyz>  123   </xyz></abc>

CkXml_Dispose(xml);

end;