summaryrefslogtreecommitdiff
path: root/xmerge/java/org/openoffice/xmerge/converter/xml/EmbeddedXMLObject.java
diff options
context:
space:
mode:
Diffstat (limited to 'xmerge/java/org/openoffice/xmerge/converter/xml/EmbeddedXMLObject.java')
-rw-r--r--xmerge/java/org/openoffice/xmerge/converter/xml/EmbeddedXMLObject.java298
1 files changed, 0 insertions, 298 deletions
diff --git a/xmerge/java/org/openoffice/xmerge/converter/xml/EmbeddedXMLObject.java b/xmerge/java/org/openoffice/xmerge/converter/xml/EmbeddedXMLObject.java
deleted file mode 100644
index c07f6f116ca2..000000000000
--- a/xmerge/java/org/openoffice/xmerge/converter/xml/EmbeddedXMLObject.java
+++ /dev/null
@@ -1,298 +0,0 @@
-/************************************************************************
- *
- * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
- *
- * Copyright 2000, 2010 Oracle and/or its affiliates.
- *
- * OpenOffice.org - a multi-platform office productivity suite
- *
- * This file is part of OpenOffice.org.
- *
- * OpenOffice.org is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License version 3
- * only, as published by the Free Software Foundation.
- *
- * OpenOffice.org is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Lesser General Public License version 3 for more details
- * (a copy is included in the LICENSE file that accompanied this code).
- *
- * You should have received a copy of the GNU Lesser General Public License
- * version 3 along with OpenOffice.org. If not, see
- * <http://www.openoffice.org/license.html>
- * for a copy of the LGPLv3 License.
- *
- ************************************************************************/
-
-package org.openoffice.xmerge.converter.xml;
-
-import java.io.ByteArrayInputStream;
-import java.io.IOException;
-
-import javax.xml.parsers.DocumentBuilder;
-import javax.xml.parsers.DocumentBuilderFactory;
-import javax.xml.parsers.ParserConfigurationException;
-
-import org.w3c.dom.Document;
-import org.w3c.dom.DOMException;
-import org.w3c.dom.Element;
-import org.w3c.dom.Node;
-
-import org.xml.sax.EntityResolver;
-import org.xml.sax.InputSource;
-import org.xml.sax.SAXException;
-
-/**
- * This class represents those embedded objects in an OpenOffice.org document
- * that have an XML representation. Currently, according to the OpenOffice.org
- * File Format 1.0 document, there are 6 such objects:
- *
- * Formulae created with Math (application/vnd.sun.xml.math)
- * Charts created with Chart (application/vnd.sun.xml.chart)
- * Spreadsheets created with Calc (application/vnd.sun.xml.calc)
- * Text created with Writer (application/vnd.sun.xml.writer)
- * Drawings created with Draw (application/vnd.sun.xml.draw)
- * Presentations created with Impress (application/vnd.sun.xml.impress)
- *
- * These object types are stored using a combination of content, settings and styles
- * XML files.
- */
-public class EmbeddedXMLObject extends EmbeddedObject {
-
- // Entries for the subdocuments that constitute this object;
- protected Document contentDOM = null;
- protected Document settingsDOM = null;
- protected Document stylesDOM = null;
-
- private DocumentBuilder builder = null;
-
- /**
- * Constructor for an embedded object stored using an XML representation.
- *
- * @param name The name of the object.
- * @param type The mime-type of the object. See the class summary.
- */
- public EmbeddedXMLObject(String name, String type) {
- super(name, type);
- }
-
- /**
- * Package private constructor for use when reading an object from a
- * compressed SX? file.
- *
- * @param name The name of the object.
- * @param type The mime-type of the object. See the class summary.
- * @param source The OfficeZip representation of the SX? file that stores
- * the object.
- */
- EmbeddedXMLObject(String name, String type, OfficeZip source) {
- super(name, type, source);
- }
-
-
- /**
- * Returns the content data for this embedded object.
- *
- * @return DOM represenation of "content.xml"
- *
- * @throws SAXException If any parser error occurs
- * @throws IOException If any IO error occurs
- */
- public Document getContentDOM() throws SAXException, IOException {
-
- if (contentDOM == null) {
- contentDOM = getNamedDOM("content.xml");
- }
-
- return contentDOM;
- }
-
-
- /**
- * Sets the content data for the embedded object.
- *
- * @param content DOM representation of the object's content.
- */
- public void setContentDOM(Document content) {
- contentDOM = content;
- hasChanged = true;
- }
-
-
- /**
- * Returns the settings data for this embedded object.
- *
- * @return DOM represenation of "settings.xml"
- *
- * @throws SAXException If any parser error occurs
- * @throws IOException If any IO error occurs
- */
- public Document getSettingsDOM() throws SAXException, IOException {
-
- if (settingsDOM == null) {
- settingsDOM = getNamedDOM("settings.xml");
- }
-
- return settingsDOM;
- }
-
-
- /**
- * Sets the settings data for the embedded object.
- *
- * @param styles DOM representation of the object's styles.
- */
- public void setSettingsDOM(Document settings) {
- settingsDOM = settings;
- hasChanged = true;
- }
-
-
- /**
- * Returns the style data for this embedded object.
- *
- * @return DOM represenation of "styles.xml"
- *
- * @throws SAXException If any parser error occurs
- * @throws IOException If any IO error occurs
- */
- public Document getStylesDOM() throws SAXException, IOException {
-
- if (stylesDOM == null) {
- stylesDOM = getNamedDOM("styles.xml");
- }
-
- return stylesDOM;
- }
-
-
- /**
- * Sets the styles data for the embedded object.
- *
- * @param styles DOM representation of the object's styles.
- */
- public void setStylesDOM(Document styles) {
- stylesDOM = styles;
- hasChanged = true;
- }
-
-
- /**
- * This method extracts the data for the given XML file from the SX? file
- * and creates a DOM representation of it.
- *
- * @param name The name of the XML file to retrieve. It is paired with
- * the object name to access the SX? file.
- *
- * @return DOM representation of the named XML file.
- *
- * @throws SAXException If any parser error occurs
- * @throws IOException If any IO error occurs
- */
- private Document getNamedDOM(String name) throws SAXException, IOException {
- if (zipFile == null) {
- return null;
- }
-
- try {
- if (builder == null) {
- DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
-
- factory.setValidating(false);
- builder = factory.newDocumentBuilder();
- }
-
- byte[] data = zipFile.getNamedBytes(new String(objName + "/" + name));
- if (data != null) {
- return OfficeDocument.parse(builder, data);
- }
- else {
- return null;
- }
-
- }
- catch (SAXException se) {
- throw se;
- }
- catch (IOException ioe) {
- throw ioe;
- }
- catch (ParserConfigurationException pce) {
- throw new SAXException(pce);
- }
- }
-
-
- /**
- * Package private method for writing the data of the EmbeddedObject to a
- * SX? file.
- *
- * @param zip An <code>OfficeZip</code> instance representing the file
- * the data is to be written to.
- */
- void write(OfficeZip zip) throws IOException {
- if (hasChanged == true) {
- if (contentDOM != null) {
- zip.setNamedBytes(new String(objName + "/content.xml"),
- OfficeDocument.docToBytes(contentDOM));
- }
- if (settingsDOM != null) {
- zip.setNamedBytes(new String(objName + "/settings.xml"),
- OfficeDocument.docToBytes(settingsDOM));
- }
- if (stylesDOM != null) {
- zip.setNamedBytes(new String(objName + "/styles.xml"),
- OfficeDocument.docToBytes(stylesDOM));
- }
- }
- }
-
- /**
- * Package private method that constructs the manifest.xml entries for this
- * embedded object.
- *
- * @param manifestDoc <code>Document</code> containing the manifest entries.
- */
- void writeManifestData(Document manifestDoc) throws DOMException {
- Node root = manifestDoc.getDocumentElement();
-
- if (contentDOM != null) {
- Element contentNode = manifestDoc.createElement(OfficeConstants.TAG_MANIFEST_FILE);
-
- contentNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_TYPE, "text/xml");
- contentNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_PATH,
- new String(objName + "/content.xml"));
-
- root.appendChild(contentNode);
- }
-
- if (settingsDOM != null) {
- Element settingsNode = manifestDoc.createElement(OfficeConstants.TAG_MANIFEST_FILE);
-
- settingsNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_TYPE, "text/xml");
- settingsNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_PATH,
- new String(objName + "/settings.xml"));
-
- root.appendChild(settingsNode);
- }
-
- if (stylesDOM != null) {
- Element stylesNode = manifestDoc.createElement(OfficeConstants.TAG_MANIFEST_FILE);
-
- stylesNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_TYPE, "text/xml");
- stylesNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_PATH,
- new String(objName + "/styles.xml"));
- }
-
-
- Element objectNode = manifestDoc.createElement(OfficeConstants.TAG_MANIFEST_FILE);
-
- objectNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_TYPE, objType);
- objectNode.setAttribute(OfficeConstants.ATTRIBUTE_MANIFEST_FILE_PATH,
- new String(objName + "/"));
-
- root.appendChild(objectNode);
- }
-
-} \ No newline at end of file