mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 19:20:38 +00:00
Minor formatting changes, fix nedmalloc on BSD, fix win32 joystick detection issue, fix for ambient sounds, possible fix for stopsound malfunctioning after extended play time, add CON compilation error for duplicate "break" in switch statement
git-svn-id: https://svn.eduke32.com/eduke32@1599 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
512535c53f
commit
c369aec8cc
20 changed files with 167 additions and 756 deletions
|
@ -198,8 +198,6 @@ else
|
||||||
|
|
||||||
GAMEOBJS+= $(OBJ)/game_icon.$o $(OBJ)/sdlmusic.$o
|
GAMEOBJS+= $(OBJ)/game_icon.$o $(OBJ)/sdlmusic.$o
|
||||||
EDITOROBJS+= $(OBJ)/build_icon.$o
|
EDITOROBJS+= $(OBJ)/build_icon.$o
|
||||||
else
|
|
||||||
GAMEOBJS+= $(OBJ)/audiolib_musicstub.$o
|
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -248,15 +246,6 @@ ifeq (1,$(RELEASE))
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
duke3d_w32$(EXESUFFIX): $(OBJ)/wrapper.$o
|
|
||||||
$(LINK_STATUS)
|
|
||||||
if $(CC) $(CFLAGS) $(OURCFLAGS) -o $@ $^ -Wl; then $(LINK_OK); else $(LINK_FAILED); fi
|
|
||||||
ifeq (1,$(RELEASE))
|
|
||||||
ifeq (0,$(DEBUGANYWAY))
|
|
||||||
$(STRIP) duke3d_w32$(EXESUFFIX)
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
include Makefile.deps
|
include Makefile.deps
|
||||||
|
|
||||||
.PHONY: enginelib editorlib
|
.PHONY: enginelib editorlib
|
||||||
|
|
|
@ -46,8 +46,6 @@ $(OBJ)/mathutil.$o: $(SRC)/jmact/mathutil.c
|
||||||
$(OBJ)/scriplib.$o: $(SRC)/jmact/scriplib.c $(SRC)/jmact/scriplib.h $(SRC)/jmact/util_lib.h $(SRC)/jmact/_scrplib.h $(EINC)/compat.h
|
$(OBJ)/scriplib.$o: $(SRC)/jmact/scriplib.c $(SRC)/jmact/scriplib.h $(SRC)/jmact/util_lib.h $(SRC)/jmact/_scrplib.h $(EINC)/compat.h
|
||||||
|
|
||||||
# jAudioLib objects
|
# jAudioLib objects
|
||||||
$(OBJ)/audiolib_fxstub.$o: $(SRC)/jaudiolib/audiolib_fxstub.c $(SRC)/jaudiolib/fx_man.h
|
|
||||||
$(OBJ)/audiolib_musicstub.$o: $(SRC)/audiolib_musicstub.c $(JAUDIOLIBDIR)/include/music.h
|
|
||||||
|
|
||||||
$(OBJ)/mv_mix.$o: $(SRC)/jaudiolib/mv_mix.nasm
|
$(OBJ)/mv_mix.$o: $(SRC)/jaudiolib/mv_mix.nasm
|
||||||
$(OBJ)/mv_mix16.$o: $(SRC)/jaudiolib/mv_mix16.nasm
|
$(OBJ)/mv_mix16.$o: $(SRC)/jaudiolib/mv_mix16.nasm
|
||||||
|
|
|
@ -142,10 +142,6 @@ mapster32$(EXESUFFIX): $(EDITOROBJS) $(EOBJ)\$(ENGINELIB) $(EOBJ)\$(EDITORLIB) $
|
||||||
$(LINK) /OUT:$@ /SUBSYSTEM:WINDOWS /LIBPATH:$(DXROOT)\lib\x86" /LIBPATH:$(PLATFORMSDK)\lib" /LIBPATH:$(MSSDKROOT)\lib" $(flags_link) /MAP $** $(LIBS)
|
$(LINK) /OUT:$@ /SUBSYSTEM:WINDOWS /LIBPATH:$(DXROOT)\lib\x86" /LIBPATH:$(PLATFORMSDK)\lib" /LIBPATH:$(MSSDKROOT)\lib" $(flags_link) /MAP $** $(LIBS)
|
||||||
$(MT) -manifest $(RSRC)\manifest.build.xml -hashupdate -outputresource:$@ -out:$@.manifest
|
$(MT) -manifest $(RSRC)\manifest.build.xml -hashupdate -outputresource:$@ -out:$@.manifest
|
||||||
|
|
||||||
duke3d_w32$(EXESUFFIX): $(OBJ)/wrapper.$o
|
|
||||||
$(LINK) /OUT:$@ /SUBSYSTEM:WINDOWS /LIBPATH:$(DXROOT)\lib\x86" /LIBPATH:$(PLATFORMSDK)\lib" /LIBPATH:$(MSSDKROOT)\lib" $(flags_link) /MAP $** $(LIBS)
|
|
||||||
$(MT) -manifest $@.manifest -outputresource:$@
|
|
||||||
|
|
||||||
!include Makefile.deps
|
!include Makefile.deps
|
||||||
|
|
||||||
enginelib editorlib: AlwaysBuild
|
enginelib editorlib: AlwaysBuild
|
||||||
|
|
|
@ -3,8 +3,8 @@
|
||||||
ENGINELIB=libengine.a
|
ENGINELIB=libengine.a
|
||||||
EDITORLIB=libbuild.a
|
EDITORLIB=libbuild.a
|
||||||
|
|
||||||
# SDLCONFIG = /usr/local/bin/sdl-config
|
SDLCONFIG = /usr/local/bin/sdl-config
|
||||||
SDLCONFIG = sdl-config
|
# SDLCONFIG = sdl-config
|
||||||
|
|
||||||
ifeq ($(wildcard $(SDLCONFIG)),$(SDLCONFIG))
|
ifeq ($(wildcard $(SDLCONFIG)),$(SDLCONFIG))
|
||||||
SDLROOT = /usr/local
|
SDLROOT = /usr/local
|
||||||
|
|
|
@ -60,7 +60,7 @@ DEALINGS IN THE SOFTWARE.
|
||||||
#if defined(_WIN32)
|
#if defined(_WIN32)
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef __linux__
|
#if defined(__linux__) || defined(__FreeBSD__)
|
||||||
/* Sadly we can't include <malloc.h> as it causes a redefinition error */
|
/* Sadly we can't include <malloc.h> as it causes a redefinition error */
|
||||||
extern size_t malloc_usable_size(void *);
|
extern size_t malloc_usable_size(void *);
|
||||||
#endif
|
#endif
|
||||||
|
@ -215,10 +215,10 @@ size_t (*sysblksize)(void *)=
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
/* This is the MSVCRT equivalent */
|
/* This is the MSVCRT equivalent */
|
||||||
_msize;
|
_msize;
|
||||||
#elif defined(__linux__)
|
#elif defined(__linux__) || defined(__FreeBSD__)
|
||||||
/* This is the glibc/ptmalloc2/dlmalloc equivalent. */
|
/* This is the glibc/ptmalloc2/dlmalloc equivalent. */
|
||||||
malloc_usable_size;
|
malloc_usable_size;
|
||||||
#elif defined(__FreeBSD__) || defined(__APPLE__)
|
#elif defined(__APPLE__)
|
||||||
/* This is the BSD libc equivalent. */
|
/* This is the BSD libc equivalent. */
|
||||||
malloc_size;
|
malloc_size;
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -1259,7 +1259,7 @@ static BOOL CALLBACK InitDirectInput_enum(LPCDIDEVICEINSTANCE lpddi, LPVOID pvRe
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
// d = "OTHER"; break;
|
// d = "OTHER"; break;
|
||||||
return DIENUM_STOP;
|
return DIENUM_CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
initprintf(" * %s: %s\n", d, lpddi->tszProductName);
|
initprintf(" * %s: %s\n", d, lpddi->tszProductName);
|
||||||
|
|
|
@ -1238,7 +1238,7 @@ ACTOR_STATIC void G_MoveFX(void)
|
||||||
}
|
}
|
||||||
if (x >= ht && T1 == 1)
|
if (x >= ht && T1 == 1)
|
||||||
{
|
{
|
||||||
T1 = 0;
|
// T1 = 0;
|
||||||
S_StopEnvSound(s->lotag,i);
|
S_StopEnvSound(s->lotag,i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6798,9 +6798,9 @@ ACTOR_STATIC void G_MoveEffectors(void) //STATNUM 3
|
||||||
{
|
{
|
||||||
q = sprite[sprite[j].owner].sectnum;
|
q = sprite[sprite[j].owner].sectnum;
|
||||||
sector[sprite[j].sectnum].floorpal = sector[sprite[j].sectnum].ceilingpal =
|
sector[sprite[j].sectnum].floorpal = sector[sprite[j].sectnum].ceilingpal =
|
||||||
sector[q].floorpal;
|
sector[q].floorpal;
|
||||||
sector[sprite[j].sectnum].floorshade = sector[sprite[j].sectnum].ceilingshade =
|
sector[sprite[j].sectnum].floorshade = sector[sprite[j].sectnum].ceilingshade =
|
||||||
sector[q].floorshade;
|
sector[q].floorshade;
|
||||||
|
|
||||||
ActorExtra[sprite[j].owner].temp_data[0] = 2;
|
ActorExtra[sprite[j].owner].temp_data[0] = 2;
|
||||||
}
|
}
|
||||||
|
@ -6826,11 +6826,11 @@ ACTOR_STATIC void G_MoveEffectors(void) //STATNUM 3
|
||||||
{
|
{
|
||||||
q = sprite[l].sectnum;
|
q = sprite[l].sectnum;
|
||||||
sector[q].floorshade =
|
sector[q].floorshade =
|
||||||
sector[q].ceilingshade =
|
sector[q].ceilingshade =
|
||||||
sprite[sprite[l].owner].shade;
|
sprite[sprite[l].owner].shade;
|
||||||
sector[q].floorpal =
|
sector[q].floorpal =
|
||||||
sector[q].ceilingpal =
|
sector[q].ceilingpal =
|
||||||
sprite[sprite[l].owner].pal;
|
sprite[sprite[l].owner].pal;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -1,510 +0,0 @@
|
||||||
//-------------------------------------------------------------------------
|
|
||||||
/*
|
|
||||||
Duke Nukem Copyright (C) 1996, 2003 3D Realms Entertainment
|
|
||||||
|
|
||||||
This file is part of Duke Nukem 3D version 1.5 - Atomic Edition
|
|
||||||
|
|
||||||
Duke Nukem 3D is free software; you can redistribute it and/or
|
|
||||||
modify it under the terms of the GNU General Public License
|
|
||||||
as published by the Free Software Foundation; either version 2
|
|
||||||
of the License, or (at your option) any later version.
|
|
||||||
|
|
||||||
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, write to the Free Software
|
|
||||||
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
Dummy AudioLib stub implementation by Jonathon Fowler (jonof@edgenetwk.com)
|
|
||||||
*/
|
|
||||||
//-------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#include "music.h"
|
|
||||||
|
|
||||||
|
|
||||||
#define TRUE ( 1 == 1 )
|
|
||||||
#define FALSE ( !TRUE )
|
|
||||||
|
|
||||||
|
|
||||||
int32_t MUSIC_ErrorCode = MUSIC_Ok;
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_ErrorString
|
|
||||||
|
|
||||||
Returns a pointer to the error message associated with an error
|
|
||||||
number. A -1 returns a pointer the current error.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
char *MUSIC_ErrorString
|
|
||||||
(
|
|
||||||
int32_t ErrorNumber
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
char *ErrorString;
|
|
||||||
|
|
||||||
switch (ErrorNumber)
|
|
||||||
{
|
|
||||||
case MUSIC_Warning :
|
|
||||||
case MUSIC_Error :
|
|
||||||
ErrorString = MUSIC_ErrorString(MUSIC_ErrorCode);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_Ok :
|
|
||||||
ErrorString = "Music ok.";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_ASSVersion :
|
|
||||||
ErrorString = "Apogee Sound System Version "
|
|
||||||
"Programmed by Jim Dose\n"
|
|
||||||
"(c) Copyright 1996 James R. Dose. All Rights Reserved.\n";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_SoundCardError :
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_MPU401Error :
|
|
||||||
ErrorString = "Could not detect MPU-401.";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_InvalidCard :
|
|
||||||
ErrorString = "Invalid Music device.";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_MidiError :
|
|
||||||
ErrorString = "Error playing MIDI file.";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_TaskManError :
|
|
||||||
ErrorString = "TaskMan error.";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MUSIC_DPMI_Error :
|
|
||||||
ErrorString = "DPMI Error in MUSIC.";
|
|
||||||
break;
|
|
||||||
|
|
||||||
default :
|
|
||||||
ErrorString = "Unknown Music error code.";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return(ErrorString);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_Init
|
|
||||||
|
|
||||||
Selects which sound device to use.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_Init
|
|
||||||
(
|
|
||||||
int32_t SoundCard,
|
|
||||||
int32_t Address
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
int32_t i;
|
|
||||||
int32_t status;
|
|
||||||
|
|
||||||
status = MUSIC_Ok;
|
|
||||||
|
|
||||||
return(status);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_Shutdown
|
|
||||||
|
|
||||||
Terminates use of sound device.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_Shutdown
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
int32_t status;
|
|
||||||
|
|
||||||
status = MUSIC_Ok;
|
|
||||||
|
|
||||||
|
|
||||||
return(status);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetMaxFMMidiChannel
|
|
||||||
|
|
||||||
Sets the maximum MIDI channel that FM cards respond to.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetMaxFMMidiChannel
|
|
||||||
(
|
|
||||||
int32_t channel
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetVolume
|
|
||||||
|
|
||||||
Sets the volume of music playback.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetVolume
|
|
||||||
(
|
|
||||||
int32_t volume
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetMidiChannelVolume
|
|
||||||
|
|
||||||
Sets the volume of music playback on the specified MIDI channel.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetMidiChannelVolume
|
|
||||||
(
|
|
||||||
int32_t channel,
|
|
||||||
int32_t volume
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_ResetMidiChannelVolumes
|
|
||||||
|
|
||||||
Sets the volume of music playback on all MIDI channels to full volume.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_ResetMidiChannelVolumes
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_GetVolume
|
|
||||||
|
|
||||||
Returns the volume of music playback.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_GetVolume
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
return(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetLoopFlag
|
|
||||||
|
|
||||||
Set whether the music will loop or end when it reaches the end of
|
|
||||||
the song.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetLoopFlag
|
|
||||||
(
|
|
||||||
int32_t loopflag
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SongPlaying
|
|
||||||
|
|
||||||
Returns whether there is a song playing.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_SongPlaying
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
return(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_Continue
|
|
||||||
|
|
||||||
Continues playback of a paused song.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_Continue
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_Pause
|
|
||||||
|
|
||||||
Pauses playback of a song.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_Pause
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_StopSong
|
|
||||||
|
|
||||||
Stops playback of current song.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_StopSong
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
return(MUSIC_Ok);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_PlaySong
|
|
||||||
|
|
||||||
Begins playback of MIDI song.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_PlaySong
|
|
||||||
(
|
|
||||||
uint8_t *song,
|
|
||||||
int32_t loopflag
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
return(MUSIC_Ok);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetContext
|
|
||||||
|
|
||||||
Sets the song context.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetContext
|
|
||||||
(
|
|
||||||
int32_t context
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_GetContext
|
|
||||||
|
|
||||||
Returns the current song context.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_GetContext
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetSongTick
|
|
||||||
|
|
||||||
Sets the position of the song pointer.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetSongTick
|
|
||||||
(
|
|
||||||
uint32_t PositionInTicks
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetSongTime
|
|
||||||
|
|
||||||
Sets the position of the song pointer.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetSongTime
|
|
||||||
(
|
|
||||||
uint32_t milliseconds
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_SetSongPosition
|
|
||||||
|
|
||||||
Sets the position of the song pointer.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_SetSongPosition
|
|
||||||
(
|
|
||||||
int32_t measure,
|
|
||||||
int32_t beat,
|
|
||||||
int32_t tick
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_GetSongPosition
|
|
||||||
|
|
||||||
Returns the position of the song pointer.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_GetSongPosition
|
|
||||||
(
|
|
||||||
songposition *pos
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_GetSongLength
|
|
||||||
|
|
||||||
Returns the length of the song.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_GetSongLength
|
|
||||||
(
|
|
||||||
songposition *pos
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_FadeVolume
|
|
||||||
|
|
||||||
Fades music volume from current level to another over a specified
|
|
||||||
period of time.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_FadeVolume
|
|
||||||
(
|
|
||||||
int32_t tovolume,
|
|
||||||
int32_t milliseconds
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
return(MUSIC_Ok);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_FadeActive
|
|
||||||
|
|
||||||
Returns whether the fade routine is active.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
int32_t MUSIC_FadeActive
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
return(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_StopFade
|
|
||||||
|
|
||||||
Stops fading the music.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_StopFade
|
|
||||||
(
|
|
||||||
void
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_RerouteMidiChannel
|
|
||||||
|
|
||||||
Sets callback function to reroute MIDI commands from specified
|
|
||||||
function.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_RerouteMidiChannel
|
|
||||||
(
|
|
||||||
int32_t channel,
|
|
||||||
int32_t (*function)(int32_t event, int32_t c1, int32_t c2)
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*---------------------------------------------------------------------
|
|
||||||
Function: MUSIC_RegisterTimbreBank
|
|
||||||
|
|
||||||
Halts playback of all sounds.
|
|
||||||
---------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
void MUSIC_RegisterTimbreBank
|
|
||||||
(
|
|
||||||
uint8_t *timbres
|
|
||||||
)
|
|
||||||
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void MUSIC_Update(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ extern int32_t A_PlaySound(uint32_t num,int32_t i);
|
||||||
extern void S_StopSound(int32_t num);
|
extern void S_StopSound(int32_t num);
|
||||||
extern void S_StopEnvSound(int32_t num,int32_t i);
|
extern void S_StopEnvSound(int32_t num,int32_t i);
|
||||||
extern void S_Pan3D(void);
|
extern void S_Pan3D(void);
|
||||||
extern void S_TestSoundCallback(uint32_t num);
|
extern void S_Callback(uint32_t num);
|
||||||
extern void S_ClearSoundLocks(void);
|
extern void S_ClearSoundLocks(void);
|
||||||
extern int32_t A_CallSound(int32_t sn,int32_t whatsprite);
|
extern int32_t A_CallSound(int32_t sn,int32_t whatsprite);
|
||||||
extern int32_t G_CheckActivatorMotion(int32_t lotag);
|
extern int32_t G_CheckActivatorMotion(int32_t lotag);
|
||||||
|
|
|
@ -67,6 +67,12 @@ extern int32_t G_GetVersionFromWebsite(char *buffer);
|
||||||
static int32_t usecwd = 0;
|
static int32_t usecwd = 0;
|
||||||
#endif /* _WIN32 */
|
#endif /* _WIN32 */
|
||||||
|
|
||||||
|
/*
|
||||||
|
this should be lower than the MTU size by at least the size of the UDP and ENet headers
|
||||||
|
or else fragmentation will occur
|
||||||
|
*/
|
||||||
|
#define SYNCPACKETSIZE 1408
|
||||||
|
|
||||||
ENetHost * g_netServer = NULL;
|
ENetHost * g_netServer = NULL;
|
||||||
ENetHost * g_netClient = NULL;
|
ENetHost * g_netClient = NULL;
|
||||||
ENetPeer * g_netClientPeer = NULL;
|
ENetPeer * g_netClientPeer = NULL;
|
||||||
|
@ -318,6 +324,7 @@ void P_SetGamePalette(DukePlayer_t *player, uint8_t *pal, int32_t set)
|
||||||
player->palette = pal;
|
player->palette = pal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// FIXME: this function sucks.
|
||||||
int32_t gametext_z(int32_t small, int32_t starttile, int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t orientation,int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t z)
|
int32_t gametext_z(int32_t small, int32_t starttile, int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t orientation,int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t z)
|
||||||
{
|
{
|
||||||
int32_t ac,newx,oldx=x;
|
int32_t ac,newx,oldx=x;
|
||||||
|
@ -609,7 +616,6 @@ void Net_Connect(const char * srvaddr)
|
||||||
enet_address_set_host(&address, addrstr);
|
enet_address_set_host(&address, addrstr);
|
||||||
address.port = atoi((addrstr = strtok(NULL, ":")) == NULL ? "23513" : addrstr);
|
address.port = atoi((addrstr = strtok(NULL, ":")) == NULL ? "23513" : addrstr);
|
||||||
|
|
||||||
// use 2 channels for easy packet sorting at a lower level than the game later
|
|
||||||
g_netClientPeer = enet_host_connect(g_netClient, &address, CHAN_MAX);
|
g_netClientPeer = enet_host_connect(g_netClient, &address, CHAN_MAX);
|
||||||
|
|
||||||
if (g_netClientPeer == NULL)
|
if (g_netClientPeer == NULL)
|
||||||
|
@ -786,6 +792,7 @@ void Net_SendUserMapName(void)
|
||||||
enet_host_broadcast(g_netServer, CHAN_GAMESTATE, enet_packet_create(packbuf, j, ENET_PACKET_FLAG_RELIABLE));
|
enet_host_broadcast(g_netServer, CHAN_GAMESTATE, enet_packet_create(packbuf, j, ENET_PACKET_FLAG_RELIABLE));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// FIXME: change all of the game starting support code to be fully server controlled
|
||||||
void Net_NewGame(int32_t volume, int32_t level)
|
void Net_NewGame(int32_t volume, int32_t level)
|
||||||
{
|
{
|
||||||
packbuf[0] = PACKET_NEW_GAME;
|
packbuf[0] = PACKET_NEW_GAME;
|
||||||
|
@ -813,18 +820,16 @@ static int32_t spritecrc[MAXSPRITES], lastupdate[MAXSPRITES], sectcrc[MAXSECTORS
|
||||||
static int32_t wallcrc[MAXWALLS], lastwallupdate[MAXWALLS];
|
static int32_t wallcrc[MAXWALLS], lastwallupdate[MAXWALLS];
|
||||||
static int32_t peractorvals[MAXGAMEVARS][MAXSPRITES], perplayervals[MAXGAMEVARS][MAXPLAYERS];
|
static int32_t peractorvals[MAXGAMEVARS][MAXSPRITES], perplayervals[MAXGAMEVARS][MAXPLAYERS];
|
||||||
|
|
||||||
|
// sends a simple crc32 of the current password, verified by the server before the connection can continue
|
||||||
static void Net_SendChallenge(void)
|
static void Net_SendChallenge(void)
|
||||||
{
|
{
|
||||||
int32_t l;
|
int32_t l = 1;
|
||||||
uint32_t crc;
|
uint32_t crc = crc32once((uint8_t *)g_netPassword, Bstrlen(g_netPassword));
|
||||||
|
|
||||||
if (!g_netClientPeer) return;
|
if (!g_netClientPeer) return;
|
||||||
|
|
||||||
crc = crc32once((uint8_t *)g_netPassword, Bstrlen(g_netPassword));
|
|
||||||
|
|
||||||
buf[0] = PACKET_AUTH;
|
buf[0] = PACKET_AUTH;
|
||||||
l = 1;
|
*(uint32_t *)&buf[1] = crc;
|
||||||
*(uint32_t *)&buf[l] = crc;
|
|
||||||
l += sizeof(int32_t);
|
l += sizeof(int32_t);
|
||||||
|
|
||||||
buf[l++] = myconnectindex;
|
buf[l++] = myconnectindex;
|
||||||
|
@ -872,10 +877,12 @@ void P_Disconnected(int32_t i)
|
||||||
}
|
}
|
||||||
|
|
||||||
Bstrcpy(ScriptQuotes[116],buf);
|
Bstrcpy(ScriptQuotes[116],buf);
|
||||||
g_player[myconnectindex].ps->ftq = 116, g_player[myconnectindex].ps->fta = 180;
|
g_player[myconnectindex].ps->ftq = 116;
|
||||||
|
g_player[myconnectindex].ps->fta = 180;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// sync a connecting player up with the current game state
|
||||||
void Net_SyncPlayer(ENetEvent * event)
|
void Net_SyncPlayer(ENetEvent * event)
|
||||||
{
|
{
|
||||||
int32_t i, j;
|
int32_t i, j;
|
||||||
|
@ -886,10 +893,8 @@ void Net_SyncPlayer(ENetEvent * event)
|
||||||
if (!g_player[i].playerquitflag)
|
if (!g_player[i].playerquitflag)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// no slots empty from players quitting, so open a new one
|
// open a new slot if necessary
|
||||||
if (i == -1)
|
event->peer->data = (void *)((intptr_t) (i = (i == -1 ? playerswhenstarted++ : i)));
|
||||||
i = playerswhenstarted++;
|
|
||||||
event->peer->data = (void *) ((intptr_t) i);
|
|
||||||
|
|
||||||
clearbufbyte(&g_player[i].playerquitflag,1,0x01010101);
|
clearbufbyte(&g_player[i].playerquitflag,1,0x01010101);
|
||||||
g_player[i].movefifoend = 1;
|
g_player[i].movefifoend = 1;
|
||||||
|
@ -946,12 +951,17 @@ void Net_SyncPlayer(ENetEvent * event)
|
||||||
|
|
||||||
G_SaveMapState(g_multiMapState);
|
G_SaveMapState(g_multiMapState);
|
||||||
j = qlz_compress((char *)g_multiMapState, buf, sizeof(mapstate_t), state_compress);
|
j = qlz_compress((char *)g_multiMapState, buf, sizeof(mapstate_t), state_compress);
|
||||||
while (j > 1024)
|
|
||||||
|
// all of these packets are SYNCPACKETSIZE
|
||||||
|
while (j >= SYNCPACKETSIZE)
|
||||||
{
|
{
|
||||||
enet_peer_send(event->peer, CHAN_SYNC, enet_packet_create((char *)(buf)+qlz_size_compressed(buf)-j, 1024, ENET_PACKET_FLAG_RELIABLE));
|
enet_peer_send(event->peer, CHAN_SYNC,
|
||||||
j -= 1024;
|
enet_packet_create((char *)(buf)+qlz_size_compressed(buf)-j, SYNCPACKETSIZE, ENET_PACKET_FLAG_RELIABLE));
|
||||||
|
j -= SYNCPACKETSIZE;
|
||||||
}
|
}
|
||||||
enet_peer_send(event->peer, CHAN_SYNC, enet_packet_create((char *)(buf)+qlz_size_compressed(buf)-j, j, ENET_PACKET_FLAG_RELIABLE));
|
// ...except for this one. A non-SYNCPACKETSIZE packet on CHAN_SYNC doubles as the signal that the transfer is done.
|
||||||
|
enet_peer_send(event->peer, CHAN_SYNC,
|
||||||
|
enet_packet_create((char *)(buf)+qlz_size_compressed(buf)-j, j, ENET_PACKET_FLAG_RELIABLE));
|
||||||
Bfree(buf);
|
Bfree(buf);
|
||||||
Bfree(g_multiMapState);
|
Bfree(g_multiMapState);
|
||||||
g_multiMapState = NULL;
|
g_multiMapState = NULL;
|
||||||
|
@ -1231,22 +1241,17 @@ process:
|
||||||
}
|
}
|
||||||
|
|
||||||
Bfree(packbuf);
|
Bfree(packbuf);
|
||||||
// movefifosendplc++;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
g_player[other].playerreadyflag++;
|
|
||||||
return;
|
|
||||||
|
|
||||||
case PACKET_MESSAGE:
|
case PACKET_MESSAGE:
|
||||||
//slaves in M/S mode only send to master
|
Bstrncpy(recbuf, (char *)packbuf+2, packbufleng-2);
|
||||||
Bstrcpy(recbuf,(char *)packbuf+2);
|
|
||||||
recbuf[packbufleng-2] = 0;
|
recbuf[packbufleng-2] = 0;
|
||||||
|
|
||||||
G_AddUserQuote(recbuf);
|
G_AddUserQuote(recbuf);
|
||||||
S_PlaySound(EXITMENUSOUND);
|
S_PlaySound(EXITMENUSOUND);
|
||||||
|
|
||||||
pus = NUMPAGES;
|
pus = pub = NUMPAGES;
|
||||||
pub = NUMPAGES;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1564,8 +1569,7 @@ void Net_ParseClientPacket(ENetEvent * event)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case PACKET_MESSAGE:
|
case PACKET_MESSAGE:
|
||||||
//slaves in M/S mode only send to master
|
Bstrncpy(recbuf, (char *)packbuf+2, packbufleng-2);
|
||||||
Bstrcpy(recbuf,(char *)packbuf+2);
|
|
||||||
recbuf[packbufleng-2] = 0;
|
recbuf[packbufleng-2] = 0;
|
||||||
|
|
||||||
G_AddUserQuote(recbuf);
|
G_AddUserQuote(recbuf);
|
||||||
|
@ -1630,8 +1634,7 @@ void Net_ParseClientPacket(ENetEvent * event)
|
||||||
g_player[other].ps->palookup = g_player[other].pcolor = packbuf[i++];
|
g_player[other].ps->palookup = g_player[other].pcolor = packbuf[i++];
|
||||||
g_player[other].pteam = packbuf[i++];
|
g_player[other].pteam = packbuf[i++];
|
||||||
|
|
||||||
j = i;
|
for (j=i; i-j<10; i++) g_player[other].wchoice[i-j] = packbuf[i];
|
||||||
for (; i-j<10; i++) g_player[other].wchoice[i-j] = packbuf[i];
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1855,7 +1858,7 @@ void Net_GetPackets(void)
|
||||||
event.peer -> data,
|
event.peer -> data,
|
||||||
event.channelID);
|
event.channelID);
|
||||||
|
|
||||||
// mapstate transfer from the server... all packets but the last are exactly 1 kB
|
// mapstate transfer from the server... all packets but the last are SYNCPACKETSIZE
|
||||||
if (event.channelID == CHAN_SYNC)
|
if (event.channelID == CHAN_SYNC)
|
||||||
{
|
{
|
||||||
static int32_t datasiz = 0;
|
static int32_t datasiz = 0;
|
||||||
|
@ -1871,10 +1874,10 @@ void Net_GetPackets(void)
|
||||||
buf = Bcalloc(1, sizeof(mapstate_t)<<1);
|
buf = Bcalloc(1, sizeof(mapstate_t)<<1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (buf && event.packet->dataLength == 1024)
|
if (buf && event.packet->dataLength == SYNCPACKETSIZE)
|
||||||
{
|
{
|
||||||
Bmemcpy((char *)(buf)+datasiz, event.packet->data, event.packet->dataLength);
|
Bmemcpy((char *)(buf)+datasiz, event.packet->data, event.packet->dataLength);
|
||||||
datasiz += 1024;
|
datasiz += SYNCPACKETSIZE;
|
||||||
}
|
}
|
||||||
// last packet of mapstate sequence
|
// last packet of mapstate sequence
|
||||||
else if (buf)
|
else if (buf)
|
||||||
|
@ -2116,7 +2119,8 @@ void Net_UpdateClients(void)
|
||||||
{
|
{
|
||||||
l = crc32once((uint8_t *)&sprite[i], sizeof(spritetype));
|
l = crc32once((uint8_t *)&sprite[i], sizeof(spritetype));
|
||||||
|
|
||||||
if (!lastupdate[i] || spritecrc[i] != l)
|
// only send STAT_MISC sprites at spawn time and let the client handle it from there
|
||||||
|
if (!lastupdate[i] || (spritecrc[i] != l && sprite[i].statnum != STAT_MISC))
|
||||||
{
|
{
|
||||||
int32_t jj = 0;
|
int32_t jj = 0;
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,7 @@ char g_szScriptFileName[BMAX_PATH] = "(none)"; // file we're currently compilin
|
||||||
static char g_szCurrentBlockName[256] = "(none)", g_szLastBlockName[256] = "NULL";
|
static char g_szCurrentBlockName[256] = "(none)", g_szLastBlockName[256] = "NULL";
|
||||||
|
|
||||||
int32_t g_totalLines,g_lineNumber;
|
int32_t g_totalLines,g_lineNumber;
|
||||||
static int32_t g_checkingIfElse,g_processingState;
|
static int32_t g_checkingIfElse, g_processingState, g_lastKeyword = -1;
|
||||||
char g_szBuf[1024];
|
char g_szBuf[1024];
|
||||||
|
|
||||||
intptr_t *g_caseScriptPtr=NULL; // the pointer to the start of the case table in a switch statement
|
intptr_t *g_caseScriptPtr=NULL; // the pointer to the start of the case table in a switch statement
|
||||||
|
@ -1993,7 +1993,7 @@ static int32_t C_CountCaseStatements()
|
||||||
|
|
||||||
static int32_t C_ParseCommand(void)
|
static int32_t C_ParseCommand(void)
|
||||||
{
|
{
|
||||||
int32_t i, j=0, k=0, done, tw;
|
int32_t i, j=0, k=0, done, tw, otw = g_lastKeyword;
|
||||||
char *temptextptr;
|
char *temptextptr;
|
||||||
intptr_t *tempscrptr = NULL;
|
intptr_t *tempscrptr = NULL;
|
||||||
|
|
||||||
|
@ -2015,7 +2015,7 @@ static int32_t C_ParseCommand(void)
|
||||||
//Bsprintf(g_szBuf,"PC(): '%.25s'",textptr);
|
//Bsprintf(g_szBuf,"PC(): '%.25s'",textptr);
|
||||||
//AddLog(g_szBuf);
|
//AddLog(g_szBuf);
|
||||||
}
|
}
|
||||||
tw = C_GetNextKeyword();
|
g_lastKeyword = tw = C_GetNextKeyword();
|
||||||
// Bsprintf(tempbuf,"%s",keyw[tw]);
|
// Bsprintf(tempbuf,"%s",keyw[tw]);
|
||||||
// AddLog(tempbuf);
|
// AddLog(tempbuf);
|
||||||
|
|
||||||
|
@ -4677,8 +4677,7 @@ repeatcase:
|
||||||
//Bsprintf(g_szBuf,"case3: %.12s",textptr);
|
//Bsprintf(g_szBuf,"case3: %.12s",textptr);
|
||||||
//AddLog(g_szBuf);
|
//AddLog(g_szBuf);
|
||||||
|
|
||||||
j = C_GetKeyword();
|
if (C_GetKeyword() == CON_CASE)
|
||||||
if (j == CON_CASE)
|
|
||||||
{
|
{
|
||||||
//AddLog("Found Repeat Case");
|
//AddLog("Found Repeat Case");
|
||||||
C_GetNextKeyword(); // eat 'case'
|
C_GetNextKeyword(); // eat 'case'
|
||||||
|
@ -4691,8 +4690,7 @@ repeatcase:
|
||||||
{
|
{
|
||||||
//Bsprintf(g_szBuf,"case5 '%.25s'",textptr);
|
//Bsprintf(g_szBuf,"case5 '%.25s'",textptr);
|
||||||
//AddLog(g_szBuf);
|
//AddLog(g_szBuf);
|
||||||
j = C_GetKeyword();
|
if (C_GetKeyword() == CON_CASE)
|
||||||
if (j == CON_CASE)
|
|
||||||
{
|
{
|
||||||
//AddLog("Found Repeat Case");
|
//AddLog("Found Repeat Case");
|
||||||
C_GetNextKeyword(); // eat 'case'
|
C_GetNextKeyword(); // eat 'case'
|
||||||
|
@ -5651,6 +5649,13 @@ repeatcase:
|
||||||
case CON_BREAK:
|
case CON_BREAK:
|
||||||
if (g_checkingSwitch)
|
if (g_checkingSwitch)
|
||||||
{
|
{
|
||||||
|
if (otw == CON_BREAK)
|
||||||
|
{
|
||||||
|
C_ReportError(-1);
|
||||||
|
initprintf("%s:%d: error: duplicate `break'.\n",g_szScriptFileName, g_lineNumber);
|
||||||
|
g_numCompilerErrors++;
|
||||||
|
}
|
||||||
|
|
||||||
//Bsprintf(g_szBuf," * (L%d) case Break statement.\n",g_lineNumber);
|
//Bsprintf(g_szBuf," * (L%d) case Break statement.\n",g_lineNumber);
|
||||||
//AddLog(g_szBuf);
|
//AddLog(g_szBuf);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
|
@ -1615,7 +1615,7 @@ skip_check:
|
||||||
insptr++;
|
insptr++;
|
||||||
{
|
{
|
||||||
int32_t i = Gv_GetVarX(*insptr++),
|
int32_t i = Gv_GetVarX(*insptr++),
|
||||||
f=Gv_GetVarX(*insptr++);
|
f=Gv_GetVarX(*insptr++);
|
||||||
int32_t j=Gv_GetVarX(*insptr++);
|
int32_t j=Gv_GetVarX(*insptr++);
|
||||||
if ((i<0 || i>=MAXQUOTES) /* && g_scriptSanityChecks */)
|
if ((i<0 || i>=MAXQUOTES) /* && g_scriptSanityChecks */)
|
||||||
OSD_Printf(CON_ERROR "invalid quote ID %d\n",g_errorLineNum,keyw[g_tw],i);
|
OSD_Printf(CON_ERROR "invalid quote ID %d\n",g_errorLineNum,keyw[g_tw],i);
|
||||||
|
|
|
@ -165,7 +165,7 @@ char szPlayerName[32];
|
||||||
int32_t g_damageCameras,g_freezerSelfDamage=0,g_tripbombLaserMode=0;
|
int32_t g_damageCameras,g_freezerSelfDamage=0,g_tripbombLaserMode=0;
|
||||||
int32_t g_gameQuit = 0,everyothertime;
|
int32_t g_gameQuit = 0,everyothertime;
|
||||||
int32_t g_numFreezeBounces=3,g_rpgBlastRadius,g_pipebombBlastRadius,g_tripbombBlastRadius,
|
int32_t g_numFreezeBounces=3,g_rpgBlastRadius,g_pipebombBlastRadius,g_tripbombBlastRadius,
|
||||||
g_shrinkerBlastRadius,g_morterBlastRadius,g_bouncemineBlastRadius,g_seenineBlastRadius;
|
g_shrinkerBlastRadius,g_morterBlastRadius,g_bouncemineBlastRadius,g_seenineBlastRadius;
|
||||||
DukeStatus_t sbar;
|
DukeStatus_t sbar;
|
||||||
|
|
||||||
int32_t mymaxlag, otherminlag, bufferjitter = 1;
|
int32_t mymaxlag, otherminlag, bufferjitter = 1;
|
||||||
|
|
|
@ -3829,8 +3829,9 @@ cheat_for_port_credits:
|
||||||
else if (function == 2)
|
else if (function == 2)
|
||||||
{
|
{
|
||||||
static char *directions[] =
|
static char *directions[] =
|
||||||
{ "UP", "RIGHT", "DOWN", "LEFT"
|
{
|
||||||
};
|
"UP", "RIGHT", "DOWN", "LEFT"
|
||||||
|
};
|
||||||
if (whichkey < 2*joynumbuttons)
|
if (whichkey < 2*joynumbuttons)
|
||||||
Bsprintf(tempbuf,"TO %s%s", (whichkey&1)?"DOUBLE-CLICKED ":"", getjoyname(1,whichkey>>1));
|
Bsprintf(tempbuf,"TO %s%s", (whichkey&1)?"DOUBLE-CLICKED ":"", getjoyname(1,whichkey>>1));
|
||||||
else
|
else
|
||||||
|
@ -4094,8 +4095,9 @@ cheat_for_port_credits:
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
static char *directions[] =
|
static char *directions[] =
|
||||||
{ "Up", "Right", "Down", "Left"
|
{
|
||||||
};
|
"Up", "Right", "Down", "Left"
|
||||||
|
};
|
||||||
Bsprintf(tempbuf, "Hat %s", directions[(l+m)-2*joynumbuttons]);
|
Bsprintf(tempbuf, "Hat %s", directions[(l+m)-2*joynumbuttons]);
|
||||||
x = ud.config.JoystickFunctions[joynumbuttons + ((l+m)-2*joynumbuttons)][0];
|
x = ud.config.JoystickFunctions[joynumbuttons + ((l+m)-2*joynumbuttons)][0];
|
||||||
}
|
}
|
||||||
|
|
|
@ -418,7 +418,7 @@ static int32_t osdcmd_restartvid(const osdfuncparm_t *parm)
|
||||||
static int32_t osdcmd_vidmode(const osdfuncparm_t *parm)
|
static int32_t osdcmd_vidmode(const osdfuncparm_t *parm)
|
||||||
{
|
{
|
||||||
int32_t newbpp = ud.config.ScreenBPP, newwidth = ud.config.ScreenWidth,
|
int32_t newbpp = ud.config.ScreenBPP, newwidth = ud.config.ScreenWidth,
|
||||||
newheight = ud.config.ScreenHeight, newfs = ud.config.ScreenMode;
|
newheight = ud.config.ScreenHeight, newfs = ud.config.ScreenMode;
|
||||||
if (parm->numparms < 1 || parm->numparms > 4) return OSDCMD_SHOWHELP;
|
if (parm->numparms < 1 || parm->numparms > 4) return OSDCMD_SHOWHELP;
|
||||||
|
|
||||||
switch (parm->numparms)
|
switch (parm->numparms)
|
||||||
|
|
|
@ -3553,7 +3553,7 @@ int16_t WeaponPickupSprites[MAX_WEAPONS] = { KNEE__STATIC, FIRSTGUNSPRITE__STATI
|
||||||
void P_DropWeapon(DukePlayer_t *p)
|
void P_DropWeapon(DukePlayer_t *p)
|
||||||
{
|
{
|
||||||
int32_t snum = sprite[p->i].yvel,
|
int32_t snum = sprite[p->i].yvel,
|
||||||
cw = aplWeaponWorksLike[p->curr_weapon][snum];
|
cw = aplWeaponWorksLike[p->curr_weapon][snum];
|
||||||
|
|
||||||
if (cw < 1 || cw >= MAX_WEAPONS) return;
|
if (cw < 1 || cw >= MAX_WEAPONS) return;
|
||||||
|
|
||||||
|
|
|
@ -1007,7 +1007,7 @@ static uint8_t *writespecdata(const dataspec_t *spec, FILE *fil, uint8_t *dump)
|
||||||
if (fil)
|
if (fil)
|
||||||
{
|
{
|
||||||
if (((sp->flags&DS_CNTMASK)==0 && sp->size*cnt<=(int32_t)savegame_comprthres)
|
if (((sp->flags&DS_CNTMASK)==0 && sp->size*cnt<=(int32_t)savegame_comprthres)
|
||||||
|| (sp->flags&DS_CMP))
|
|| (sp->flags&DS_CMP))
|
||||||
fwrite(ptr, sp->size, cnt, fil);
|
fwrite(ptr, sp->size, cnt, fil);
|
||||||
else
|
else
|
||||||
dfwrite((void *)ptr, sp->size, cnt, fil);
|
dfwrite((void *)ptr, sp->size, cnt, fil);
|
||||||
|
@ -1119,7 +1119,7 @@ static void docmpsd(const void *ptr, void *dump, uint32_t size, uint32_t cnt, ui
|
||||||
uint8_t *retdiff = *diffvar;
|
uint8_t *retdiff = *diffvar;
|
||||||
|
|
||||||
// Hail to the C preprocessor, baby!
|
// Hail to the C preprocessor, baby!
|
||||||
#define CPSINGLEVAL(Datbits) \
|
#define CPSINGLEVAL(Datbits) \
|
||||||
if (VAL(Datbits, ptr) != VAL(Datbits, dump)) \
|
if (VAL(Datbits, ptr) != VAL(Datbits, dump)) \
|
||||||
{ \
|
{ \
|
||||||
VAL(Datbits, retdiff) = VAL(Datbits, dump) = VAL(Datbits, ptr); \
|
VAL(Datbits, retdiff) = VAL(Datbits, dump) = VAL(Datbits, ptr); \
|
||||||
|
@ -1135,7 +1135,7 @@ static void docmpsd(const void *ptr, void *dump, uint32_t size, uint32_t cnt, ui
|
||||||
case 1: CPSINGLEVAL(8); return;
|
case 1: CPSINGLEVAL(8); return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CPELTS(Idxbits, Datbits) do \
|
#define CPELTS(Idxbits, Datbits) do \
|
||||||
{ \
|
{ \
|
||||||
for (i=0; i<nelts; i++) \
|
for (i=0; i<nelts; i++) \
|
||||||
{ \
|
{ \
|
||||||
|
@ -1154,7 +1154,7 @@ static void docmpsd(const void *ptr, void *dump, uint32_t size, uint32_t cnt, ui
|
||||||
retdiff += BYTES(Idxbits); \
|
retdiff += BYTES(Idxbits); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define CPDATA(Datbits) do \
|
#define CPDATA(Datbits) do \
|
||||||
{ \
|
{ \
|
||||||
const UINT(Datbits) *p=ptr; \
|
const UINT(Datbits) *p=ptr; \
|
||||||
UINT(Datbits) *op=dump; \
|
UINT(Datbits) *op=dump; \
|
||||||
|
@ -1179,16 +1179,16 @@ static void docmpsd(const void *ptr, void *dump, uint32_t size, uint32_t cnt, ui
|
||||||
*diffvar = retdiff;
|
*diffvar = retdiff;
|
||||||
return;
|
return;
|
||||||
|
|
||||||
#undef CPELTS
|
#undef CPELTS
|
||||||
#undef CPSINGLEVAL
|
#undef CPSINGLEVAL
|
||||||
#undef CPDATA
|
#undef CPDATA
|
||||||
}
|
}
|
||||||
|
|
||||||
// get the number of elements to be monitored for changes
|
// get the number of elements to be monitored for changes
|
||||||
static int32_t getnumvar(const dataspec_t *spec)
|
static int32_t getnumvar(const dataspec_t *spec)
|
||||||
{
|
{
|
||||||
int32_t n=0;
|
int32_t n=0;
|
||||||
for (;spec->flags!=DS_END; spec++)
|
for (; spec->flags!=DS_END; spec++)
|
||||||
n += (spec->flags&(DS_STRING|DS_CMP|DS_NOCHK|DS_SAVEFN|DS_LOADFN) ? 0 : 1);
|
n += (spec->flags&(DS_STRING|DS_CMP|DS_NOCHK|DS_SAVEFN|DS_LOADFN) ? 0 : 1);
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
@ -1266,7 +1266,7 @@ static int32_t applydiff(const dataspec_t *spec, uint8_t **dumpvar, uint8_t **di
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------
|
// ----------
|
||||||
#define CPSINGLEVAL(Datbits) \
|
#define CPSINGLEVAL(Datbits) \
|
||||||
VAL(Datbits, dumptr) = VAL(Datbits, diffptr); \
|
VAL(Datbits, dumptr) = VAL(Datbits, diffptr); \
|
||||||
diffptr += BYTES(Datbits); \
|
diffptr += BYTES(Datbits); \
|
||||||
dumptr += BYTES(Datbits)
|
dumptr += BYTES(Datbits)
|
||||||
|
@ -1282,7 +1282,7 @@ static int32_t applydiff(const dataspec_t *spec, uint8_t **dumpvar, uint8_t **di
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define CPELTS(Idxbits, Datbits) do \
|
#define CPELTS(Idxbits, Datbits) do \
|
||||||
{ \
|
{ \
|
||||||
UINT(Idxbits) idx; \
|
UINT(Idxbits) idx; \
|
||||||
goto readidx_##Idxbits##_##Datbits; \
|
goto readidx_##Idxbits##_##Datbits; \
|
||||||
|
@ -1296,7 +1296,7 @@ readidx_##Idxbits##_##Datbits: \
|
||||||
} while ((int##Idxbits##_t)idx != -1); \
|
} while ((int##Idxbits##_t)idx != -1); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define CPDATA(Datbits) do \
|
#define CPDATA(Datbits) do \
|
||||||
{ \
|
{ \
|
||||||
uint32_t nelts=(sp->size*cnt)/BYTES(Datbits); \
|
uint32_t nelts=(sp->size*cnt)/BYTES(Datbits); \
|
||||||
if (nelts>65536) \
|
if (nelts>65536) \
|
||||||
|
@ -1318,9 +1318,9 @@ readidx_##Idxbits##_##Datbits: \
|
||||||
dumptr += sp->size*cnt;
|
dumptr += sp->size*cnt;
|
||||||
// ----------
|
// ----------
|
||||||
|
|
||||||
#undef CPELTS
|
#undef CPELTS
|
||||||
#undef CPSINGLEVAL
|
#undef CPSINGLEVAL
|
||||||
#undef CPDATA
|
#undef CPDATA
|
||||||
}
|
}
|
||||||
|
|
||||||
*diffvar = diffptr;
|
*diffvar = diffptr;
|
||||||
|
@ -1383,8 +1383,8 @@ static void sv_restload();
|
||||||
static uint8_t savegame_bitmap[MAXSPRITES>>3][3];
|
static uint8_t savegame_bitmap[MAXSPRITES>>3][3];
|
||||||
static uint32_t savegame_bitptrsize;
|
static uint32_t savegame_bitptrsize;
|
||||||
static uint8_t savegame_quotedef[MAXQUOTES>>3];
|
static uint8_t savegame_quotedef[MAXQUOTES>>3];
|
||||||
static char (*savegame_quotes)[MAXQUOTELEN];
|
static char(*savegame_quotes)[MAXQUOTELEN];
|
||||||
static char (*savegame_quoteredefs)[MAXQUOTELEN];
|
static char(*savegame_quoteredefs)[MAXQUOTELEN];
|
||||||
static uint8_t savegame_restdata[SVARDATALEN];
|
static uint8_t savegame_restdata[SVARDATALEN];
|
||||||
|
|
||||||
static const dataspec_t svgm_udnetw[] =
|
static const dataspec_t svgm_udnetw[] =
|
||||||
|
@ -1776,16 +1776,16 @@ uint32_t sv_writediff(FILE *fil)
|
||||||
int32_t sv_readdiff(int32_t fil)
|
int32_t sv_readdiff(int32_t fil)
|
||||||
{
|
{
|
||||||
uint8_t *p=svsnapshot, *d=svdiff, i=0; //, tbuf[4];
|
uint8_t *p=svsnapshot, *d=svdiff, i=0; //, tbuf[4];
|
||||||
int32_t diffsiz;
|
int32_t diffsiz;
|
||||||
|
|
||||||
#if 0 // handled by the caller
|
#if 0 // handled by the caller
|
||||||
if (kread(fil, tbuf, 4)!=4)
|
if (kread(fil, tbuf, 4)!=4)
|
||||||
return -1;
|
return -1;
|
||||||
if (Bmemcmp(tbuf, "dIfF", 4))
|
if (Bmemcmp(tbuf, "dIfF", 4))
|
||||||
return 4;
|
return 4;
|
||||||
#endif
|
#endif
|
||||||
if (kread(fil, &diffsiz, sizeof(uint32_t))!=sizeof(uint32_t))
|
if (kread(fil, &diffsiz, sizeof(uint32_t))!=sizeof(uint32_t))
|
||||||
return -1;
|
return -1;
|
||||||
if (savegame_diffcompress)
|
if (savegame_diffcompress)
|
||||||
{
|
{
|
||||||
if (kdfread(svdiff, 1, diffsiz, fil) != diffsiz) // cnt and sz swapped
|
if (kdfread(svdiff, 1, diffsiz, fil) != diffsiz) // cnt and sz swapped
|
||||||
|
@ -1797,20 +1797,20 @@ int32_t sv_readdiff(int32_t fil)
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (applydiff(svgm_udnetw, &p, &d)) return -3;
|
if (applydiff(svgm_udnetw, &p, &d)) return -3;
|
||||||
if (applydiff(svgm_secwsp, &p, &d)) return -4;
|
if (applydiff(svgm_secwsp, &p, &d)) return -4;
|
||||||
if (applydiff(svgm_script, &p, &d)) return -5;
|
if (applydiff(svgm_script, &p, &d)) return -5;
|
||||||
if (applydiff(svgm_anmisc, &p, &d)) return -6;
|
if (applydiff(svgm_anmisc, &p, &d)) return -6;
|
||||||
if (applydiff(svgm_vars, &p, &d)) return -7;
|
if (applydiff(svgm_vars, &p, &d)) return -7;
|
||||||
|
|
||||||
if (p!=svsnapshot+svsnapsiz)
|
if (p!=svsnapshot+svsnapsiz)
|
||||||
i|=1;
|
i|=1;
|
||||||
if (d!=svdiff+diffsiz)
|
if (d!=svdiff+diffsiz)
|
||||||
i|=2;
|
i|=2;
|
||||||
if (i)
|
if (i)
|
||||||
OSD_Printf("sv_readdiff: p=%p, svsnapshot+svsnapsiz=%p; d=%p, svdiff+diffsiz=%p",
|
OSD_Printf("sv_readdiff: p=%p, svsnapshot+svsnapsiz=%p; d=%p, svdiff+diffsiz=%p",
|
||||||
p, svsnapshot+svsnapsiz, d, svdiff+diffsiz);
|
p, svsnapshot+svsnapsiz, d, svdiff+diffsiz);
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
// SVGM data description
|
// SVGM data description
|
||||||
|
@ -1913,8 +1913,8 @@ static void sv_postactordata()
|
||||||
intptr_t j=(intptr_t)&script[0];
|
intptr_t j=(intptr_t)&script[0];
|
||||||
|
|
||||||
#if POLYMER
|
#if POLYMER
|
||||||
if (getrendermode() == 4)
|
if (getrendermode() == 4)
|
||||||
polymer_resetlights();
|
polymer_resetlights();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (i=0; i<MAXSPRITES; i++)
|
for (i=0; i<MAXSPRITES; i++)
|
||||||
|
@ -2005,7 +2005,7 @@ static void sv_restsave()
|
||||||
|
|
||||||
Bmemset(&dummy_ps, 0, sizeof(DukePlayer_t));
|
Bmemset(&dummy_ps, 0, sizeof(DukePlayer_t));
|
||||||
|
|
||||||
#define CPDAT(ptr,sz) Bmemcpy(mem, ptr, sz), mem+=sz
|
#define CPDAT(ptr,sz) Bmemcpy(mem, ptr, sz), mem+=sz
|
||||||
for (i=0; i<MAXPLAYERS; i++)
|
for (i=0; i<MAXPLAYERS; i++)
|
||||||
{
|
{
|
||||||
CPDAT(g_player[i].user_name, 32);
|
CPDAT(g_player[i].user_name, 32);
|
||||||
|
@ -2026,7 +2026,7 @@ static void sv_restsave()
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
Bmemset(mem, 0, (savegame_restdata+SVARDATALEN)-mem);
|
Bmemset(mem, 0, (savegame_restdata+SVARDATALEN)-mem);
|
||||||
#undef CPDAT
|
#undef CPDAT
|
||||||
}
|
}
|
||||||
static void sv_restload()
|
static void sv_restload()
|
||||||
{
|
{
|
||||||
|
@ -2034,7 +2034,7 @@ static void sv_restload()
|
||||||
uint8_t *mem = savegame_restdata;
|
uint8_t *mem = savegame_restdata;
|
||||||
DukePlayer_t dummy_ps;
|
DukePlayer_t dummy_ps;
|
||||||
|
|
||||||
#define CPDAT(ptr,sz) Bmemcpy(ptr, mem, sz), mem+=sz
|
#define CPDAT(ptr,sz) Bmemcpy(ptr, mem, sz), mem+=sz
|
||||||
for (i=0; i<MAXPLAYERS; i++)
|
for (i=0; i<MAXPLAYERS; i++)
|
||||||
{
|
{
|
||||||
CPDAT(g_player[i].user_name, 32);
|
CPDAT(g_player[i].user_name, 32);
|
||||||
|
@ -2051,7 +2051,7 @@ static void sv_restload()
|
||||||
for (i=0; i<lightcount; i++)
|
for (i=0; i<lightcount; i++)
|
||||||
CPDAT(&prlights[i], sizeof(_prlight));
|
CPDAT(&prlights[i], sizeof(_prlight));
|
||||||
#endif
|
#endif
|
||||||
#undef CPDAT
|
#undef CPDAT
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SAVEWR(ptr, sz, cnt) do { if (fil) dfwrite(ptr,sz,cnt,fil); } while (0)
|
#define SAVEWR(ptr, sz, cnt) do { if (fil) dfwrite(ptr,sz,cnt,fil); } while (0)
|
||||||
|
@ -2123,8 +2123,7 @@ static int32_t doloadplayer2(int32_t spot, int32_t fil, uint8_t **memptr)
|
||||||
{
|
{
|
||||||
if (LOADRDU(&tbuf, 19, 1)) return -3;
|
if (LOADRDU(&tbuf, 19, 1)) return -3;
|
||||||
}
|
}
|
||||||
else
|
else if (LOADRDU(&ud.savegame[spot][0], 19, 1)) return -3;
|
||||||
if (LOADRDU(&ud.savegame[spot][0], 19, 1)) return -3;
|
|
||||||
|
|
||||||
if (LOADRDU(tbuf, 1, 1)) return -3;
|
if (LOADRDU(tbuf, 1, 1)) return -3;
|
||||||
if (tbuf[0])
|
if (tbuf[0])
|
||||||
|
@ -2282,7 +2281,8 @@ static void postloadplayer2()
|
||||||
G_ResetTimers();
|
G_ResetTimers();
|
||||||
|
|
||||||
#ifdef POLYMER
|
#ifdef POLYMER
|
||||||
if (getrendermode() == 4) {
|
if (getrendermode() == 4)
|
||||||
|
{
|
||||||
polymer_loadboard();
|
polymer_loadboard();
|
||||||
polymer_resetlights();
|
polymer_resetlights();
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,7 +78,7 @@ void S_SoundStartup(void)
|
||||||
|
|
||||||
FX_SetVolume(ud.config.FXVolume);
|
FX_SetVolume(ud.config.FXVolume);
|
||||||
FX_SetReverseStereo(ud.config.ReverseStereo);
|
FX_SetReverseStereo(ud.config.ReverseStereo);
|
||||||
status = FX_SetCallBack(S_TestSoundCallback);
|
status = FX_SetCallBack(S_Callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -562,26 +562,34 @@ int32_t S_PlaySound3D(int32_t num, int32_t i, const vec3_t *pos)
|
||||||
while (l < MAXSOUNDINSTANCES && g_sounds[num].SoundOwner[l].voice > 0)
|
while (l < MAXSOUNDINSTANCES && g_sounds[num].SoundOwner[l].voice > 0)
|
||||||
l++;
|
l++;
|
||||||
|
|
||||||
if (g_sounds[num].m&1)
|
if (l < MAXSOUNDINSTANCES)
|
||||||
{
|
{
|
||||||
if (g_sounds[num].num > 0) return -1;
|
if (g_sounds[num].m&1)
|
||||||
|
{
|
||||||
|
if (g_sounds[num].num > 0) return -1;
|
||||||
|
|
||||||
voice = FX_PlayLoopedAuto(g_sounds[num].ptr, g_sounds[num].soundsiz, 0, -1,
|
voice = FX_PlayLoopedAuto(g_sounds[num].ptr, g_sounds[num].soundsiz, 0, -1,
|
||||||
pitch,sndist>>6,sndist>>6,0,g_sounds[num].pr,(num * MAXSOUNDINSTANCES) + l);
|
pitch,sndist>>6,sndist>>6,0,g_sounds[num].pr,(num * MAXSOUNDINSTANCES) + l);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
voice = FX_PlayAuto3D(g_sounds[ num ].ptr, g_sounds[num].soundsiz, pitch,sndang>>4,sndist>>6, g_sounds[num].pr,
|
||||||
|
(num * MAXSOUNDINSTANCES) + l);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (voice >= FX_Ok)
|
||||||
|
{
|
||||||
|
g_sounds[num].SoundOwner[l].i = i;
|
||||||
|
g_sounds[num].SoundOwner[l].voice = voice;
|
||||||
|
g_sounds[num].num++;
|
||||||
|
}
|
||||||
|
else g_soundlocks[num]--;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
voice = FX_PlayAuto3D(g_sounds[ num ].ptr, g_sounds[num].soundsiz, pitch,sndang>>4,sndist>>6, g_sounds[num].pr,
|
g_soundlocks[num]--;
|
||||||
(num * MAXSOUNDINSTANCES) + l);
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (voice >= FX_Ok)
|
|
||||||
{
|
|
||||||
g_sounds[num].SoundOwner[l].i = i;
|
|
||||||
g_sounds[num].SoundOwner[l].voice = voice;
|
|
||||||
g_sounds[num].num++;
|
|
||||||
}
|
|
||||||
else g_soundlocks[num]--;
|
|
||||||
}
|
}
|
||||||
return (voice);
|
return (voice);
|
||||||
}
|
}
|
||||||
|
@ -655,45 +663,37 @@ int32_t A_PlaySound(uint32_t num, int32_t i)
|
||||||
|
|
||||||
void S_StopSound(int32_t num)
|
void S_StopSound(int32_t num)
|
||||||
{
|
{
|
||||||
if (num >= 0 && num < MAXSOUNDS)
|
if (num >= 0 && num < MAXSOUNDS && g_sounds[num].num > 0)
|
||||||
{
|
{
|
||||||
if (g_sounds[num].num > 0)
|
int32_t j=MAXSOUNDINSTANCES-1;
|
||||||
{
|
|
||||||
int32_t j=MAXSOUNDINSTANCES-1;
|
|
||||||
|
|
||||||
for (; j>=0; j--)
|
for (; j>=0; j--)
|
||||||
|
{
|
||||||
|
if (g_sounds[num].SoundOwner[j].voice)
|
||||||
{
|
{
|
||||||
if (g_sounds[num].SoundOwner[j].voice)
|
FX_StopSound(g_sounds[num].SoundOwner[j].voice);
|
||||||
{
|
// g_sounds[num].SoundOwner[j].voice = 0;
|
||||||
FX_StopSound(g_sounds[num].SoundOwner[j].voice);
|
|
||||||
g_sounds[num].SoundOwner[j].voice = 0;
|
|
||||||
}
|
|
||||||
// S_TestSoundCallback(num);
|
|
||||||
}
|
}
|
||||||
|
// S_Callback(num);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void S_StopEnvSound(int32_t num,int32_t i)
|
void S_StopEnvSound(int32_t num,int32_t i)
|
||||||
{
|
{
|
||||||
if (num >= 0 && num < MAXSOUNDS)
|
if (num >= 0 && num < MAXSOUNDS && g_sounds[num].num > 0)
|
||||||
{
|
{
|
||||||
if (g_sounds[num].num > 0)
|
int32_t j=MAXSOUNDINSTANCES-1;
|
||||||
{
|
|
||||||
int32_t j=MAXSOUNDINSTANCES-1;
|
|
||||||
|
|
||||||
for (; j>=0; j--)
|
for (; j>=0; j--)
|
||||||
|
{
|
||||||
|
if (g_sounds[num].SoundOwner[j].i == i && g_sounds[num].SoundOwner[j].voice)
|
||||||
{
|
{
|
||||||
if (g_sounds[num].SoundOwner[j].i == i)
|
// OSD_Printf("stopping sound %d index %d spr %d\n",num,j,i);
|
||||||
{
|
FX_StopSound(g_sounds[num].SoundOwner[j].voice);
|
||||||
if (g_sounds[num].SoundOwner[j].voice)
|
// g_sounds[num].SoundOwner[j].voice = 0;
|
||||||
{
|
|
||||||
FX_StopSound(g_sounds[num].SoundOwner[j].voice);
|
|
||||||
g_sounds[num].SoundOwner[j].voice = 0;
|
|
||||||
}
|
|
||||||
// S_TestSoundCallback(num);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
// S_Callback(num);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -730,7 +730,7 @@ void S_Pan3D(void)
|
||||||
if (i < 0 || i >= MAXSPRITES || g_sounds[j].SoundOwner[k].voice < 1)
|
if (i < 0 || i >= MAXSPRITES || g_sounds[j].SoundOwner[k].voice < 1)
|
||||||
{
|
{
|
||||||
// OSD_Printf(OSD_ERROR "S_Pan3D(): INTERNAL ERROR: invalid id %d!\n",i);
|
// OSD_Printf(OSD_ERROR "S_Pan3D(): INTERNAL ERROR: invalid id %d!\n",i);
|
||||||
k--;
|
// k--;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -788,7 +788,7 @@ void S_Pan3D(void)
|
||||||
while (j--);
|
while (j--);
|
||||||
}
|
}
|
||||||
|
|
||||||
void S_TestSoundCallback(uint32_t num)
|
void S_Callback(uint32_t num)
|
||||||
{
|
{
|
||||||
if ((int32_t)num == MUSIC_ID)
|
if ((int32_t)num == MUSIC_ID)
|
||||||
return;
|
return;
|
||||||
|
@ -809,9 +809,11 @@ void S_TestSoundCallback(uint32_t num)
|
||||||
{
|
{
|
||||||
int32_t i = g_sounds[num].SoundOwner[j].i;
|
int32_t i = g_sounds[num].SoundOwner[j].i;
|
||||||
|
|
||||||
// OSD_Printf("removing sound %d index %d from spr %d\n",num,j,i);
|
|
||||||
if (sprite[i].picnum == MUSICANDSFX && sector[sprite[i].sectnum].lotag < 3 && sprite[i].lotag < 999)
|
if (sprite[i].picnum == MUSICANDSFX && sector[sprite[i].sectnum].lotag < 3 && sprite[i].lotag < 999)
|
||||||
|
{
|
||||||
|
// OSD_Printf("removing sound %d index %d from spr %d\n",num,j,i);
|
||||||
ActorExtra[i].temp_data[0] = 0;
|
ActorExtra[i].temp_data[0] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
g_sounds[num].SoundOwner[j].i = -1;
|
g_sounds[num].SoundOwner[j].i = -1;
|
||||||
g_sounds[num].SoundOwner[j].voice = 0;
|
g_sounds[num].SoundOwner[j].voice = 0;
|
||||||
|
|
|
@ -55,7 +55,7 @@ int32_t backflag,g_numEnvSoundsPlaying;
|
||||||
|
|
||||||
void MUSIC_Update(void) {} // needed when linking
|
void MUSIC_Update(void) {} // needed when linking
|
||||||
|
|
||||||
void S_TestSoundCallback(uint32_t);
|
void S_Callback(uint32_t);
|
||||||
extern void initprintf(const char *f, ...);
|
extern void initprintf(const char *f, ...);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -91,7 +91,7 @@ int32_t S_SoundStartup(void)
|
||||||
{
|
{
|
||||||
FX_SetVolume(FXVolume);
|
FX_SetVolume(FXVolume);
|
||||||
FX_SetReverseStereo(ReverseStereo);
|
FX_SetReverseStereo(ReverseStereo);
|
||||||
status = FX_SetCallBack(S_TestSoundCallback);
|
status = FX_SetCallBack(S_Callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status != FX_Ok)
|
if (status != FX_Ok)
|
||||||
|
@ -360,7 +360,7 @@ void S_StopSound(int32_t num)
|
||||||
if (g_sounds[num].num > 0)
|
if (g_sounds[num].num > 0)
|
||||||
{
|
{
|
||||||
FX_StopSound(g_sounds[num].SoundOwner[g_sounds[num].num-1].voice);
|
FX_StopSound(g_sounds[num].SoundOwner[g_sounds[num].num-1].voice);
|
||||||
S_TestSoundCallback(num);
|
S_Callback(num);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -444,7 +444,7 @@ void S_Pan3D(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void S_TestSoundCallback(uint32_t num)
|
void S_Callback(uint32_t num)
|
||||||
{
|
{
|
||||||
int32_t i,j,k;
|
int32_t i,j,k;
|
||||||
|
|
||||||
|
|
|
@ -1,75 +0,0 @@
|
||||||
// this is a wrapper to launch EDuke32 properly from Dukester X 1.5
|
|
||||||
// gcc -o duke3d_w32.exe wrapper.c
|
|
||||||
|
|
||||||
#include <windows.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#define ISWS(x) ((x == ' ') || (x == '\t') || (x == '\r') || (x == '\n'))
|
|
||||||
|
|
||||||
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInst, LPSTR lpCmdLine, int nCmdShow)
|
|
||||||
{
|
|
||||||
int i=0,j=0;
|
|
||||||
char CmdLine[1024], sCmdLine[1024], szFileName[255];
|
|
||||||
LPTSTR szCmdLine;
|
|
||||||
|
|
||||||
FILE * fp=fopen("wrapper.log","w");
|
|
||||||
STARTUPINFO si;
|
|
||||||
PROCESS_INFORMATION pi;
|
|
||||||
|
|
||||||
UNREFERENCED_PARAMETER(hInstance);
|
|
||||||
UNREFERENCED_PARAMETER(hPrevInst);
|
|
||||||
UNREFERENCED_PARAMETER(nCmdShow);
|
|
||||||
|
|
||||||
strcpy(sCmdLine,lpCmdLine);
|
|
||||||
szFileName[0] = '\0';
|
|
||||||
|
|
||||||
while (sCmdLine[i] == ' ') i++;
|
|
||||||
while (i < (signed)strlen(sCmdLine))
|
|
||||||
{
|
|
||||||
if (sCmdLine[i] == '-' && sCmdLine[i+1] == 'n' && sCmdLine[i+2] == 'e' && sCmdLine[i+3] == 't')
|
|
||||||
{
|
|
||||||
CmdLine[i-1] = '\0';
|
|
||||||
i += 5;
|
|
||||||
while (sCmdLine[i] != ' ' && i < (signed)strlen(sCmdLine))
|
|
||||||
{
|
|
||||||
szFileName[j] = sCmdLine[i];
|
|
||||||
j++,i++;
|
|
||||||
}
|
|
||||||
szFileName[j] = '\0';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else CmdLine[i] = sCmdLine[i];
|
|
||||||
i++;
|
|
||||||
CmdLine[i] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (szFileName[0] != '\0' && CmdLine[0] != '\0') Bsprintf(sCmdLine,"eduke32.exe %s -rmnet %s",CmdLine,szFileName);
|
|
||||||
else if (CmdLine[0] != '\0') Bsprintf(sCmdLine,"eduke32.exe %s",CmdLine);
|
|
||||||
else Bsprintf(sCmdLine,"eduke32.exe");
|
|
||||||
|
|
||||||
szCmdLine = sCmdLine;
|
|
||||||
|
|
||||||
fprintf(fp,"EDuke32 wrapper for Dukester X v0.02\n");
|
|
||||||
fprintf(fp,"Copyright (c) 2006 EDuke32 team\n\n");
|
|
||||||
fprintf(fp,"Args passed to wrapper: %s\n",lpCmdLine);
|
|
||||||
fprintf(fp,"Final command line: %s",szCmdLine);
|
|
||||||
|
|
||||||
fclose(fp);
|
|
||||||
|
|
||||||
ZeroMemory(&si,sizeof(si));
|
|
||||||
ZeroMemory(&pi,sizeof(pi));
|
|
||||||
si.cb = sizeof(si);
|
|
||||||
|
|
||||||
printf("Launching EDuke32...\n\nPlease leave this window open for the entire duration of your game.");
|
|
||||||
|
|
||||||
if (!CreateProcess(NULL,szCmdLine,NULL,NULL,0,0,NULL,NULL,&si,&pi))
|
|
||||||
{
|
|
||||||
MessageBox(0,"Failed to start eduke32.exe.", "Failure starting game", MB_OK|MB_ICONSTOP);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else WaitForSingleObject(pi.hProcess,INFINITE);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue