All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.izforge.izpack.uninstaller.resource.Executables Maven / Gradle / Ivy

There is a newer version: 5.2.3
Show newest version
/*
 * IzPack - Copyright 2001-2012 Julien Ponge, All Rights Reserved.
 *
 * http://izpack.org/
 * http://izpack.codehaus.org/
 *
 * Copyright 2012 Tim Anderson
 *
 * 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 com.izforge.izpack.uninstaller.resource;

import java.io.ObjectInputStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.logging.Logger;

import com.izforge.izpack.api.exception.IzPackException;
import com.izforge.izpack.api.handler.Prompt;
import com.izforge.izpack.api.resource.Resources;
import com.izforge.izpack.core.handler.PromptUIHandler;
import com.izforge.izpack.api.data.ExecutableFile;
import com.izforge.izpack.util.FileExecutor;
import com.izforge.izpack.util.PlatformModelMatcher;


/**
 * The uninstaller {@link ExecutableFile}s.
 *
 * @author Tim Anderson
 */
public class Executables
{

    /**
     * The executables.
     */
    private final List executables;

    /**
     * The platform-model matcher.
     */
    private final PlatformModelMatcher matcher;

    /**
     * The prompt for reporting errors.
     */
    private final Prompt prompt;

    /**
     * The logger.
     */
    private static final Logger logger = Logger.getLogger(Executables.class.getName());


    /**
     * Constructs an Executables.
     *
     * @param resources used to locate the executables resource
     * @param matcher   the platform-model matcher
     * @param prompt    the prompt for reporting errors
     * @throws IzPackException if the executables cannot be read
     */
    public Executables(Resources resources, PlatformModelMatcher matcher, Prompt prompt)
    {
        this.prompt = prompt;
        this.matcher = matcher;
        executables = read(resources);
    }

    /**
     * Runs the {@link ExecutableFile}s.
     * 

* TODO - should this update the uninstall progress? * * @return true if they were run successfully */ public boolean run() { for (ExecutableFile file : executables) { if (file.executionStage == ExecutableFile.UNINSTALL && matcher.matchesCurrentPlatform(file.osList)) { if (!run(file)) { return false; } } } return true; } /** * Runs an executable file. * * @param file the file to execute * @return true if it ran successfully, otherwise false */ protected boolean run(ExecutableFile file) { FileExecutor executor = new FileExecutor(Arrays.asList(file)); int status = executor.executeFiles(ExecutableFile.UNINSTALL, matcher, new PromptUIHandler(prompt)); if (status != 0) { logger.severe("Executable=" + file.path + " exited with status=" + status); return false; } return true; } /** * Reads the executables. * * @return the executables * @throws IzPackException if the executables cannot be read */ private List read(Resources resources) { List executables = new ArrayList(); try { ObjectInputStream in = new ObjectInputStream(resources.getInputStream("executables")); int count = in.readInt(); for (int i = 0; i < count; i++) { ExecutableFile file = (ExecutableFile) in.readObject(); executables.add(file); } } catch (Exception exception) { throw new IzPackException("Failed to read executable resources", exception); } return executables; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy