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

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