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

com.sun.jna.platform.win32.COM.COMException Maven / Gradle / Ivy

There is a newer version: 1.50.0
Show newest version
/* Copyright (c) 2012 Tobias Wolf, All Rights Reserved
 *
 * The contents of this file is dual-licensed under 2
 * alternative Open Source/Free licenses: LGPL 2.1 or later and
 * Apache License 2.0. (starting with JNA version 4.0.0).
 *
 * You can freely decide which license you want to apply to
 * the project.
 *
 * You may obtain a copy of the LGPL License at:
 *
 * http://www.gnu.org/licenses/licenses.html
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "LGPL2.1".
 *
 * You may obtain a copy of the Apache License at:
 *
 * http://www.apache.org/licenses/
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "AL2.0".
 */
package com.sun.jna.platform.win32.COM;

import com.sun.jna.platform.win32.WinNT.HRESULT;

/**
 * Exception class for all COM related classes.
 *
 * @author Tobias Wolf, [email protected]
 */
public class COMException extends RuntimeException {
    private static final long serialVersionUID = 1L;

    private final HRESULT hresult;

    /**
     * Instantiates a new automation exception.
     */
    public COMException() {
        this("", (Throwable) null);
    }

    /**
     * Instantiates a new automation exception.
     *
     * @param message
     *            the message
     */
    public COMException(String message) {
        this(message, (Throwable) null);
    }


    /**
     * Instantiates a new automation exception.
     *
     * @param cause
     *            the cause
     */
    public COMException(Throwable cause) {
        this(null, cause);
    }

    /**
     * Instantiates a new automation exception.
     *
     * @param message
     *            the message
     * @param cause
     *            the cause
     */
    public COMException(String message, Throwable cause) {
        super(message, cause);
        this.hresult = null;
    }

    /**
     * Instantiates a new automation exception.
     *
     * @param message
     *            the message
     * @param hresult
     *            HRESULT that lead to the creation of the COMException
     */
    public COMException(String message, HRESULT hresult) {
        super(message);
        this.hresult = hresult;
    }

    /**
     * @return the HRESULT that lead to thie COMException or NULL if the COMException as not directly caused by a native call
     */
    public HRESULT getHresult() {
        return hresult;
    }

    /**
     * @param errorCode
     * @return true if the exception has an associated HRESULT and that HRESULT
     * matches the supplied error code
     */
    public boolean matchesErrorCode(int errorCode) {
        return hresult != null && hresult.intValue() == errorCode;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy