com.sun.jna.platform.win32.COM.IRunningObjectTable Maven / Gradle / Ivy
/* Copyright (c) 2014 Dr David H. Akehurst (itemis), All Rights Reserved
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*/
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