Porting to Left 4 Dead

From AlliedModders Wiki
Revision as of 02:23, 26 November 2008 by DS (talk | contribs)
Jump to: navigation, search

Porting Valve Server Plugins or Metamod:Source plugins to Left 4 Dead is not very difficult. This article explores some of the changes and how to simplify them.

Users of Metamod:Source must upgrade to Metamod:Source 1.7 and use the 1.6+ API (see MM:S API Differences).

As there is no official SDK yet, we've simply reverse engineered the new header files. These changes aren't guaranteed to be 100% correct and the SDK isn't complete for building mods -- just most plugins.


  • IVEngineServer::UserMessageBegin now takes an additional string parameter containing the message name.
  • The low-level datagram type for setting replicated convars on clients has changed from 5 to 6.
  • CreateEntityByName appears to have a third parameter (SourceMod sets it to true).


IVEngineServer Functions

The IVEngineServer functions PEntityOfEntIndex and IndexOfEdict have been removed for faster code that can be inlined. An example of how to re-implement this (as Valve has not released a new SDK yet):

inline int IndexOfEdict(const edict_t *pEdict)
	return (int)(pEdict - gpGlobals->baseEdict);
inline edict_t *PEntityOfEntIndex(int iEntIndex)
	if (iEntIndex >= 0 && iEntIndex < gpGlobals->maxEntities)
		return (edict_t *)(gpGlobals->baseEdict + iEntIndex);
	return NULL;

ICVar functions

The function GetCommands has been removed. In general, FindCommand can be used as a replacement.

However, if iterating across all ConCommandBases is a must, then use FactoryInternalIterator. This returns a pointer to ICvarIteratorInternal. An example of how to use these:

ICvarIteratorInternal *iter = icvar->FactoryInternalIterator();
while (iter->IsValid())
	ConCommandBase *pCmd = iter->Get();
	Msg("ConCommandBase: %s\n", pCmd->GetName());


The console will spew "VPK" warnings unless your file-backed KeyValues operations use relative paths instead of absolute paths.