HLua/dmc/cl_dll
Dominik Tugend a800ff8246 Visual C++ 2010 Express support
fixes ValveSoftware/halflife#1338

Changes:
- added project files for Visual C++ 2010 Express
- resolved function calls that would otherwise be ambiguous now
- solved ARRAYSIZE macro and HSPRITE type collisions with Windows.h and
  winsock.h includes by guarding the includes

TODO:
We should think about if we actually should instead link to a .h that
defines / redirects the required macros, so that platform differences
would be limited to a few .cpp files (meaning not including windows.h in a
huge number of files as it is now), see the issue above for details.
2013-10-06 21:22:29 +02:00
..
quake initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
CTF_FlagStatus.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
CTF_HudMessage.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
DMC_BSPFile.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
DMC_Teleporters.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
DMC_Teleporters.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
Exports.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
GameStudioModelRenderer.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
GameStudioModelRenderer.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
MOTD.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
StudioModelRenderer.cpp Visual C++ 2010 Express support 2013-10-06 21:22:29 +02:00
StudioModelRenderer.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ammo.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ammo.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ammo_secondary.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ammohistory.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ammohistory.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
battery.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
camera.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
cdll_int.cpp Visual C++ 2010 Express support 2013-10-06 21:22:29 +02:00
cl_dll.dsp - convert DSP files to CRLF 2013-09-02 10:05:29 -07:00
cl_dll.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
cl_util.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
com_model.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
com_weapons.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
com_weapons.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
death.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
demo.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
demo.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
entity.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ev_common.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ev_hldm.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
ev_hldm.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
events.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
eventscripts.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
flashlight.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
geiger.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
health.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
health.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_iface.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_msg.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_redraw.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_servers.cpp Visual C++ 2010 Express support 2013-10-06 21:22:29 +02:00
hud_servers.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_servers_priv.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_spectator.cpp Visual C++ 2010 Express support 2013-10-06 21:22:29 +02:00
hud_spectator.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
hud_update.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
in_camera.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
in_defs.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
input.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
inputw32.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
kbutton.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
menu.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
message.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
readme.txt initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
saytext.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
scoreboard.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
status_icons.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
statusbar.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
studio_util.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
studio_util.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
text_message.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
train.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
tri.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
util.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
util.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
util_vector.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_ControlConfigPanel.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_CustomObjects.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_MOTDWindow.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_SchemeManager.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_SchemeManager.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_ScorePanel.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_ScorePanel.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_ServerBrowser.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_ServerBrowser.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_SpectatorPanel.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_SpectatorPanel.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_int.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_int.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_viewport.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
vgui_viewport.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
view.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
view.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
voice_status.cpp initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
voice_status.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00
wrect.h initial seed of Half-Life 1 SDK 2013-08-30 13:34:05 -07:00

readme.txt

  client dll readme.txt
-------------------------

This file details the structure of the half-life client dll,  and
how it communicates with the half-life game engine.


Engine callback functions:

Drawing functions:
	HSPRITE SPR_Load( char *picname );
		Loads a sprite into memory, and returns a handle to it.

	int  SPR_Frames( HSPRITE sprite );
		Returns the number of frames stored in the specified sprite.

	int  SPR_Height( HSPRITE x, int frame )
		Returns the height, in pixels, of a sprite at the specified frame.  
		Returns 0 is the frame number or the sprite handle is invalid.

	int  SPR_Width( HSPRITE x, int f )
		Returns the width, in pixels, of a sprite at the specified frame.  
		Returns 0 is the frame number or the sprite handle is invalid.

	int  SPR_Set( HSPRITE sprite, int r, int g, int b );
		Prepares a sprite about to be drawn.  RBG color values are applied to the sprite at this time.


	void  SPR_Draw( int frame, int x, int y );
		Precondition:  SPR_Set has already been called for a sprite.
		Draws the currently active sprite to the screen,  at position (x,y), where (0,0) is
		the top left-hand corner of the screen.


	void  SPR_DrawHoles( int frame, int x, int y );
		Precondition:  SPR_Set has already been called for a sprite.
		Draws the currently active sprite to the screen.  Color index #255 is treated as transparent.

	void  SPR_DrawAdditive( int frame, int x, int y );
		Precondition:  SPR_Set has already been called for a sprite.
		Draws the currently active sprite to the screen,  adding it's color values to the background.

	void  SPR_EnableScissor( int x, int y, int width, int height );
		Creates a clipping rectangle.  No pixels will be drawn outside the specified area.  Will
		stay in effect until either the next frame,  or SPR_DisableScissor is called.

	void  SPR_DisableScissor( void );
		Disables the effect of an SPR_EnableScissor call.

	int	 IsHighRes( void );
		returns 1 if the res mode is 640x480 or higher;  0 otherwise.

	int	 ScreenWidth( void );
		returns the screen width, in pixels.

	int	 ScreenHeight( void );
		returns the screen height, in pixels.

// Sound functions
	void PlaySound( char *szSound, int volume )
		plays the sound 'szSound' at the specified volume.  Loads the sound if it hasn't been cached.
		If it can't find the sound,  it displays an error message and plays no sound.

	void PlaySound( int iSound, int volume )
		Precondition:  iSound has been precached.
		Plays the sound, from the precache list.


// Communication functions
	void  SendClientCmd( char *szCmdString );
		sends a command to the server,  just as if the client had typed the szCmdString at the console.

	char *GetPlayerName( int entity_number );
		returns a pointer to a string, that contains the name of the specified client.  
		Returns NULL if the entity_number is not a client.
		

	DECLARE_MESSAGE(),  HOOK_MESSAGE()
		These two macros bind the message sending between the entity DLL and the client DLL to
		the CHud object.

		HOOK_MESSAGE( message_name )
			 This is used inside CHud::Init().  It calls into the engine to hook that message
			 from the incoming message stream.
			 Precondition:  There must be a function of name UserMsg_message_name declared
			 for CHud.  Eg,  CHud::UserMsg_Health() must be declared if you want to 
			 use HOOK_MESSAGE( Health );

		DECLARE_MESSAGE( message_name )
			For each HOOK_MESSAGE you must have an equivalent DECLARE_MESSAGE.  This creates
			a function which passes the hooked messages into the CHud object.


	HOOK_COMMAND(),  DECLARE_COMMAND()
		These two functions declare and hook console commands into the client dll.
		
		HOOK_COMMAND( char *command, command_name )
			Whenever the user types the 'command' at the console,  the function 'command_name'
			will be called.
			Precondition: There must be a function of the name UserCmd_command_name declared
			for CHud. Eg,  CHud::UserMsg_ShowScores() must be declared if you want to
			use HOOK_COMMAND( "+showscores", ShowScores );

		DECLARE_COMMAND( command_name )
			For each HOOK_COMMAND you must have an equivelant DECLARE_COMMAND.  This creates
			a function which passes the hooked commands into the CHud object.