Sample code for 30+ languages & platforms
Unicode C++

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 Unicode C++ Downloads

Unicode C++
#include <CkXmlW.h>

void ChilkatSample(void)
    {
    bool success = false;

    CkXmlW xml;

    // If autoTrim is true, then the content inside an leaf element is trimmed.
    // For example:
    bool autoTrim = true;
    xml.LoadXml2(L"<abc><xyz>  123   </xyz></abc>",autoTrim);
    wprintf(L"%s\n",xml.getXml());

    // 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;
    xml.LoadXml2(L"<abc><xyz>  123   </xyz></abc>",autoTrim);
    wprintf(L"%s\n",xml.getXml());

    // 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;
    xml.LoadXml2(L"<abc><xyz>  123   </xyz></abc>",autoTrim);
    xml.put_EmitCompact(true);
    wprintf(L"%s\n",xml.getXml());

    // Output is:

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

    // No Auto-trim + emit compact:
    autoTrim = false;
    xml.LoadXml2(L"<abc><xyz>  123   </xyz></abc>",autoTrim);
    xml.put_EmitCompact(true);
    wprintf(L"%s\n",xml.getXml());

    // Output is:

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