org.jodconverter.local.office.OfficeDescriptor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jodconverter-local Show documentation
Show all versions of jodconverter-local Show documentation
Module required in order to process local conversions for the Java OpenDocument Converter (JODConverter) project.
The newest version!
/*
* Copyright (c) 2004 - 2012; Mirko Nasato and contributors
* 2016 - 2022; Simon Braconnier and contributors
* 2022 - present; JODConverter
*
* This file is part of JODConverter - Java OpenDocument Converter.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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 org.jodconverter.local.office;
import java.util.List;
import java.util.Locale;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/** Contains basic information about the office installation being used. */
public final class OfficeDescriptor {
private static final Logger LOGGER = LoggerFactory.getLogger(OfficeDescriptor.class);
private static final String LIBRE_OFFICE = "LibreOffice";
private static final String OPEN_OFFICE = "OpenOffice";
private static final String LIBRE_OFFICE_LCASE = "libreoffice";
private static final String OPEN_OFFICE_LCASE = "openoffice";
private String product = "???";
private String version = "???";
private boolean useLongOptionNameGnuStyle;
private OfficeDescriptor() {}
/**
* Creates descriptor from the command line output using the help option.
*
* @param lines The output lines of the execution.
* @return The descriptor.
*/
public static @NonNull OfficeDescriptor fromHelpOutput(
final @NonNull List<@NonNull String> lines) {
final OfficeDescriptor desc = new OfficeDescriptor();
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("Building {} from help output lines", OfficeDescriptor.class.getName());
}
for (final String line : lines) {
if (line.contains("--help")) {
desc.useLongOptionNameGnuStyle = true;
} else {
fromLine(desc, line);
}
}
if (LOGGER.isInfoEnabled()) {
LOGGER.info("soffice info (from help output): {}", desc);
}
return desc;
}
private static void fromLine(final OfficeDescriptor desc, final String line) {
final String lowerLine = line.trim().toLowerCase(Locale.ROOT);
if (lowerLine.startsWith(OPEN_OFFICE_LCASE) || lowerLine.startsWith(LIBRE_OFFICE_LCASE)) {
final String productLine = line.trim();
final String[] parts = productLine.split(" ");
if (parts.length > 0) {
desc.product = parts[0];
if (parts.length > 1) {
desc.version = parts[1];
}
}
}
}
/**
* Creates descriptor from the office installation path.
*
* @param path The installation path.
* @return The descriptor.
*/
public static @NonNull OfficeDescriptor fromExecutablePath(final @NonNull String path) {
final OfficeDescriptor desc = new OfficeDescriptor();
final String lowerPath = path.toLowerCase(Locale.ROOT);
if (lowerPath.contains(LIBRE_OFFICE_LCASE)) {
desc.product = LIBRE_OFFICE;
desc.useLongOptionNameGnuStyle = true;
} else if (lowerPath.contains(OPEN_OFFICE_LCASE)) {
desc.product = OPEN_OFFICE;
desc.useLongOptionNameGnuStyle = false;
}
// Version cannot be known from the installation path.
if (LOGGER.isInfoEnabled()) {
LOGGER.info("soffice info (from exec path): {}", desc);
}
return desc;
}
/**
* Gets the product name of the office installation being used.
*
* @return LibreOffice or OpenOffice or ??? if unknown.
*/
public @NonNull String getProduct() {
return product;
}
/**
* Gets the version of the office installation being used.
*
* @return The version or ??? if unknown.
*/
public @NonNull String getVersion() {
return version;
}
/**
* Gets whether we must use the lone option name GNU style (--) when setting command line options
* to start an office instance.
*
* @return {@code true} to use the lone option name GNU style,{@code false} otherwise.
*/
public boolean useLongOptionNameGnuStyle() {
return useLongOptionNameGnuStyle;
}
@Override
public @NonNull String toString() {
return String.format(
"Product: %s - Version: %s - useLongOptionNameGnuStyle: %s",
getProduct(), getVersion(), useLongOptionNameGnuStyle());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy