summaryrefslogtreecommitdiffstats
path: root/wizards/com/sun/star/wizards/web/export/AbstractExporter.java
diff options
context:
space:
mode:
Diffstat (limited to 'wizards/com/sun/star/wizards/web/export/AbstractExporter.java')
-rw-r--r--wizards/com/sun/star/wizards/web/export/AbstractExporter.java150
1 files changed, 105 insertions, 45 deletions
diff --git a/wizards/com/sun/star/wizards/web/export/AbstractExporter.java b/wizards/com/sun/star/wizards/web/export/AbstractExporter.java
index cadb10ec2ee2..71c214a272e6 100644
--- a/wizards/com/sun/star/wizards/web/export/AbstractExporter.java
+++ b/wizards/com/sun/star/wizards/web/export/AbstractExporter.java
@@ -1,9 +1,39 @@
/*
+ ************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2008 by Sun Microsystems, Inc.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: AbstractExporter.java,v $
+ *
+ * $Revision: 1.6.192.1 $
+ *
+ * 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.
+ *
+ ************************************************************************/
+/*
* AbstractExporter.java
*
* Created on 1. Oktober 2003, 16:12
*/
-
package com.sun.star.wizards.web.export;
import com.sun.star.beans.PropertyValue;
@@ -31,107 +61,137 @@ import com.sun.star.wizards.web.data.TypeDetection;
*
* @author rpiterman
*/
-public abstract class AbstractExporter implements Exporter {
+public abstract class AbstractExporter implements Exporter
+{
+
protected CGExporter exporter;
protected FileAccess fileAccess;
protected void storeToURL(Object officeDocument, Properties props, String targetUrl, String filterName, PropertyValue[] filterData)
- throws IOException {
-
- props = new Properties();
- props.put("FilterName", filterName);
+ throws IOException
+ {
- if (filterData.length>0)
- props.put("FilterData", filterData);
+ props = new Properties();
+ props.put("FilterName", filterName);
- XStorable xs = ((XStorable)UnoRuntime.queryInterface(XStorable.class,officeDocument));
- PropertyValue[] o = props.getProperties();
- xs.storeToURL(targetUrl, o);
- }
+ if (filterData.length > 0)
+ {
+ props.put("FilterData", filterData);
+ }
+ XStorable xs = ((XStorable) UnoRuntime.queryInterface(XStorable.class, officeDocument));
+ PropertyValue[] o = props.getProperties();
+ xs.storeToURL(targetUrl, o);
+ }
- protected void storeToURL(Object officeDocument, String targetUrl, String filterName, PropertyValue[] filterData)
- throws IOException {
+ protected void storeToURL(Object officeDocument, String targetUrl, String filterName, PropertyValue[] filterData)
+ throws IOException
+ {
- storeToURL(officeDocument, new Properties(), targetUrl, filterName, filterData);
- }
+ storeToURL(officeDocument, new Properties(), targetUrl, filterName, filterData);
+ }
- protected void storeToURL(Object officeDocument, String targetUrl, String filterName )
- throws IOException {
+ protected void storeToURL(Object officeDocument, String targetUrl, String filterName)
+ throws IOException
+ {
- storeToURL(officeDocument, new Properties(), targetUrl, filterName, new PropertyValue[0]);
+ storeToURL(officeDocument, new Properties(), targetUrl, filterName, new PropertyValue[0]);
- }
+ }
- protected String getArgument(String name, CGExporter p) {
- return ((CGArgument)p.cp_Arguments.getElement(name)).cp_Value;
+ protected String getArgument(String name, CGExporter p)
+ {
+ return ((CGArgument) p.cp_Arguments.getElement(name)).cp_Value;
}
protected Object openDocument(CGDocument doc, XMultiServiceFactory xmsf)
- throws com.sun.star.io.IOException
+ throws com.sun.star.io.IOException
{
Object document = null;
//open the document.
- try {
+ try
+ {
XDesktop desktop = Desktop.getDesktop(xmsf);
Properties props = new Properties();
props.put("Hidden", Boolean.TRUE);
props.put("MacroExecutionMode", new Short(MacroExecMode.NEVER_EXECUTE));
- props.put( "UpdateDocMode", new Short(UpdateDocMode.NO_UPDATE));
- document = ((XComponentLoader) UnoRuntime.queryInterface(XComponentLoader.class, desktop)).loadComponentFromURL( doc.cp_URL, "_blank", 0, props.getProperties());
- } catch (com.sun.star.lang.IllegalArgumentException iaex) {
+ props.put("UpdateDocMode", new Short(UpdateDocMode.NO_UPDATE));
+ document = ((XComponentLoader) UnoRuntime.queryInterface(XComponentLoader.class, desktop)).loadComponentFromURL(doc.cp_URL, "_blank", 0, props.getProperties());
+ }
+ catch (com.sun.star.lang.IllegalArgumentException iaex)
+ {
}
//try to get the number of pages in the document;
- try {
- pageCount(doc,document);
+ try
+ {
+ pageCount(doc, document);
}
- catch (Exception ex) {
+ catch (Exception ex)
+ {
//Here i do nothing since pages is not *so* important.
}
return document;
}
- protected void closeDocument(Object doc,XMultiServiceFactory xmsf) {
+ protected void closeDocument(Object doc, XMultiServiceFactory xmsf)
+ {
/*OfficeDocument.dispose(
- xmsf,
- (XComponent) UnoRuntime.queryInterface(XComponent.class, doc));*/
- try {
- XCloseable xc = (XCloseable)UnoRuntime.queryInterface(XCloseable.class, doc);
+ xmsf,
+ (XComponent) UnoRuntime.queryInterface(XComponent.class, doc));*/
+ try
+ {
+ XCloseable xc = (XCloseable) UnoRuntime.queryInterface(XCloseable.class, doc);
xc.close(false);
}
- catch (Exception ex) {
+ catch (Exception ex)
+ {
ex.printStackTrace();
}
}
- private void pageCount(CGDocument doc, Object document) {
+ private void pageCount(CGDocument doc, Object document)
+ {
if (doc.appType.equals(TypeDetection.WRITER_DOC))
+ {
doc.pages = TextDocument.getPageCount(document);
+ }
else if (doc.appType.equals(TypeDetection.IMPRESS_DOC))
+ {
doc.pages = OfficeDocument.getSlideCount(document);
+ }
else if (doc.appType.equals(TypeDetection.DRAW_DOC))
+ {
doc.pages = OfficeDocument.getSlideCount(document);
+ }
}
- public void init(CGExporter exporter_) {
+ public void init(CGExporter exporter_)
+ {
exporter = exporter_;
}
- protected FileAccess getFileAccess(XMultiServiceFactory xmsf) {
- if ( fileAccess == null )
- try {
+ protected FileAccess getFileAccess(XMultiServiceFactory xmsf)
+ {
+ if (fileAccess == null)
+ {
+ try
+ {
fileAccess = new FileAccess(xmsf);
}
- catch (Exception ex) {}
+ catch (Exception ex)
+ {
+ }
+ }
return fileAccess;
}
- protected void calcFileSize(CGDocument doc, String url, XMultiServiceFactory xmsf) {
+ protected void calcFileSize(CGDocument doc, String url, XMultiServiceFactory xmsf)
+ {
/*if the exporter exports to a
* binary format, get the size of the destination.
*/
if (exporter.cp_Binary)
+ {
doc.sizeBytes = getFileAccess(xmsf).getSize(url);
-
+ }
}
-
}