/** * vim: set ts=4 : * ============================================================================= * SourceMod (C)2004-2007 AlliedModders LLC. All rights reserved. * ============================================================================= * * This file is part of the SourceMod/SourcePawn SDK. * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License, version 3.0, as published by the * Free Software Foundation. * * This program 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 General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . * * As a special exception, AlliedModders LLC gives you permission to link the * code of this program (as well as its derivative works) to "Half-Life 2," the * "Source Engine," the "SourcePawn JIT," and any Game MODs that run on software * by the Valve Corporation. You must obey the GNU General Public License in * all respects for all other code used. Additionally, AlliedModders LLC grants * this exception to all derivative works. AlliedModders LLC defines further * exceptions, found in LICENSE.txt (as of this writing, version JULY-31-2007), * or . * * Version: $Id$ */ #if defined _handles_included #endinput #endif #define _handles_included /** * Handle helper macros. */ enum Handle { INVALID_HANDLE = 0, }; /** * Returns if a handle is valid or not. * @note It is not a good idea to call this on every Handle. If you code properly, * all of your Handles will either be valid or will expose important bugs to fix. * This is provided for situations only where testing for handle validity is needed. * * @param hndl Handle to test for validity. * @return True if handle is valid, false otherwise. */ native bool:IsValidHandle(Handle:hndl); /** * Closes a Handle. If the handle has multiple copies open, * it is not destroyed unless all copies are closed. * * @note Closing a Handle has a different meaning for each Handle type. Make * sure you read the documentation on whatever provided the Handle. * * @param hndl Handle to close. * @return True if successful, false if not closeable. * @error Invalid handles will cause a run time error. */ native bool:CloseHandle(Handle:hndl); /** * Clones a Handle. When passing handles in between plugins, caching handles * can result in accidental invalidation when one plugin releases the Handle, or is its owner * is unloaded from memory. To prevent this, the Handle may be "cloned" with a new owner. * * @note Usually, you will be cloning Handles for other plugins. This means that if you clone * the Handle without specifying the new owner, it will assume the identity of your original calling * plugin, which is not very useful. You should either specify that the receiving plugin should * clone the handle on its own, or you should explicitly clone the Handle using the receiving plugin's * identity Handle. * * @param hndl Handle to clone/duplicate. * @param plugin Optional Handle to another plugin to mark as the new owner. * If no owner is passed, the owner becomes the calling plugin. * @return Handle on success, INVALID_HANDLE if not cloneable. * @error Invalid handles will cause a run time error. */ native Handle:CloneHandle(Handle:hndl, Handle:plugin=INVALID_HANDLE);