Reliable formatting of ${ooo.user} variable in Open Office Startup

- Open office seems to be temperamental about starting if its env:UserInstallation argument doesn't begin "file:///" on Windows or "file://" on Unix. The argument may not contain any backslashes either. Unfortunately, this doesn't correspond to Java's File to URI conversion
- Created OpenOfficeURI class for doing the formatting instead instead

git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@14771 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
Dave Ward
2009-06-17 14:02:45 +00:00
parent 7ca716d403
commit 9f69064bd6
3 changed files with 178 additions and 1 deletions

View File

@@ -13,6 +13,13 @@
</property>
</bean>
<!-- We have to convert the user directory to an Open Office compatible URI -->
<bean id="userInstallationURI" class="org.alfresco.util.OpenOfficeURI">
<constructor-arg>
<value>${ooo.user}</value>
</constructor-arg>
</bean>
<bean id="openOfficeStartupCommand" class="org.alfresco.util.exec.RuntimeExec">
<property name="commandsAndArguments">
<map>
@@ -20,7 +27,14 @@
<list>
<value>${ooo.exe}</value>
<value>-accept=socket,host=localhost,port=8100;urp;StarOffice.ServiceManager</value>
<value>-env:UserInstallation=file:///${ooo.user}</value>
<bean class="org.alfresco.util.StringAppendingFactoryBean">
<property name="items">
<list>
<value>-env:UserInstallation=</value>
<ref bean="userInstallationURI" />
</list>
</property>
</bean>
<value>-nologo</value>
<value>-headless</value>
<value>-nofirststartwizard</value>

View File

@@ -0,0 +1,76 @@
/*
* Copyright (C) 2005-2009 Alfresco Software Limited.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program 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 General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* As a special exception to the terms and conditions of version 2.0 of
* the GPL, you may redistribute this Program in connection with Free/Libre
* and Open Source Software ("FLOSS") applications as described in Alfresco's
* FLOSS exception. You should have received a copy of the text describing
* the FLOSS exception, and it is also available here:
* http://www.alfresco.com/legal/licensing"
*/
package org.alfresco.util;
import java.io.File;
import java.io.IOException;
/**
* A class that attempts to embody OpenOffice's rules for encoding file URIs which appear to differ from Java's. A
* Windows style path is always prefixed "file:///" whereas a unix one is prefixed "file://".
*
* @author dward
*/
public class OpenOfficeURI
{
/** The source file. */
private File source;
/**
* Instantiates a new open office URI.
*
* @param source
* the source file to convert to a URI
*/
public OpenOfficeURI(File source)
{
this.source = source;
}
/*
* (non-Javadoc)
* @see java.lang.Object#toString()
*/
@Override
public String toString()
{
String absolute;
try
{
absolute = this.source.getCanonicalPath();
}
catch (IOException e)
{
throw new RuntimeException(e);
}
if (File.separatorChar != '/')
{
absolute = absolute.replace(File.separatorChar, '/');
}
return (absolute.startsWith("/") ? "file://" : "file:///") + absolute;
}
}

View File

@@ -0,0 +1,87 @@
/*
* Copyright (C) 2005-2009 Alfresco Software Limited.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program 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 General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* As a special exception to the terms and conditions of version 2.0 of
* the GPL, you may redistribute this Program in connection with Free/Libre
* and Open Source Software ("FLOSS") applications as described in Alfresco's
* FLOSS exception. You should have received a copy of the text describing
* the FLOSS exception, and it is also available here:
* http://www.alfresco.com/legal/licensing"
*/
package org.alfresco.util;
import org.springframework.beans.factory.FactoryBean;
/**
* A simple factory for glueing together multiple arguments as a string
*
* @author dward
*/
public class StringAppendingFactoryBean implements FactoryBean
{
/** The items. */
private Object[] items;
/**
* Sets the items to be appended together.
*
* @param items
* the items
*/
public void setItems(Object[] items)
{
this.items = items;
}
/*
* (non-Javadoc)
* @see org.springframework.beans.factory.FactoryBean#getObject()
*/
public Object getObject() throws Exception
{
if (this.items == null)
{
return "";
}
StringBuilder buff = new StringBuilder(1024);
for (Object item : this.items)
{
buff.append(item);
}
return buff.toString();
}
/*
* (non-Javadoc)
* @see org.springframework.beans.factory.FactoryBean#getObjectType()
*/
public Class<?> getObjectType()
{
return String.class;
}
/*
* (non-Javadoc)
* @see org.springframework.beans.factory.FactoryBean#isSingleton()
*/
public boolean isSingleton()
{
return true;
}
}