/* * Copyright [2012] [wisemapping] * * Licensed under WiseMapping Public License, Version 1.0 (the "License"). * It is basically the Apache License, Version 2.0 (the "License") plus the * "powered by wisemapping" text requirement on every single page; * you may not use this file except in compliance with the License. * You may obtain a copy of the license at * * http://www.wisemapping.org/license * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.wisemapping.importer; import java.io.OutputStream; import org.apache.xml.serialize.OutputFormat; import org.apache.xml.serialize.XMLSerializer; import org.jetbrains.annotations.NotNull; import org.w3c.dom.Document; @SuppressWarnings("deprecation") public class JaxbCDATAMarshaller { public static XMLSerializer createMindmapXMLSerializer(@NotNull OutputStream out) { // configure an OutputFormat to handle CDATA OutputFormat of = new OutputFormat(); // specify which of your elements you want to be handled as CDATA. // The use of the '^' between the namespaceURI and the localname // seems to be an implementation detail of the xerces code. // When processing xml that doesn't use namespaces, simply omit the // namespace prefix as shown in the third CDataElement below. of.setCDataElements( new String[]{"^text"}); // // set any other options you'd like // of.setPreserveSpace(true); of.setIndenting(true); of.setEncoding("UTF-8"); // create the serializer XMLSerializer result = new XMLSerializer(of); result.setOutputByteStream(out); return result; } }