mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-18 15:32:33 +00:00
Remove SRB2 Music Player
This thing is ancient history and also depends on FMOD.
This commit is contained in:
parent
955259d5c1
commit
2ff3035746
12 changed files with 0 additions and 1404 deletions
|
@ -1,44 +0,0 @@
|
|||
# Makfile of SRB2MP
|
||||
|
||||
CFLAGS +=-Wall -mms-bitfields -fno-exceptions
|
||||
LDFLAGS +=-mwindows -lfmod
|
||||
WINDRESFLAGS=
|
||||
|
||||
SRC=lump.c SRB2MP.c
|
||||
|
||||
ifdef DEBUGMODE
|
||||
CFLAGS +=-g -D_DEBUG
|
||||
LDFLAGS +=-g
|
||||
else
|
||||
CFLAGS :=-Os -s $(CFLAGS)
|
||||
LDFLAGS :=-s $(LDFLAGS)
|
||||
endif
|
||||
|
||||
OBJ=$(SRC:.c=.o) # replaces the .c from SRC with .o
|
||||
EXTRAOBJ=Script1.res
|
||||
EXE=SRB2MP.exe
|
||||
|
||||
ifdef PREFIX
|
||||
CC=$(PREFIX)-gcc
|
||||
WINDRES ?=$(PREFIX)-windres
|
||||
endif
|
||||
|
||||
WINDRES ?=windres
|
||||
|
||||
RM=rm
|
||||
|
||||
%.o: %.c StdAfx.h lump.h resource.h
|
||||
$(CC) $(CFLAGS) -o $@ -c $<
|
||||
|
||||
%.res: %.rc resource.h
|
||||
$(WINDRES) -i $< -O rc $(WINDRESFLAGS) -o $@ -O coff
|
||||
|
||||
.PHONY : all # .PHONY ignores files named all
|
||||
all: $(EXE) # all is dependent on $(EXE) to be complete
|
||||
|
||||
$(EXE): $(OBJ) $(EXTRAOBJ) # $(EXE) is dependent on all of the files in $(OBJ) to exist
|
||||
$(CC) $(OBJ) $(EXTRAOBJ) $(LDFLAGS) -o $@
|
||||
|
||||
.PHONY : clean # .PHONY ignores files named clean
|
||||
clean:
|
||||
-$(RM) $(OBJ) $(EXTRAOBJ)
|
|
@ -1,464 +0,0 @@
|
|||
// SRB2MP.cpp : Defines the entry point for the application.
|
||||
//
|
||||
|
||||
#include "StdAfx.h"
|
||||
#include "lump.h"
|
||||
|
||||
#define APPTITLE "SRB2 Music Player"
|
||||
#define APPVERSION "v0.1"
|
||||
#define APPAUTHOR "SSNTails"
|
||||
#define APPCOMPANY "Sonic Team Junior"
|
||||
|
||||
static FSOUND_STREAM *fmus = NULL;
|
||||
static int fsoundchannel = -1;
|
||||
static FMUSIC_MODULE *mod = NULL;
|
||||
static struct wadfile* wfptr = NULL;
|
||||
|
||||
static inline VOID M_SetVolume(int volume)
|
||||
{
|
||||
if (mod && FMUSIC_GetType(mod) != FMUSIC_TYPE_NONE)
|
||||
FMUSIC_SetMasterVolume(mod, volume);
|
||||
if (fsoundchannel != -1)
|
||||
FSOUND_SetVolume(fsoundchannel, volume);
|
||||
}
|
||||
|
||||
static inline BOOL M_InitMusic(VOID)
|
||||
{
|
||||
if (FSOUND_GetVersion() < FMOD_VERSION)
|
||||
{
|
||||
printf("Error : You are using the wrong DLL version!\nYou should be using FMOD %.02f\n", FMOD_VERSION);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
#ifdef _DEBUG
|
||||
FSOUND_SetOutput(FSOUND_OUTPUT_WINMM);
|
||||
#endif
|
||||
|
||||
if (!FSOUND_Init(44100, 1, FSOUND_INIT_GLOBALFOCUS))
|
||||
{
|
||||
printf("%s\n", FMOD_ErrorString(FSOUND_GetError()));
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static inline VOID M_FreeMusic(VOID)
|
||||
{
|
||||
if (mod)
|
||||
{
|
||||
FMUSIC_StopSong(mod);
|
||||
FMUSIC_FreeSong(mod);
|
||||
mod = NULL;
|
||||
}
|
||||
if (fmus)
|
||||
{
|
||||
FSOUND_Stream_Stop(fmus);
|
||||
FSOUND_Stream_Close(fmus);
|
||||
fmus = NULL;
|
||||
fsoundchannel = -1;
|
||||
}
|
||||
}
|
||||
|
||||
static inline VOID M_ShutdownMusic(VOID)
|
||||
{
|
||||
M_FreeMusic();
|
||||
FSOUND_Close();
|
||||
//remove(musicfile); // Delete the temp file
|
||||
}
|
||||
|
||||
static inline VOID M_PauseMusic(VOID)
|
||||
{
|
||||
if (mod && !FMUSIC_GetPaused(mod))
|
||||
FMUSIC_SetPaused(mod, TRUE);
|
||||
if (fsoundchannel != -1 && FSOUND_IsPlaying(fsoundchannel))
|
||||
FSOUND_SetPaused(fsoundchannel, TRUE);
|
||||
}
|
||||
|
||||
static inline VOID M_ResumeMusic(VOID)
|
||||
{
|
||||
if (mod && FMUSIC_GetPaused(mod))
|
||||
FMUSIC_SetPaused(mod, FALSE);
|
||||
if (fsoundchannel != -1 && FSOUND_GetPaused(fsoundchannel))
|
||||
FSOUND_SetPaused(fsoundchannel, FALSE);
|
||||
}
|
||||
|
||||
static inline VOID M_StopMusic(VOID)
|
||||
{
|
||||
if (mod)
|
||||
FMUSIC_StopSong(mod);
|
||||
if (fsoundchannel != -1 && fmus && FSOUND_IsPlaying(fsoundchannel))
|
||||
FSOUND_Stream_Stop(fmus);
|
||||
}
|
||||
|
||||
static inline VOID M_StartFMODSong(LPVOID data, int len, int looping, HWND hDlg)
|
||||
{
|
||||
const int loops = FSOUND_LOOP_NORMAL|FSOUND_LOADMEMORY;
|
||||
const int nloop = FSOUND_LOADMEMORY;
|
||||
M_FreeMusic();
|
||||
|
||||
if (looping)
|
||||
mod = FMUSIC_LoadSongEx(data, 0, len, loops, NULL, 0);
|
||||
else
|
||||
mod = FMUSIC_LoadSongEx(data, 0, len, nloop, NULL, 0);
|
||||
|
||||
if (mod)
|
||||
{
|
||||
FMUSIC_SetLooping(mod, (signed char)looping);
|
||||
FMUSIC_SetPanSeperation(mod, 0.0f);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (looping)
|
||||
fmus = FSOUND_Stream_Open(data, loops, 0, len);
|
||||
else
|
||||
fmus = FSOUND_Stream_Open(data, nloop, 0, len);
|
||||
}
|
||||
|
||||
if (!fmus && !mod)
|
||||
{
|
||||
MessageBoxA(hDlg, FMOD_ErrorString(FSOUND_GetError()), "Error", MB_OK|MB_APPLMODAL);
|
||||
return;
|
||||
}
|
||||
|
||||
// Scan the OGG for the COMMENT= field for a custom loop point
|
||||
if (looping && fmus)
|
||||
{
|
||||
const BYTE *origpos, *dataum = data;
|
||||
size_t scan, size = len;
|
||||
|
||||
CHAR buffer[512];
|
||||
BOOL titlefound = FALSE, artistfound = FALSE;
|
||||
|
||||
unsigned int loopstart = 0;
|
||||
|
||||
origpos = dataum;
|
||||
|
||||
for(scan = 0; scan < size; scan++)
|
||||
{
|
||||
if (!titlefound)
|
||||
{
|
||||
if (*dataum++ == 'T')
|
||||
if (*dataum++ == 'I')
|
||||
if (*dataum++ == 'T')
|
||||
if (*dataum++ == 'L')
|
||||
if (*dataum++ == 'E')
|
||||
if (*dataum++ == '=')
|
||||
{
|
||||
size_t titlecount = 0;
|
||||
CHAR title[256];
|
||||
BYTE length = *(dataum-10) - 6;
|
||||
|
||||
while(titlecount < length)
|
||||
title[titlecount++] = *dataum++;
|
||||
|
||||
title[titlecount] = '\0';
|
||||
|
||||
sprintf(buffer, "Title: %s", title);
|
||||
|
||||
SendMessage(GetDlgItem(hDlg, IDC_TITLE), WM_SETTEXT, 0, (LPARAM)(LPCSTR)buffer);
|
||||
|
||||
titlefound = TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
dataum = origpos;
|
||||
|
||||
for(scan = 0; scan < size; scan++)
|
||||
{
|
||||
if (!artistfound)
|
||||
{
|
||||
if (*dataum++ == 'A')
|
||||
if (*dataum++ == 'R')
|
||||
if (*dataum++ == 'T')
|
||||
if (*dataum++ == 'I')
|
||||
if (*dataum++ == 'S')
|
||||
if (*dataum++ == 'T')
|
||||
if (*dataum++ == '=')
|
||||
{
|
||||
size_t artistcount = 0;
|
||||
CHAR artist[256];
|
||||
BYTE length = *(dataum-11) - 7;
|
||||
|
||||
while(artistcount < length)
|
||||
artist[artistcount++] = *dataum++;
|
||||
|
||||
artist[artistcount] = '\0';
|
||||
|
||||
sprintf(buffer, "By: %s", artist);
|
||||
|
||||
SendMessage(GetDlgItem(hDlg, IDC_ARTIST), WM_SETTEXT, 0, (LPARAM)(LPCSTR)buffer);
|
||||
|
||||
artistfound = TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
dataum = origpos;
|
||||
|
||||
for(scan = 0; scan < size; scan++)
|
||||
{
|
||||
if (*dataum++ == 'C'){
|
||||
if (*dataum++ == 'O'){
|
||||
if (*dataum++ == 'M'){
|
||||
if (*dataum++ == 'M'){
|
||||
if (*dataum++ == 'E'){
|
||||
if (*dataum++ == 'N'){
|
||||
if (*dataum++ == 'T'){
|
||||
if (*dataum++ == '='){
|
||||
if (*dataum++ == 'L'){
|
||||
if (*dataum++ == 'O'){
|
||||
if (*dataum++ == 'O'){
|
||||
if (*dataum++ == 'P'){
|
||||
if (*dataum++ == 'P'){
|
||||
if (*dataum++ == 'O'){
|
||||
if (*dataum++ == 'I'){
|
||||
if (*dataum++ == 'N'){
|
||||
if (*dataum++ == 'T'){
|
||||
if (*dataum++ == '=')
|
||||
{
|
||||
size_t newcount = 0;
|
||||
CHAR looplength[64];
|
||||
while (*dataum != 1 && newcount < 63)
|
||||
{
|
||||
looplength[newcount++] = *dataum++;
|
||||
}
|
||||
|
||||
looplength[newcount] = '\n';
|
||||
|
||||
loopstart = atoi(looplength);
|
||||
}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
else
|
||||
dataum--;}
|
||||
}
|
||||
|
||||
if (loopstart > 0)
|
||||
{
|
||||
const int length = FSOUND_Stream_GetLengthMs(fmus);
|
||||
const int freq = 44100;
|
||||
const unsigned int loopend = (unsigned int)((freq/1000.0f)*length-(freq/1000.0f));
|
||||
if (!FSOUND_Stream_SetLoopPoints(fmus, loopstart, loopend))
|
||||
{
|
||||
printf("FMOD(Start,FSOUND_Stream_SetLoopPoints): %s\n",
|
||||
FMOD_ErrorString(FSOUND_GetError()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (mod)
|
||||
FMUSIC_PlaySong(mod);
|
||||
if (fmus)
|
||||
fsoundchannel = FSOUND_Stream_PlayEx(FSOUND_FREE, fmus, NULL, FALSE);
|
||||
|
||||
M_SetVolume(128);
|
||||
}
|
||||
|
||||
static inline VOID FreeWADLumps(VOID)
|
||||
{
|
||||
M_FreeMusic();
|
||||
if (wfptr) free_wadfile(wfptr);
|
||||
wfptr = NULL;
|
||||
}
|
||||
|
||||
static inline VOID ReadWADLumps(LPCSTR WADfilename, HWND hDlg)
|
||||
{
|
||||
HWND listbox = GetDlgItem(hDlg, IDC_PLAYLIST);
|
||||
FILE* f;
|
||||
struct lumplist *curlump;
|
||||
|
||||
SendMessage(listbox, LB_RESETCONTENT, 0, 0);
|
||||
FreeWADLumps();
|
||||
f = fopen(WADfilename, "rb");
|
||||
wfptr = read_wadfile(f);
|
||||
fclose(f);
|
||||
|
||||
/* start of C_LIST */
|
||||
/* Loop through the lump list, printing lump info */
|
||||
for(curlump = wfptr->head->next; curlump; curlump = curlump->next)
|
||||
{
|
||||
LPCSTR lumpname = get_lump_name(curlump->cl);
|
||||
if (!strncmp(lumpname, "O_", 2) || !strncmp(lumpname, "D_", 2))
|
||||
SendMessage(listbox, LB_ADDSTRING, 0, (LPARAM)(LPCSTR)get_lump_name(curlump->cl));
|
||||
}
|
||||
/* end of C_LIST */
|
||||
}
|
||||
|
||||
//
|
||||
// OpenWadfile
|
||||
//
|
||||
// Provides a common dialog box
|
||||
// for selecting the desired wad file.
|
||||
//
|
||||
static inline VOID OpenWadfile(HWND hDlg)
|
||||
{
|
||||
OPENFILENAMEA ofn;
|
||||
CHAR FileBuffer[256] = "";
|
||||
|
||||
ZeroMemory(&ofn, sizeof(ofn));
|
||||
ofn.hwndOwner = hDlg;
|
||||
ofn.lpstrFilter = "WAD Files\0*.wad\0All Files\0*.*\0\0";
|
||||
ofn.lpstrInitialDir = NULL;
|
||||
ofn.lpstrFile = FileBuffer;
|
||||
ofn.lStructSize = sizeof(ofn);
|
||||
ofn.nMaxFile = sizeof(FileBuffer);
|
||||
ofn.nFilterIndex = 1;
|
||||
ofn.lpstrFileTitle = NULL;
|
||||
ofn.nMaxFileTitle = 0;
|
||||
ofn.Flags = OFN_PATHMUSTEXIST | OFN_FILEMUSTEXIST | OFN_HIDEREADONLY;
|
||||
|
||||
if (GetOpenFileNameA(&ofn))
|
||||
ReadWADLumps(FileBuffer, hDlg);
|
||||
}
|
||||
|
||||
static inline VOID PlayLump(HWND hDlg)
|
||||
{
|
||||
HWND listbox = GetDlgItem(hDlg, IDC_PLAYLIST);
|
||||
LRESULT cursel = SendMessage(listbox, LB_GETCURSEL, 0, 0);
|
||||
|
||||
/* Start of C_EXTRACT */
|
||||
CHAR argv[9];
|
||||
|
||||
SendMessage(listbox, LB_GETTEXT, cursel, (LPARAM)(LPCSTR)argv);
|
||||
|
||||
/* Extract LUMPNAME FILENAME pairs */
|
||||
if (wfptr)
|
||||
{
|
||||
struct lumplist *extracted;
|
||||
|
||||
printf("Extracting lump %s...\n", argv);
|
||||
/* Find the lump to extract */
|
||||
extracted = find_previous_lump(wfptr->head, NULL, argv);
|
||||
if (extracted == NULL || (extracted = extracted->next) == NULL)
|
||||
return;
|
||||
|
||||
/* Extract lump */
|
||||
M_StartFMODSong(extracted->cl->data, extracted->cl->len, FALSE, hDlg);
|
||||
|
||||
/* end of extracting LUMPNAME FILENAME pairs */
|
||||
|
||||
} /* end of C_EXTRACT */
|
||||
return;
|
||||
}
|
||||
|
||||
static LRESULT CALLBACK MainWndproc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
|
||||
{
|
||||
return DefWindowProc(hWnd, message, wParam, lParam);
|
||||
}
|
||||
|
||||
static INT_PTR CALLBACK DialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
|
||||
{
|
||||
switch(message)
|
||||
{
|
||||
case WM_INITDIALOG:
|
||||
M_InitMusic();
|
||||
break;
|
||||
|
||||
case WM_CLOSE:
|
||||
EndDialog(hDlg, message);
|
||||
break;
|
||||
|
||||
case WM_DESTROY:
|
||||
FreeWADLumps();
|
||||
M_ShutdownMusic();
|
||||
break;
|
||||
|
||||
case WM_COMMAND:
|
||||
{
|
||||
switch(LOWORD(wParam))
|
||||
{
|
||||
case 2:
|
||||
EndDialog(hDlg, message);
|
||||
return TRUE;
|
||||
case IDC_ABOUT: // The About button.
|
||||
{
|
||||
char TempString[256];
|
||||
sprintf(TempString, "%s %s by %s - %s", APPTITLE, APPVERSION, APPAUTHOR, APPCOMPANY);
|
||||
MessageBoxA(hDlg, TempString, "About", MB_OK|MB_APPLMODAL);
|
||||
}
|
||||
return TRUE;
|
||||
case IDC_OPEN:
|
||||
OpenWadfile(hDlg);
|
||||
return TRUE;
|
||||
case IDC_PLAY:
|
||||
PlayLump(hDlg);
|
||||
return TRUE;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static inline VOID RegisterDialogClass(LPCSTR name, WNDPROC callback, HINSTANCE hInst)
|
||||
{
|
||||
WNDCLASSA wnd;
|
||||
|
||||
wnd.style = CS_HREDRAW | CS_VREDRAW;
|
||||
wnd.cbWndExtra = DLGWINDOWEXTRA;
|
||||
wnd.cbClsExtra = 0;
|
||||
wnd.hCursor = LoadCursorA(NULL,(LPCSTR)MAKEINTRESOURCE(IDC_ARROW));
|
||||
wnd.hIcon = LoadIcon(NULL,MAKEINTRESOURCE(IDI_ICON1));
|
||||
wnd.hInstance = hInst;
|
||||
wnd.lpfnWndProc = callback;
|
||||
wnd.lpszClassName = name;
|
||||
wnd.lpszMenuName = NULL;
|
||||
wnd.hbrBackground = (HBRUSH)(COLOR_WINDOW);
|
||||
|
||||
if (!RegisterClassA(&wnd))
|
||||
{
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
int APIENTRY WinMain(HINSTANCE hInstance,
|
||||
HINSTANCE hPrevInstance,
|
||||
LPSTR lpCmdLine,
|
||||
int nCmdShow)
|
||||
{
|
||||
// Prevent multiples instances of this app.
|
||||
CreateMutexA(NULL, TRUE, APPTITLE);
|
||||
|
||||
if (GetLastError() == ERROR_ALREADY_EXISTS)
|
||||
return 0;
|
||||
|
||||
RegisterDialogClass("SRB2MP", MainWndproc, hInstance);
|
||||
|
||||
DialogBoxA(hInstance, (LPCSTR)IDD_MAIN, NULL, DialogProc);
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -1,148 +0,0 @@
|
|||
# Microsoft Developer Studio Project File - Name="SRB2MP" - Package Owner=<4>
|
||||
# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
||||
# ** DO NOT EDIT **
|
||||
|
||||
# TARGTYPE "Win32 (x86) Application" 0x0101
|
||||
|
||||
CFG=SRB2MP - Win32 Debug
|
||||
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||
!MESSAGE use the Export Makefile command and run
|
||||
!MESSAGE
|
||||
!MESSAGE NMAKE /f "SRB2MP.mak".
|
||||
!MESSAGE
|
||||
!MESSAGE You can specify a configuration when running NMAKE
|
||||
!MESSAGE by defining the macro CFG on the command line. For example:
|
||||
!MESSAGE
|
||||
!MESSAGE NMAKE /f "SRB2MP.mak" CFG="SRB2MP - Win32 Debug"
|
||||
!MESSAGE
|
||||
!MESSAGE Possible choices for configuration are:
|
||||
!MESSAGE
|
||||
!MESSAGE "SRB2MP - Win32 Release" (based on "Win32 (x86) Application")
|
||||
!MESSAGE "SRB2MP - Win32 Debug" (based on "Win32 (x86) Application")
|
||||
!MESSAGE
|
||||
|
||||
# Begin Project
|
||||
# PROP AllowPerConfigDependencies 0
|
||||
# PROP Scc_ProjName ""
|
||||
# PROP Scc_LocalPath ""
|
||||
CPP=cl.exe
|
||||
MTL=midl.exe
|
||||
RSC=rc.exe
|
||||
|
||||
!IF "$(CFG)" == "SRB2MP - Win32 Release"
|
||||
|
||||
# PROP BASE Use_MFC 0
|
||||
# PROP BASE Use_Debug_Libraries 0
|
||||
# PROP BASE Output_Dir "Release"
|
||||
# PROP BASE Intermediate_Dir "Release"
|
||||
# PROP BASE Target_Dir ""
|
||||
# PROP Use_MFC 0
|
||||
# PROP Use_Debug_Libraries 0
|
||||
# PROP Output_Dir "Release"
|
||||
# PROP Intermediate_Dir "Release"
|
||||
# PROP Ignore_Export_Lib 0
|
||||
# PROP Target_Dir ""
|
||||
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /Yu"stdafx.h" /FD /c
|
||||
# ADD CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /D "_MBCS" /Yu"stdafx.h" /FD /c
|
||||
# ADD BASE MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||
# ADD MTL /nologo /D "NDEBUG" /mktyplib203 /win32
|
||||
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||
# ADD RSC /l 0x409 /d "NDEBUG"
|
||||
BSC32=bscmake.exe
|
||||
# ADD BASE BSC32 /nologo
|
||||
# ADD BSC32 /nologo
|
||||
LINK32=link.exe
|
||||
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /machine:I386
|
||||
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib fmodvc.lib /nologo /subsystem:windows /machine:I386
|
||||
|
||||
!ELSEIF "$(CFG)" == "SRB2MP - Win32 Debug"
|
||||
|
||||
# PROP BASE Use_MFC 0
|
||||
# PROP BASE Use_Debug_Libraries 1
|
||||
# PROP BASE Output_Dir "Debug"
|
||||
# PROP BASE Intermediate_Dir "Debug"
|
||||
# PROP BASE Target_Dir ""
|
||||
# PROP Use_MFC 0
|
||||
# PROP Use_Debug_Libraries 1
|
||||
# PROP Output_Dir "Debug"
|
||||
# PROP Intermediate_Dir "Debug"
|
||||
# PROP Ignore_Export_Lib 0
|
||||
# PROP Target_Dir ""
|
||||
# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /Yu"stdafx.h" /FD /GZ /c
|
||||
# ADD CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "_MBCS" /Yu"stdafx.h" /FD /GZ /c
|
||||
# ADD BASE MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||
# ADD MTL /nologo /D "_DEBUG" /mktyplib203 /win32
|
||||
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||
# ADD RSC /l 0x409 /d "_DEBUG"
|
||||
BSC32=bscmake.exe
|
||||
# ADD BASE BSC32 /nologo
|
||||
# ADD BSC32 /nologo
|
||||
LINK32=link.exe
|
||||
# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:windows /debug /machine:I386 /pdbtype:sept
|
||||
# ADD LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib fmodvc.lib /nologo /subsystem:windows /debug /machine:I386 /pdbtype:sept
|
||||
|
||||
!ENDIF
|
||||
|
||||
# Begin Target
|
||||
|
||||
# Name "SRB2MP - Win32 Release"
|
||||
# Name "SRB2MP - Win32 Debug"
|
||||
# Begin Group "Source Files"
|
||||
|
||||
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\lump.c
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\SRB2MP.c
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\StdAfx.c
|
||||
# ADD CPP /Yc"stdafx.h"
|
||||
# End Source File
|
||||
# End Group
|
||||
# Begin Group "Header Files"
|
||||
|
||||
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\lump.h
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\resource.h
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\StdAfx.h
|
||||
# End Source File
|
||||
# End Group
|
||||
# Begin Group "Resource Files"
|
||||
|
||||
# PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe"
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\icon1.ico
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\icon2.ico
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\icon3.ico
|
||||
# End Source File
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\Script1.rc
|
||||
# End Source File
|
||||
# End Group
|
||||
# Begin Source File
|
||||
|
||||
SOURCE=.\ReadMe.txt
|
||||
# End Source File
|
||||
# End Target
|
||||
# End Project
|
|
@ -1,29 +0,0 @@
|
|||
Microsoft Developer Studio Workspace File, Format Version 6.00
|
||||
# WARNING: DO NOT EDIT OR DELETE THIS WORKSPACE FILE!
|
||||
|
||||
###############################################################################
|
||||
|
||||
Project: "SRB2MP"=.\SRB2MP.dsp - Package Owner=<4>
|
||||
|
||||
Package=<5>
|
||||
{{{
|
||||
}}}
|
||||
|
||||
Package=<4>
|
||||
{{{
|
||||
}}}
|
||||
|
||||
###############################################################################
|
||||
|
||||
Global:
|
||||
|
||||
Package=<5>
|
||||
{{{
|
||||
}}}
|
||||
|
||||
Package=<3>
|
||||
{{{
|
||||
}}}
|
||||
|
||||
###############################################################################
|
||||
|
Binary file not shown.
|
@ -1,118 +0,0 @@
|
|||
//Microsoft Developer Studio generated resource script.
|
||||
//
|
||||
#include "resource.h"
|
||||
|
||||
#define APSTUDIO_READONLY_SYMBOLS
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Generated from the TEXTINCLUDE 2 resource.
|
||||
//
|
||||
#include "afxres.h"
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
#undef APSTUDIO_READONLY_SYMBOLS
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// English (U.S.) resources
|
||||
|
||||
#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU)
|
||||
#ifdef _WIN32
|
||||
LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US
|
||||
#pragma code_page(1252)
|
||||
#endif //_WIN32
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Dialog
|
||||
//
|
||||
|
||||
IDD_MAIN DIALOG DISCARDABLE 0, 0, 262, 170
|
||||
STYLE DS_3DLOOK | WS_MINIMIZEBOX | WS_POPUP | WS_VISIBLE | WS_CAPTION |
|
||||
WS_SYSMENU
|
||||
CAPTION "SRB2 Music Player"
|
||||
FONT 8, "MS Sans Serif"
|
||||
BEGIN
|
||||
PUSHBUTTON "E&xit",IDCANCEL,205,145,50,19
|
||||
PUSHBUTTON "&About",IDC_ABOUT,230,15,23,10
|
||||
LISTBOX IDC_WADLIST,5,30,112,110,LBS_SORT | LBS_NOINTEGRALHEIGHT |
|
||||
WS_VSCROLL | WS_TABSTOP
|
||||
LISTBOX IDC_PLAYLIST,140,30,114,110,LBS_SORT |
|
||||
LBS_NOINTEGRALHEIGHT | WS_VSCROLL | WS_TABSTOP
|
||||
PUSHBUTTON "&Play",IDC_PLAY,140,145,60,20
|
||||
PUSHBUTTON "->",IDC_ADD,120,35,15,15
|
||||
PUSHBUTTON "<-",IDC_REMOVE,120,55,15,15
|
||||
PUSHBUTTON "&Open WAD...",IDC_OPEN,5,10,50,15
|
||||
ICON IDI_ICON1,IDC_STATIC,205,5,20,20
|
||||
LTEXT "Title:",IDC_TITLE,5,140,125,10
|
||||
LTEXT "By:",IDC_ARTIST,5,150,125,15
|
||||
END
|
||||
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// DESIGNINFO
|
||||
//
|
||||
|
||||
#ifdef APSTUDIO_INVOKED
|
||||
GUIDELINES DESIGNINFO DISCARDABLE
|
||||
BEGIN
|
||||
IDD_MAIN, DIALOG
|
||||
BEGIN
|
||||
LEFTMARGIN, 7
|
||||
RIGHTMARGIN, 255
|
||||
TOPMARGIN, 7
|
||||
BOTTOMMARGIN, 163
|
||||
END
|
||||
END
|
||||
#endif // APSTUDIO_INVOKED
|
||||
|
||||
|
||||
#ifdef APSTUDIO_INVOKED
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// TEXTINCLUDE
|
||||
//
|
||||
|
||||
1 TEXTINCLUDE DISCARDABLE
|
||||
BEGIN
|
||||
"resource.h\0"
|
||||
END
|
||||
|
||||
2 TEXTINCLUDE DISCARDABLE
|
||||
BEGIN
|
||||
"#include ""afxres.h""\r\n"
|
||||
"\0"
|
||||
END
|
||||
|
||||
3 TEXTINCLUDE DISCARDABLE
|
||||
BEGIN
|
||||
"\r\n"
|
||||
"\0"
|
||||
END
|
||||
|
||||
#endif // APSTUDIO_INVOKED
|
||||
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Icon
|
||||
//
|
||||
|
||||
// Icon with lowest ID value placed first to ensure application icon
|
||||
// remains consistent on all systems.
|
||||
IDI_ICON1 ICON DISCARDABLE "icon1.ico"
|
||||
#endif // English (U.S.) resources
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
||||
|
||||
#ifndef APSTUDIO_INVOKED
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Generated from the TEXTINCLUDE 3 resource.
|
||||
//
|
||||
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
#endif // not APSTUDIO_INVOKED
|
||||
|
|
@ -1,8 +0,0 @@
|
|||
// stdafx.cpp : source file that includes just the standard includes
|
||||
// SRB2MP.pch will be the pre-compiled header
|
||||
// stdafx.obj will contain the pre-compiled type information
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
// TODO: reference any additional headers you need in STDAFX.H
|
||||
// and not in this file
|
|
@ -1,35 +0,0 @@
|
|||
// stdafx.h : include file for standard system include files,
|
||||
// or project specific include files that are used frequently, but
|
||||
// are changed infrequently
|
||||
//
|
||||
|
||||
#if !defined(AFX_STDAFX_H__A9DB83DB_A9FD_11D0_BFD1_444553540000__INCLUDED_)
|
||||
#define AFX_STDAFX_H__A9DB83DB_A9FD_11D0_BFD1_444553540000__INCLUDED_
|
||||
|
||||
//#define UNICODE
|
||||
|
||||
#if _MSC_VER > 1000
|
||||
#pragma once
|
||||
#endif // _MSC_VER > 1000
|
||||
|
||||
#define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers
|
||||
|
||||
#include <windows.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <commdlg.h>
|
||||
|
||||
// TODO: reference additional headers your program requires here
|
||||
#ifdef __MINGW32__
|
||||
#include <FMOD/fmod.h>
|
||||
#include <FMOD/fmod_errors.h>
|
||||
#else
|
||||
#include <fmod.h>
|
||||
#include <fmod_errors.h>
|
||||
#endif
|
||||
#include "resource.h"
|
||||
|
||||
//{{AFX_INSERT_LOCATION}}
|
||||
// Microsoft Visual C++ will insert additional declarations immediately before the previous line.
|
||||
|
||||
#endif // !defined(AFX_STDAFX_H__A9DB83DB_A9FD_11D0_BFD1_444553540000__INCLUDED_)
|
Binary file not shown.
Before Width: | Height: | Size: 2.9 KiB |
|
@ -1,471 +0,0 @@
|
|||
/*
|
||||
LumpMod v0.21, a command-line utility for working with lumps in wad files.
|
||||
Copyright (C) 2003 Thunder Palace Entertainment.
|
||||
|
||||
This program 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., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
lump.c: Provides functions for dealing with lumps
|
||||
*/
|
||||
|
||||
#include "StdAfx.h"
|
||||
#include <string.h>
|
||||
#include <ctype.h>
|
||||
#include "lump.h"
|
||||
|
||||
/* Read contents of a wad file and store them in memory.
|
||||
* fpoint is the file to read, opened with "rb" mode.
|
||||
* A pointer to a new wadfile struct will be returned, or NULL on error.
|
||||
*/
|
||||
struct wadfile *read_wadfile(FILE *fpoint) {
|
||||
struct wadfile *wfptr;
|
||||
struct lumplist *curlump;
|
||||
unsigned long diroffset, filelen;
|
||||
unsigned long count;
|
||||
|
||||
/* Allocate memory for wadfile struct */
|
||||
wfptr = (struct wadfile*)malloc(sizeof(struct wadfile));
|
||||
if(wfptr == NULL) return NULL;
|
||||
|
||||
/* Read first four characters (PWAD or IWAD) */
|
||||
if(fread(wfptr->id, 4, 1, fpoint) < 1) {
|
||||
free(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Read number of lumps */
|
||||
if(fread(&(wfptr->numlumps), 4, 1, fpoint) < 1) {
|
||||
free(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* If number of lumps is zero, nothing more needs to be done */
|
||||
if(wfptr->numlumps == 0) {
|
||||
wfptr->head = NULL;
|
||||
return wfptr;
|
||||
}
|
||||
|
||||
/* Read offset of directory */
|
||||
if(fread(&diroffset, 4, 1, fpoint) < 1) {
|
||||
free(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Verify that the directory as long as it needs to be */
|
||||
fseek(fpoint, 0, SEEK_END);
|
||||
filelen = ftell(fpoint);
|
||||
if((filelen - diroffset) / DIRENTRYLEN < wfptr->numlumps) {
|
||||
free(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Allocate memory for head lumplist item and set head pointer */
|
||||
curlump = (struct lumplist*)malloc(sizeof(struct lumplist));
|
||||
if(curlump == NULL) {
|
||||
free(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
wfptr->head = curlump;
|
||||
curlump->cl = NULL;
|
||||
|
||||
/* Read directory entries and lumps */
|
||||
for(count = 0; count < wfptr->numlumps; count++) {
|
||||
long lumpdataoffset;
|
||||
|
||||
/* Advance to a new list item */
|
||||
curlump->next = (struct lumplist*)malloc(sizeof(struct lumplist));
|
||||
if(curlump->next == NULL) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
curlump = curlump->next;
|
||||
curlump->next = NULL;
|
||||
|
||||
/* Allocate memory for the lump info */
|
||||
curlump->cl = (struct lump*)malloc(sizeof(struct lump));
|
||||
if(curlump->cl == NULL) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Seek to the proper position in the file */
|
||||
if(fseek(fpoint, diroffset + (count * DIRENTRYLEN), SEEK_SET) != 0) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Read offset of lump data */
|
||||
if(fread(&lumpdataoffset, 4, 1, fpoint) < 1) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Read size of lump in bytes */
|
||||
if(fread(&(curlump->cl->len), 4, 1, fpoint) < 1) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Read lump name */
|
||||
if(fread(curlump->cl->name, 8, 1, fpoint) < 1) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Read actual lump data, unless lump size is 0 */
|
||||
if(curlump->cl->len > 0) {
|
||||
if(fseek(fpoint, lumpdataoffset, SEEK_SET) != 0) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Allocate memory for data */
|
||||
curlump->cl->data = (unsigned char*)malloc(curlump->cl->len);
|
||||
if(curlump->cl->data == NULL) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Fill the data buffer */
|
||||
if(fread(curlump->cl->data, curlump->cl->len, 1, fpoint) < 1) {
|
||||
free_wadfile(wfptr);
|
||||
return NULL;
|
||||
}
|
||||
} else curlump->cl->data = NULL;
|
||||
} /* End of directory reading loop */
|
||||
|
||||
return wfptr;
|
||||
}
|
||||
|
||||
/* Free a wadfile from memory as well as all related structures.
|
||||
*/
|
||||
void free_wadfile(struct wadfile *wfptr) {
|
||||
struct lumplist *curlump, *nextlump;
|
||||
|
||||
if(wfptr == NULL) return;
|
||||
curlump = wfptr->head;
|
||||
|
||||
/* Free items in the lump list */
|
||||
while(curlump != NULL) {
|
||||
|
||||
/* Free the actual lump and its data, if necessary */
|
||||
if(curlump->cl != NULL) {
|
||||
if(curlump->cl->data != NULL) free(curlump->cl->data);
|
||||
free(curlump->cl);
|
||||
}
|
||||
|
||||
/* Advance to next lump and free this one */
|
||||
nextlump = curlump->next;
|
||||
free(curlump);
|
||||
curlump = nextlump;
|
||||
}
|
||||
|
||||
free(wfptr);
|
||||
}
|
||||
|
||||
/* Write complete wadfile to a file stream, opened with "wb" mode.
|
||||
* fpoint is the stream to write to.
|
||||
* wfptr is a pointer to the wadfile structure to use.
|
||||
* Return zero on success, nonzero on failure.
|
||||
*/
|
||||
int write_wadfile(FILE *fpoint, struct wadfile *wfptr) {
|
||||
struct lumplist *curlump;
|
||||
long lumpdataoffset, diroffset;
|
||||
|
||||
if(wfptr == NULL) return 1;
|
||||
|
||||
/* Write four-character ID ("PWAD" or "IWAD") */
|
||||
if(fwrite(wfptr->id, 4, 1, fpoint) < 1) return 2;
|
||||
|
||||
/* Write number of lumps */
|
||||
if(fwrite(&(wfptr->numlumps), 4, 1, fpoint) < 1) return 3;
|
||||
|
||||
/* Offset of directory is not known yet. For now, write number of lumps
|
||||
* again, just to fill the space.
|
||||
*/
|
||||
if(fwrite(&(wfptr->numlumps), 4, 1, fpoint) < 1) return 4;
|
||||
|
||||
/* Loop through lump list, writing lump data */
|
||||
for(curlump = wfptr->head; curlump != NULL; curlump = curlump->next) {
|
||||
|
||||
/* Don't write anything for the head of the lump list or for lumps of
|
||||
zero length */
|
||||
if(curlump->cl == NULL || curlump->cl->data == NULL) continue;
|
||||
|
||||
/* Write the data */
|
||||
if(fwrite(curlump->cl->data, curlump->cl->len, 1, fpoint) < 1)
|
||||
return 5;
|
||||
}
|
||||
|
||||
/* Current position is where directory will start */
|
||||
diroffset = ftell(fpoint);
|
||||
|
||||
/* Offset for the first lump's data is always 12 */
|
||||
lumpdataoffset = 12;
|
||||
|
||||
/* Loop through lump list again, this time writing directory entries */
|
||||
for(curlump = wfptr->head; curlump != NULL; curlump = curlump->next) {
|
||||
|
||||
/* Don't write anything for the head of the lump list */
|
||||
if(curlump->cl == NULL) continue;
|
||||
|
||||
/* Write offset for lump data */
|
||||
if(fwrite(&lumpdataoffset, 4, 1, fpoint) < 1) return 6;
|
||||
|
||||
/* Write size of lump data */
|
||||
if(fwrite(&(curlump->cl->len), 4, 1, fpoint) < 1) return 7;
|
||||
|
||||
/* Write lump name */
|
||||
if(fwrite(curlump->cl->name, 8, 1, fpoint) < 1) return 8;
|
||||
|
||||
/* Increment lumpdataoffset variable as appropriate */
|
||||
lumpdataoffset += curlump->cl->len;
|
||||
}
|
||||
|
||||
/* Go back to header and write the proper directory offset */
|
||||
fseek(fpoint, 8, SEEK_SET);
|
||||
if(fwrite(&diroffset, 4, 1, fpoint) < 1) return 9;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Get the name of a lump, as a null-terminated string.
|
||||
* item is a pointer to the lump (not lumplist) whose name will be obtained.
|
||||
* Return NULL on error.
|
||||
*/
|
||||
char *get_lump_name(struct lump *item) {
|
||||
char convname[9], *retname;
|
||||
|
||||
if(item == NULL) return NULL;
|
||||
memcpy(convname, item->name, 8);
|
||||
convname[8] = '\0';
|
||||
|
||||
retname = (char*)malloc(strlen(convname) + 1);
|
||||
if(retname != NULL) strcpy(retname, convname);
|
||||
return retname;
|
||||
}
|
||||
|
||||
/* Find the lump after start and before end having a certain name.
|
||||
* Return a pointer to the list item for that lump, or return NULL if no lump
|
||||
* by that name is found or lumpname is too long.
|
||||
* lumpname is a null-terminated string.
|
||||
* If end parameter is NULL, search to the end of the entire list.
|
||||
*/
|
||||
struct lumplist *find_previous_lump(struct lumplist *start, struct lumplist
|
||||
*end, char *lumpname) {
|
||||
struct lumplist *curlump, *lastlump;
|
||||
char *curname;
|
||||
int found = 0;
|
||||
|
||||
/* Verify that parameters are valid */
|
||||
if(start==NULL || start==end || lumpname==NULL || strlen(lumpname) > 8)
|
||||
return NULL;
|
||||
|
||||
/* Loop through the list from start parameter */
|
||||
lastlump = start;
|
||||
for(curlump = start->next; curlump != end && curlump != NULL;
|
||||
curlump = curlump->next) {
|
||||
|
||||
/* Skip header lump */
|
||||
if(curlump->cl == NULL) continue;
|
||||
|
||||
/* Find name of this lump */
|
||||
curname = get_lump_name(curlump->cl);
|
||||
if(curname == NULL) continue;
|
||||
|
||||
/* Compare names to see if this is the lump we want */
|
||||
if(strcmp(curname, lumpname) == 0) {
|
||||
found = 1;
|
||||
break;
|
||||
}
|
||||
|
||||
/* Free memory allocated to curname */
|
||||
free(curname);
|
||||
|
||||
lastlump = curlump;
|
||||
}
|
||||
|
||||
if(found) return lastlump;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Remove a lump from the list, free it, and free its data.
|
||||
* before is the lump immediately preceding the lump to be removed.
|
||||
* wfptr is a pointer to the wadfile structure to which the removed lump
|
||||
* belongs, so that numlumps can be decreased.
|
||||
*/
|
||||
void remove_next_lump(struct wadfile *wfptr, struct lumplist *before) {
|
||||
struct lumplist *removed;
|
||||
|
||||
/* Verify that parameters are valid */
|
||||
if(before == NULL || before->next == NULL || wfptr == NULL) return;
|
||||
|
||||
/* Update linked list to omit removed lump */
|
||||
removed = before->next;
|
||||
before->next = removed->next;
|
||||
|
||||
/* Free lump info and data if necessary */
|
||||
if(removed->cl != NULL) {
|
||||
if(removed->cl->data != NULL) free(removed->cl->data);
|
||||
free(removed->cl);
|
||||
}
|
||||
|
||||
free(removed);
|
||||
|
||||
/* Decrement numlumps */
|
||||
wfptr->numlumps--;
|
||||
}
|
||||
|
||||
/* Add a lump.
|
||||
* The lump will follow prev in the list and be named name, with a data size
|
||||
* of len.
|
||||
* A copy will be made of the data.
|
||||
* Return zero on success or nonzero on failure.
|
||||
*/
|
||||
int add_lump(struct wadfile *wfptr, struct lumplist *prev, char *name, long
|
||||
len, unsigned char *data) {
|
||||
struct lump *newlump;
|
||||
struct lumplist *newlumplist;
|
||||
unsigned char *copydata;
|
||||
|
||||
/* Verify that parameters are valid */
|
||||
if(wfptr == NULL || prev == NULL || name == NULL || strlen(name) > 8)
|
||||
return 1;
|
||||
|
||||
/* Allocate space for newlump and newlumplist */
|
||||
newlump = (struct lump*)malloc(sizeof(struct lump));
|
||||
newlumplist = (struct lumplist*)malloc(sizeof(struct lumplist));
|
||||
if(newlump == NULL || newlumplist == NULL) return 2;
|
||||
|
||||
/* Copy lump data and set up newlump */
|
||||
if(len == 0 || data == NULL) {
|
||||
newlump->len = 0;
|
||||
newlump->data = NULL;
|
||||
} else {
|
||||
newlump->len = len;
|
||||
copydata = (unsigned char*)malloc(len);
|
||||
if(copydata == NULL) return 3;
|
||||
memcpy(copydata, data, len);
|
||||
newlump->data = copydata;
|
||||
}
|
||||
|
||||
/* Set name of newlump */
|
||||
memset(newlump->name, '\0', 8);
|
||||
if(strlen(name) == 8) memcpy(newlump->name, name, 8);
|
||||
else strcpy(newlump->name, name);
|
||||
|
||||
/* Set up newlumplist and alter prev appropriately */
|
||||
newlumplist->cl = newlump;
|
||||
newlumplist->next = prev->next;
|
||||
prev->next = newlumplist;
|
||||
|
||||
/* Increment numlumps */
|
||||
wfptr->numlumps++;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Rename a lump.
|
||||
* renamed is a pointer to the lump (not lumplist) that needs renaming.
|
||||
* newname is a null-terminated string with the new name.
|
||||
* Return zero on success or nonzero on failure.
|
||||
*/
|
||||
int rename_lump(struct lump *renamed, char *newname) {
|
||||
|
||||
/* Verify that parameters are valid. */
|
||||
if(newname == NULL || renamed == NULL || strlen(newname) > 8) return 1;
|
||||
|
||||
/* Do the renaming. */
|
||||
memset(renamed->name, '\0', 8);
|
||||
if(strlen(newname) == 8) memcpy(renamed->name, newname, 8);
|
||||
else strcpy(renamed->name, newname);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Find the last lump in a wadfile structure.
|
||||
* Return this lump or NULL on failure.
|
||||
*/
|
||||
struct lumplist *find_last_lump(struct wadfile *wfptr) {
|
||||
struct lumplist *curlump;
|
||||
|
||||
if(wfptr == NULL || wfptr->head == NULL) return NULL;
|
||||
curlump = wfptr->head;
|
||||
|
||||
while(curlump->next != NULL) curlump = curlump->next;
|
||||
return curlump;
|
||||
}
|
||||
|
||||
/* Find the last lump between start and end.
|
||||
* Return this lump or NULL on failure.
|
||||
*/
|
||||
struct lumplist *find_last_lump_between(struct lumplist *start, struct
|
||||
lumplist *end) {
|
||||
struct lumplist *curlump;
|
||||
|
||||
if(start == NULL) return NULL;
|
||||
curlump = start;
|
||||
|
||||
while(curlump->next != end) {
|
||||
curlump = curlump->next;
|
||||
if(curlump == NULL) break;
|
||||
}
|
||||
|
||||
return curlump;
|
||||
}
|
||||
|
||||
/* Find the next section lump. A section lump is MAPxx (0 <= x <= 9), ExMy
|
||||
* (0 <= x <= 9, 0 <= y <= 9), or any lump whose name ends in _START or _END.
|
||||
* Return NULL if there are no section lumps after start.
|
||||
*/
|
||||
struct lumplist *find_next_section_lump(struct lumplist *start) {
|
||||
struct lumplist *curlump, *found = NULL;
|
||||
char *curname;
|
||||
|
||||
/* Verify that parameter is valid */
|
||||
if(start == NULL || start->next == NULL) return NULL;
|
||||
|
||||
/* Loop through the list from start parameter */
|
||||
for(curlump = start->next; curlump != NULL && found == NULL;
|
||||
curlump = curlump->next) {
|
||||
|
||||
/* Skip header lump */
|
||||
if(curlump->cl == NULL) continue;
|
||||
|
||||
/* Find name of this lump */
|
||||
curname = get_lump_name(curlump->cl);
|
||||
if(curname == NULL) continue;
|
||||
|
||||
/* Check to see if this is a section lump */
|
||||
if(strlen(curname) == 5 && strncmp("MAP", curname, 3) == 0 &&
|
||||
isdigit(curname[3]) && isdigit(curname[4]))
|
||||
found = curlump;
|
||||
else if(strlen(curname) == 4 && curname[0] == 'E' && curname[2] ==
|
||||
'M' && isdigit(curname[1]) && isdigit(curname[3]))
|
||||
found = curlump;
|
||||
else if(strlen(curname) == 7 && strcmp("_START", &curname[1]) == 0)
|
||||
found = curlump;
|
||||
else if(strlen(curname) == 8 && strcmp("_START", &curname[2]) == 0)
|
||||
found = curlump;
|
||||
else if(strlen(curname) == 5 && strcmp("_END", &curname[1]) == 0)
|
||||
found = curlump;
|
||||
else if(strlen(curname) == 6 && strcmp("_END", &curname[2]) == 0)
|
||||
found = curlump;
|
||||
|
||||
/* Free memory allocated to curname */
|
||||
free(curname);
|
||||
}
|
||||
|
||||
return found;
|
||||
}
|
|
@ -1,61 +0,0 @@
|
|||
/*
|
||||
LumpMod v0.21, a command-line utility for working with lumps in wad files.
|
||||
Copyright (C) 2003 Thunder Palace Entertainment.
|
||||
|
||||
This program 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., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
|
||||
lump.h: Defines constants, structures, and functions used in lump.c
|
||||
*/
|
||||
|
||||
#ifndef __LUMP_H
|
||||
#define __LUMP_H
|
||||
|
||||
/* Entries in the wadfile directory are 16 bytes */
|
||||
#define DIRENTRYLEN 16
|
||||
|
||||
/* Lumps and associated info */
|
||||
struct lump {
|
||||
long len;
|
||||
unsigned char *data;
|
||||
char name[8];
|
||||
};
|
||||
|
||||
/* Linked list of lumps */
|
||||
struct lumplist {
|
||||
struct lump *cl; /* actual content of the lump */
|
||||
struct lumplist *next;
|
||||
};
|
||||
|
||||
/* Structure to contain all wadfile data */
|
||||
struct wadfile {
|
||||
char id[4]; /* IWAD or PWAD */
|
||||
unsigned long numlumps; /* 32-bit integer */
|
||||
struct lumplist *head; /* points to first entry */
|
||||
};
|
||||
|
||||
/* Function declarations */
|
||||
struct wadfile *read_wadfile(FILE *);
|
||||
void free_wadfile(struct wadfile *);
|
||||
int write_wadfile(FILE *, struct wadfile *);
|
||||
char *get_lump_name(struct lump *);
|
||||
struct lumplist *find_previous_lump(struct lumplist *, struct lumplist *, char *);
|
||||
void remove_next_lump(struct wadfile *, struct lumplist *);
|
||||
int add_lump(struct wadfile *, struct lumplist *, char *, long, unsigned char *);
|
||||
int rename_lump(struct lump *, char *);
|
||||
struct lumplist *find_last_lump(struct wadfile *);
|
||||
struct lumplist *find_last_lump_between(struct lumplist *, struct lumplist *);
|
||||
struct lumplist *find_next_section_lump(struct lumplist *);
|
||||
|
||||
#endif
|
|
@ -1,26 +0,0 @@
|
|||
//{{NO_DEPENDENCIES}}
|
||||
// Microsoft Developer Studio generated include file.
|
||||
// Used by Script1.rc
|
||||
//
|
||||
#define IDD_MAIN 101
|
||||
#define IDI_ICON1 102
|
||||
#define IDC_ABOUT 1000
|
||||
#define IDC_WADLIST 1001
|
||||
#define IDC_PLAYLIST 1002
|
||||
#define IDC_PLAY 1003
|
||||
#define IDC_ADD 1004
|
||||
#define IDC_REMOVE 1005
|
||||
#define IDC_OPEN 1006
|
||||
#define IDC_TITLE 1007
|
||||
#define IDC_ARTIST 1008
|
||||
|
||||
// Next default values for new objects
|
||||
//
|
||||
#ifdef APSTUDIO_INVOKED
|
||||
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||
#define _APS_NEXT_RESOURCE_VALUE 105
|
||||
#define _APS_NEXT_COMMAND_VALUE 40001
|
||||
#define _APS_NEXT_CONTROL_VALUE 1009
|
||||
#define _APS_NEXT_SYMED_VALUE 101
|
||||
#endif
|
||||
#endif
|
Loading…
Reference in a new issue