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

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

There is a newer version: 1.2.2.1-jre17
Show newest version
/* Copyright (c) 2014 Dr David H. Akehurst (itemis), 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.Pointer;
import com.sun.jna.platform.win32.Guid.IID;
import com.sun.jna.platform.win32.WinBase.FILETIME;
import com.sun.jna.platform.win32.WinDef.DWORD;
import com.sun.jna.platform.win32.WinDef.DWORDByReference;
import com.sun.jna.platform.win32.WinNT.HRESULT;
import com.sun.jna.ptr.PointerByReference;

/**
 * Manages access to the running object table (ROT), a globally accessible
 * look-up table on each workstation.
 *
 * @see MSDN
 *
 */
public interface IRunningObjectTable extends IUnknown {

    public final static IID IID = new IID("{00000010-0000-0000-C000-000000000046}");

    /**
     * Creates and returns a pointer to an enumerator that can list the monikers
     * of all the objects currently registered in the running object table
     * (ROT).
     *
     * {@code
     *    HRESULT EnumRunning(
     *      [out] IEnumMoniker **ppenumMoniker
     *    );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT EnumRunning(PointerByReference ppenumMoniker);

    /**
     *
     * Determines whether the object identified by the specified moniker is
     * running, and if it is, retrieves a pointer to that object.
     *
     * {@code
     *   HRESULT GetObject(
     *     [in] IMoniker *pmkObjectName,
     *     [out] IUnknown **ppunkObject
     *   );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT GetObject(Pointer pmkObjectName, PointerByReference ppunkObject);

    /**
     * Retrieves the time that an object was last modified.
     *
     * {@code
     *   HRESULT GetTimeOfLastChange(
     *     [in]   IMoniker *pmkObjectName,
     *     [out]  FILETIME *pfiletime
     *   );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT GetTimeOfLastChange(Pointer pmkObjectName, FILETIME.ByReference pfiletime);

    /**
     * Determines whether the object identified by the specified moniker is
     * currently running.
     *
     * {@code
     *   HRESULT IsRunning(
     *     [in]  IMoniker *pmkObjectName
     *   );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT IsRunning(Pointer pmkObjectName);

    /**
     * Records the time that a running object was last modified.
     *
     * {@code
     *   HRESULT NoteChangeTime(
     *     [in]  DWORD dwRegister,
     *     [in]  FILETIME *pfiletime
     *   );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT NoteChangeTime(DWORD dwRegister, FILETIME pfiletime);

    /**
     * Registers an object and its identifying moniker in the running object
     * table (ROT).
     *
     * {@code
     *   HRESULT Register(
     *     [in]   DWORD grfFlags,
     *     [in]   IUnknown *punkObject,
     *     [in]   IMoniker *pmkObjectName,
     *     [out]  DWORD *pdwRegister
     *   );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT Register(DWORD grfFlags, Pointer punkObject, Pointer pmkObjectName, DWORDByReference pdwRegister);

    /**
     * Removes an entry from the running object table (ROT) that was previously
     * registered by a call to IRunningObjectTable.Register.
     *
     * {@code
     *   HRESULT Revoke(
     *     [in]  DWORD dwRegister
     *   );
     * }
     *
     * @see MSDN
     *
     */
    HRESULT Revoke(DWORD dwRegister);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy