2006-03-20 17:12:09 +00:00
|
|
|
/*
|
2014-06-01 17:55:23 +00:00
|
|
|
* Portions of this file are copyright Rebirth contributors and licensed as
|
|
|
|
* described in COPYING.txt.
|
|
|
|
* Portions of this file are copyright Parallax Software and licensed
|
|
|
|
* according to the Parallax license below.
|
|
|
|
* See COPYING.txt for license details.
|
|
|
|
|
2006-03-20 17:12:09 +00:00
|
|
|
THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
|
|
|
|
SOFTWARE CORPORATION ("PARALLAX"). PARALLAX, IN DISTRIBUTING THE CODE TO
|
|
|
|
END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
|
|
|
|
ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
|
|
|
|
IN USING, DISPLAYING, AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
|
|
|
|
SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
|
|
|
|
FREE PURPOSES. IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
|
|
|
|
CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES. THE END-USER UNDERSTANDS
|
|
|
|
AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
|
|
|
|
COPYRIGHT 1993-1999 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Functions for managing the pig files.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "pstypes.h"
|
|
|
|
#include "strutil.h"
|
|
|
|
#include "inferno.h"
|
|
|
|
#include "gr.h"
|
|
|
|
#include "grdef.h"
|
|
|
|
#include "u_mem.h"
|
|
|
|
#include "iff.h"
|
2012-07-07 18:35:06 +00:00
|
|
|
#include "dxxerror.h"
|
2006-03-20 17:12:09 +00:00
|
|
|
#include "sounds.h"
|
|
|
|
#include "songs.h"
|
|
|
|
#include "bm.h"
|
|
|
|
#include "hash.h"
|
2013-09-24 01:59:09 +00:00
|
|
|
#include "common/2d/bitmap.h"
|
2006-03-20 17:12:09 +00:00
|
|
|
#include "args.h"
|
|
|
|
#include "palette.h"
|
|
|
|
#include "gamefont.h"
|
2012-11-11 00:12:17 +00:00
|
|
|
#include "gamepal.h"
|
2014-07-20 01:09:55 +00:00
|
|
|
#include "physfsx.h"
|
2006-03-20 17:12:09 +00:00
|
|
|
#include "rle.h"
|
|
|
|
#include "screens.h"
|
|
|
|
#include "piggy.h"
|
|
|
|
#include "gamemine.h"
|
|
|
|
#include "textures.h"
|
|
|
|
#include "texmerge.h"
|
|
|
|
#include "paging.h"
|
|
|
|
#include "game.h"
|
|
|
|
#include "text.h"
|
|
|
|
#include "newmenu.h"
|
2014-07-03 01:47:29 +00:00
|
|
|
#include "byteutil.h"
|
2006-03-20 17:12:09 +00:00
|
|
|
#include "makesig.h"
|
2008-04-06 20:23:28 +00:00
|
|
|
#include "console.h"
|
2014-08-16 04:15:16 +00:00
|
|
|
#include "compiler-make_unique.h"
|
2013-12-21 05:12:38 +00:00
|
|
|
#include "compiler-static_assert.h"
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
#include "custom.h"
|
|
|
|
#include "snddecom.h"
|
|
|
|
#define DEFAULT_PIGFILE_REGISTERED "descent.pig"
|
|
|
|
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
#define DEFAULT_PIGFILE_REGISTERED "groupa.pig"
|
|
|
|
#define DEFAULT_PIGFILE_SHAREWARE "d2demo.pig"
|
|
|
|
#define DEFAULT_HAMFILE_REGISTERED "descent2.ham"
|
|
|
|
#define DEFAULT_HAMFILE_SHAREWARE "d2demo.ham"
|
|
|
|
|
|
|
|
#define D1_PALETTE "palette.256"
|
|
|
|
|
2007-07-14 22:36:04 +00:00
|
|
|
#define DEFAULT_SNDFILE ((Piggy_hamfile_version < 3)?DEFAULT_HAMFILE_SHAREWARE:(GameArg.SndDigiSampleRate==SAMPLE_RATE_22K)?"descent2.s22":"descent2.s11")
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
#define MAC_ALIEN1_PIGSIZE 5013035
|
|
|
|
#define MAC_ALIEN2_PIGSIZE 4909916
|
|
|
|
#define MAC_FIRE_PIGSIZE 4969035
|
|
|
|
#define MAC_GROUPA_PIGSIZE 4929684 // also used for mac shareware
|
|
|
|
#define MAC_ICE_PIGSIZE 4923425
|
|
|
|
#define MAC_WATER_PIGSIZE 4832403
|
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
alias alias_list[MAX_ALIASES];
|
|
|
|
int Num_aliases=0;
|
|
|
|
|
|
|
|
int Must_write_hamfile = 0;
|
|
|
|
int Piggy_hamfile_version = 0;
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2013-10-06 16:20:00 +00:00
|
|
|
|
2014-07-24 02:45:47 +00:00
|
|
|
static std::unique_ptr<ubyte[]> BitmapBits;
|
2014-07-24 02:45:47 +00:00
|
|
|
static std::unique_ptr<ubyte[]> SoundBits;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-22 22:03:07 +00:00
|
|
|
struct SoundFile
|
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
char name[15];
|
2013-12-22 22:03:07 +00:00
|
|
|
};
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
hashtable AllBitmapsNames;
|
|
|
|
hashtable AllDigiSndNames;
|
|
|
|
|
|
|
|
int Num_bitmap_files = 0;
|
|
|
|
int Num_sound_files = 0;
|
|
|
|
|
|
|
|
digi_sound GameSounds[MAX_SOUND_FILES];
|
|
|
|
int SoundOffset[MAX_SOUND_FILES];
|
|
|
|
grs_bitmap GameBitmaps[MAX_BITMAP_FILES];
|
|
|
|
|
|
|
|
int Num_bitmap_files_new = 0;
|
|
|
|
int Num_sound_files_new = 0;
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
#define DBM_FLAG_LARGE 128 // Flags added onto the flags struct in b
|
|
|
|
static
|
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
BitmapFile AllBitmaps[ MAX_BITMAP_FILES ];
|
|
|
|
static SoundFile AllSounds[ MAX_SOUND_FILES ];
|
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
#define DBM_FLAG_ABM 64 // animated bitmap
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
int Piggy_bitmap_cache_size = 0;
|
|
|
|
int Piggy_bitmap_cache_next = 0;
|
|
|
|
ubyte * Piggy_bitmap_cache_data = NULL;
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
|
|
|
static
|
|
|
|
#endif
|
|
|
|
int GameBitmapOffset[MAX_BITMAP_FILES];
|
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
|
|
|
static
|
|
|
|
#endif
|
|
|
|
ubyte GameBitmapFlags[MAX_BITMAP_FILES];
|
2006-03-20 17:12:09 +00:00
|
|
|
ushort GameBitmapXlat[MAX_BITMAP_FILES];
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
#define PIGGY_BUFFER_SIZE (2048*1024)
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2013-10-06 16:20:00 +00:00
|
|
|
#define PIGFILE_ID MAKE_SIG('G','I','P','P') //PPIG
|
|
|
|
#define PIGFILE_VERSION 2
|
2006-03-20 17:12:09 +00:00
|
|
|
#define PIGGY_BUFFER_SIZE (2400*1024)
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2007-07-14 20:33:42 +00:00
|
|
|
#define PIGGY_SMALL_BUFFER_SIZE (1400*1024) // size of buffer when GameArg.SysLowMem is set
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
int piggy_page_flushed = 0;
|
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
PHYSFS_file * Piggy_fp = NULL;
|
|
|
|
|
|
|
|
ubyte bogus_data[64*64];
|
|
|
|
ubyte bogus_bitmap_initialized=0;
|
|
|
|
digi_sound bogus_sound;
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
grs_bitmap bogus_bitmap;
|
|
|
|
int MacPig = 0; // using the Macintosh pigfile?
|
|
|
|
int PCSharePig = 0; // using PC Shareware pigfile?
|
|
|
|
static int SoundCompressed[ MAX_SOUND_FILES ];
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2013-10-06 16:20:00 +00:00
|
|
|
char Current_pigfile[FILENAME_LEN] = "";
|
|
|
|
int Pigfile_initialized=0;
|
|
|
|
|
2014-07-24 02:45:47 +00:00
|
|
|
static std::unique_ptr<ubyte[]> Bitmap_replacement_data;
|
2013-10-06 16:20:00 +00:00
|
|
|
|
2006-03-20 17:12:09 +00:00
|
|
|
#define DBM_NUM_FRAMES 63
|
|
|
|
|
|
|
|
#define BM_FLAGS_TO_COPY (BM_FLAG_TRANSPARENT | BM_FLAG_SUPER_TRANSPARENT \
|
|
|
|
| BM_FLAG_NO_LIGHTING | BM_FLAG_RLE | BM_FLAG_RLE_BIG)
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-22 22:03:07 +00:00
|
|
|
struct DiskBitmapHeader
|
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
char name[8];
|
|
|
|
ubyte dflags; // bits 0-5 anim frame num, bit 6 abm flag
|
|
|
|
ubyte width; // low 8 bits here, 4 more bits in wh_extra
|
|
|
|
ubyte height; // low 8 bits here, 4 more bits in wh_extra
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
ubyte wh_extra; // bits 0-3 width, bits 4-7 height
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
ubyte flags;
|
|
|
|
ubyte avg_color;
|
|
|
|
int offset;
|
2013-12-22 22:03:07 +00:00
|
|
|
} __pack__;
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
2013-11-26 05:03:00 +00:00
|
|
|
static_assert(sizeof(DiskBitmapHeader) == 0x11, "sizeof(DiskBitmapHeader) must be 0x11");
|
2013-03-03 01:03:33 +00:00
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2013-11-26 05:03:00 +00:00
|
|
|
static_assert(sizeof(DiskBitmapHeader) == 0x12, "sizeof(DiskBitmapHeader) must be 0x12");
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
#define DISKBITMAPHEADER_D1_SIZE 17 // no wh_extra
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-22 22:03:07 +00:00
|
|
|
struct DiskSoundHeader
|
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
char name[8];
|
|
|
|
int length;
|
|
|
|
int data_length;
|
|
|
|
int offset;
|
2013-12-22 22:03:07 +00:00
|
|
|
} __pack__;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2013-09-22 22:26:27 +00:00
|
|
|
static void free_bitmap_replacements();
|
|
|
|
static void free_d1_tmap_nums();
|
|
|
|
#ifdef EDITOR
|
|
|
|
static int piggy_is_substitutable_bitmap( char * name, char * subst_name );
|
2013-10-06 16:20:00 +00:00
|
|
|
static void piggy_write_pigfile(const char *filename);
|
|
|
|
static void write_int(int i,PHYSFS_file *file);
|
2013-09-22 22:26:27 +00:00
|
|
|
#endif
|
|
|
|
static int piggy_is_needed(int soundnum);
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2008-11-14 16:56:40 +00:00
|
|
|
|
2006-03-20 17:12:09 +00:00
|
|
|
/*
|
2011-06-01 07:59:55 +00:00
|
|
|
* reads a DiskBitmapHeader structure from a PHYSFS_file
|
2006-03-20 17:12:09 +00:00
|
|
|
*/
|
2013-10-27 22:00:14 +00:00
|
|
|
static void DiskBitmapHeader_read(DiskBitmapHeader *dbh, PHYSFS_file *fp)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_read(fp, dbh->name, 8, 1);
|
|
|
|
dbh->dflags = PHYSFSX_readByte(fp);
|
|
|
|
dbh->width = PHYSFSX_readByte(fp);
|
|
|
|
dbh->height = PHYSFSX_readByte(fp);
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2011-06-01 07:59:55 +00:00
|
|
|
dbh->wh_extra = PHYSFSX_readByte(fp);
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2011-06-01 07:59:55 +00:00
|
|
|
dbh->flags = PHYSFSX_readByte(fp);
|
|
|
|
dbh->avg_color = PHYSFSX_readByte(fp);
|
|
|
|
dbh->offset = PHYSFSX_readInt(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2011-06-01 07:59:55 +00:00
|
|
|
* reads a DiskSoundHeader structure from a PHYSFS_file
|
2006-03-20 17:12:09 +00:00
|
|
|
*/
|
2013-10-27 22:00:14 +00:00
|
|
|
static void DiskSoundHeader_read(DiskSoundHeader *dsh, PHYSFS_file *fp)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_read(fp, dsh->name, 8, 1);
|
|
|
|
dsh->length = PHYSFSX_readInt(fp);
|
|
|
|
dsh->data_length = PHYSFSX_readInt(fp);
|
|
|
|
dsh->offset = PHYSFSX_readInt(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
/*
|
2011-06-01 07:59:55 +00:00
|
|
|
* reads a descent 1 DiskBitmapHeader structure from a PHYSFS_file
|
2006-03-20 17:12:09 +00:00
|
|
|
*/
|
2013-10-27 22:00:14 +00:00
|
|
|
static void DiskBitmapHeader_d1_read(DiskBitmapHeader *dbh, PHYSFS_file *fp)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_read(fp, dbh->name, 8, 1);
|
|
|
|
dbh->dflags = PHYSFSX_readByte(fp);
|
|
|
|
dbh->width = PHYSFSX_readByte(fp);
|
|
|
|
dbh->height = PHYSFSX_readByte(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
dbh->wh_extra = 0;
|
2011-06-01 07:59:55 +00:00
|
|
|
dbh->flags = PHYSFSX_readByte(fp);
|
|
|
|
dbh->avg_color = PHYSFSX_readByte(fp);
|
|
|
|
dbh->offset = PHYSFSX_readInt(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
void swap_0_255(grs_bitmap *bmp)
|
|
|
|
{
|
2014-11-30 22:09:22 +00:00
|
|
|
auto a = [](uint8_t &c) {
|
|
|
|
if (c == 0)
|
|
|
|
c = 255;
|
|
|
|
else if (c == 255)
|
|
|
|
c = 0;
|
|
|
|
};
|
2014-12-02 03:24:38 +00:00
|
|
|
auto d = bmp->get_bitmap_data();
|
2014-11-30 22:09:22 +00:00
|
|
|
std::for_each(d, d + (bmp->bm_h * bmp->bm_w), a);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
char* piggy_game_bitmap_name(grs_bitmap *bmp)
|
|
|
|
{
|
|
|
|
if (bmp >= GameBitmaps && bmp < &GameBitmaps[MAX_BITMAP_FILES])
|
|
|
|
{
|
|
|
|
int i = bmp-GameBitmaps; // i = (bmp - GameBitmaps) / sizeof(grs_bitmap);
|
|
|
|
Assert (bmp == &GameBitmaps[i] && i >= 0 && i < MAX_BITMAP_FILES);
|
|
|
|
return AllBitmaps[i].name;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-06-08 22:24:17 +00:00
|
|
|
bitmap_index piggy_register_bitmap( grs_bitmap * bmp, const char * name, int in_file )
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
bitmap_index temp;
|
|
|
|
Assert( Num_bitmap_files < MAX_BITMAP_FILES );
|
|
|
|
|
|
|
|
temp.index = Num_bitmap_files;
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
if (!in_file) {
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
#ifdef EDITOR
|
2007-07-15 01:15:36 +00:00
|
|
|
if ( GameArg.EdiMacData )
|
2006-03-20 17:12:09 +00:00
|
|
|
swap_0_255( bmp );
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
#endif
|
2013-11-10 17:13:36 +00:00
|
|
|
if ( GameArg.DbgNoCompressPigBitmap ) gr_bitmap_rle_compress( bmp );
|
2006-03-20 17:12:09 +00:00
|
|
|
Num_bitmap_files_new++;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2010-12-04 05:45:43 +00:00
|
|
|
else if (SoundOffset[Num_sound_files] == 0)
|
|
|
|
SoundOffset[Num_sound_files] = -1; // make sure this sound's data is not individually freed
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
strncpy( AllBitmaps[Num_bitmap_files].name, name, 12 );
|
|
|
|
hashtable_insert( &AllBitmapsNames, AllBitmaps[Num_bitmap_files].name, Num_bitmap_files );
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
GameBitmaps[Num_bitmap_files] = *bmp;
|
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
if ( !in_file ) {
|
|
|
|
GameBitmapOffset[Num_bitmap_files] = 0;
|
|
|
|
GameBitmapFlags[Num_bitmap_files] = bmp->bm_flags;
|
|
|
|
}
|
|
|
|
Num_bitmap_files++;
|
|
|
|
|
|
|
|
return temp;
|
|
|
|
}
|
|
|
|
|
2013-06-08 22:24:17 +00:00
|
|
|
int piggy_register_sound( digi_sound * snd, const char * name, int in_file )
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
Assert( Num_sound_files < MAX_SOUND_FILES );
|
|
|
|
|
|
|
|
strncpy( AllSounds[Num_sound_files].name, name, 12 );
|
|
|
|
hashtable_insert( &AllDigiSndNames, AllSounds[Num_sound_files].name, Num_sound_files );
|
|
|
|
GameSounds[Num_sound_files] = *snd;
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
//added/moved on 11/13/99 by Victor Rachels to ready for changing freq
|
|
|
|
//#ifdef ALLEGRO
|
|
|
|
GameSounds[Num_sound_files].bits = snd->bits;
|
|
|
|
GameSounds[Num_sound_files].freq = snd->freq;
|
|
|
|
|
|
|
|
#ifdef ALLEGRO
|
|
|
|
//end this section move - VR
|
|
|
|
GameSounds[Num_sound_files].priority = 128;
|
|
|
|
GameSounds[Num_sound_files].loop_start = 0;
|
|
|
|
GameSounds[Num_sound_files].loop_end = GameSounds[Num_sound_files].len;
|
|
|
|
GameSounds[Num_sound_files].param = -1;
|
|
|
|
#endif
|
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
if ( !in_file ) {
|
|
|
|
SoundOffset[Num_sound_files] = 0;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
else if (SoundOffset[Num_sound_files] == 0)
|
|
|
|
SoundOffset[Num_sound_files] = -1; // make sure this sound's data is not individually freed
|
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
i = Num_sound_files;
|
|
|
|
|
|
|
|
if (!in_file)
|
|
|
|
Num_sound_files_new++;
|
|
|
|
|
|
|
|
Num_sound_files++;
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
|
2014-07-26 23:51:39 +00:00
|
|
|
bitmap_index piggy_find_bitmap(const char * name)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
bitmap_index bmp;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
bmp.index = 0;
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2013-06-09 17:34:26 +00:00
|
|
|
size_t namelen;
|
2014-07-26 23:51:39 +00:00
|
|
|
const char *t;
|
2006-03-20 17:12:09 +00:00
|
|
|
if ((t=strchr(name,'#'))!=NULL)
|
2013-06-09 17:34:26 +00:00
|
|
|
namelen = t - name;
|
|
|
|
else
|
|
|
|
namelen = strlen(name);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
for (i=0;i<Num_aliases;i++)
|
2013-06-09 17:34:26 +00:00
|
|
|
if (alias_list[i].alias_name[namelen] == 0 && d_strnicmp(name,alias_list[i].alias_name,namelen)==0) {
|
2006-03-20 17:12:09 +00:00
|
|
|
if (t) { //extra stuff for ABMs
|
|
|
|
static char temp[FILENAME_LEN];
|
2013-06-09 18:10:09 +00:00
|
|
|
struct splitpath_t path;
|
|
|
|
d_splitpath(alias_list[i].file_name, &path);
|
|
|
|
snprintf(temp, sizeof(temp), "%.*s%s\n", (int)(path.base_end - path.base_start), path.base_start, t);
|
2006-03-20 17:12:09 +00:00
|
|
|
name = temp;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
name=alias_list[i].file_name;
|
|
|
|
break;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
i = hashtable_search( &AllBitmapsNames, name );
|
|
|
|
Assert( i != 0 );
|
|
|
|
if ( i < 0 )
|
|
|
|
return bmp;
|
|
|
|
|
|
|
|
bmp.index = i;
|
|
|
|
return bmp;
|
|
|
|
}
|
|
|
|
|
2014-07-26 23:51:39 +00:00
|
|
|
int piggy_find_sound(const char *name)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
i = hashtable_search( &AllDigiSndNames, name );
|
|
|
|
|
|
|
|
if ( i < 0 )
|
|
|
|
return 255;
|
|
|
|
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
|
2013-10-27 22:00:14 +00:00
|
|
|
static void piggy_close_file()
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
if ( Piggy_fp ) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close( Piggy_fp );
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_fp = NULL;
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
Current_pigfile[0] = 0;
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
int properties_init()
|
|
|
|
{
|
|
|
|
int sbytes = 0;
|
|
|
|
char temp_name_read[16];
|
|
|
|
char temp_name[16];
|
|
|
|
digi_sound temp_sound;
|
|
|
|
DiskBitmapHeader bmh;
|
|
|
|
DiskSoundHeader sndh;
|
|
|
|
int header_size, N_bitmaps, N_sounds;
|
|
|
|
int i,size;
|
|
|
|
int Pigdata_start;
|
|
|
|
int pigsize;
|
|
|
|
int retval;
|
|
|
|
for (i=0; i<MAX_SOUND_FILES; i++ ) {
|
|
|
|
#ifdef ALLEGRO
|
|
|
|
GameSounds[i].len = 0;
|
|
|
|
#else
|
|
|
|
GameSounds[i].length = 0;
|
|
|
|
#endif
|
|
|
|
GameSounds[i].data = NULL;
|
|
|
|
SoundOffset[i] = 0;
|
|
|
|
|
|
|
|
//added on 11/13/99 by Victor Rachels to ready for changing freq
|
|
|
|
GameSounds[i].bits = 0;
|
|
|
|
GameSounds[i].freq = 0;
|
|
|
|
//end this section addition - VR
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<MAX_BITMAP_FILES; i++ ) {
|
|
|
|
GameBitmapXlat[i] = i;
|
|
|
|
GameBitmaps[i].bm_flags = BM_FLAG_PAGED_OUT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( !bogus_bitmap_initialized ) {
|
|
|
|
int i;
|
|
|
|
ubyte c;
|
|
|
|
bogus_bitmap_initialized = 1;
|
|
|
|
c = gr_find_closest_color( 0, 0, 63 );
|
|
|
|
for (i=0; i<4096; i++ ) bogus_data[i] = c;
|
|
|
|
c = gr_find_closest_color( 63, 0, 0 );
|
|
|
|
// Make a big red X !
|
|
|
|
for (i=0; i<64; i++ ) {
|
|
|
|
bogus_data[i*64+i] = c;
|
|
|
|
bogus_data[i*64+(63-i)] = c;
|
|
|
|
}
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(bogus_bitmap, 0, 0, 0, 64, 64, 64, bogus_data);
|
2013-03-03 01:03:33 +00:00
|
|
|
piggy_register_bitmap( &bogus_bitmap, "bogus", 1 );
|
|
|
|
#ifdef ALLEGRO
|
|
|
|
bogus_sound.len = 64*64;
|
|
|
|
#else
|
|
|
|
bogus_sound.length = 64*64;
|
|
|
|
#endif
|
|
|
|
bogus_sound.data = bogus_data;
|
|
|
|
//added on 11/13/99 by Victor Rachels to ready for changing freq
|
|
|
|
bogus_sound.freq = 11025;
|
|
|
|
bogus_sound.bits = 8;
|
|
|
|
//end this section addition - VR
|
|
|
|
GameBitmapOffset[0] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
Piggy_fp = PHYSFSX_openReadBuffered(DEFAULT_PIGFILE_REGISTERED);
|
|
|
|
if (Piggy_fp==NULL)
|
|
|
|
{
|
|
|
|
if (!PHYSFSX_exists("BITMAPS.TBL",1) && !PHYSFSX_exists("BITMAPS.BIN",1))
|
|
|
|
Error("Cannot find " DEFAULT_PIGFILE_REGISTERED " or BITMAPS.TBL");
|
|
|
|
return 1; // need to run gamedata_read_tbl
|
|
|
|
}
|
|
|
|
|
|
|
|
pigsize = PHYSFS_fileLength(Piggy_fp);
|
|
|
|
switch (pigsize) {
|
|
|
|
case D1_SHARE_BIG_PIGSIZE:
|
|
|
|
case D1_SHARE_10_PIGSIZE:
|
|
|
|
case D1_SHARE_PIGSIZE:
|
|
|
|
PCSharePig = 1;
|
|
|
|
Pigdata_start = 0;
|
|
|
|
break;
|
|
|
|
case D1_10_BIG_PIGSIZE:
|
|
|
|
case D1_10_PIGSIZE:
|
|
|
|
Pigdata_start = 0;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
Warning("Unknown size for " DEFAULT_PIGFILE_REGISTERED);
|
|
|
|
Int3();
|
|
|
|
// fall through
|
|
|
|
case D1_MAC_PIGSIZE:
|
|
|
|
case D1_MAC_SHARE_PIGSIZE:
|
|
|
|
MacPig = 1;
|
|
|
|
case D1_PIGSIZE:
|
|
|
|
case D1_OEM_PIGSIZE:
|
|
|
|
Pigdata_start = PHYSFSX_readInt(Piggy_fp );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
HiresGFXAvailable = MacPig; // for now at least
|
|
|
|
|
|
|
|
if (PCSharePig)
|
|
|
|
retval = PIGGY_PC_SHAREWARE; // run gamedata_read_tbl in shareware mode
|
|
|
|
else if (GameArg.EdiNoBm || (!PHYSFSX_exists("BITMAPS.TBL",1) && !PHYSFSX_exists("BITMAPS.BIN",1)))
|
|
|
|
{
|
|
|
|
properties_read_cmp( Piggy_fp ); // Note connection to above if!!!
|
|
|
|
for (i = 0; i < MAX_BITMAP_FILES; i++)
|
|
|
|
{
|
|
|
|
GameBitmapXlat[i] = PHYSFSX_readShort(Piggy_fp);
|
|
|
|
if (PHYSFS_eof(Piggy_fp))
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
retval = 0; // don't run gamedata_read_tbl
|
|
|
|
}
|
|
|
|
else
|
|
|
|
retval = 1; // run gamedata_read_tbl
|
|
|
|
|
|
|
|
PHYSFSX_fseek( Piggy_fp, Pigdata_start, SEEK_SET );
|
|
|
|
size = PHYSFS_fileLength(Piggy_fp) - Pigdata_start;
|
|
|
|
|
|
|
|
N_bitmaps = PHYSFSX_readInt(Piggy_fp);
|
|
|
|
size -= sizeof(int);
|
|
|
|
N_sounds = PHYSFSX_readInt(Piggy_fp);
|
|
|
|
size -= sizeof(int);
|
|
|
|
|
|
|
|
header_size = (N_bitmaps*sizeof(DiskBitmapHeader)) + (N_sounds*sizeof(DiskSoundHeader));
|
|
|
|
|
|
|
|
for (i=0; i<N_bitmaps; i++ ) {
|
|
|
|
DiskBitmapHeader_read(&bmh, Piggy_fp);
|
|
|
|
|
|
|
|
GameBitmapFlags[i+1] = 0;
|
|
|
|
if ( bmh.flags & BM_FLAG_TRANSPARENT ) GameBitmapFlags[i+1] |= BM_FLAG_TRANSPARENT;
|
|
|
|
if ( bmh.flags & BM_FLAG_SUPER_TRANSPARENT ) GameBitmapFlags[i+1] |= BM_FLAG_SUPER_TRANSPARENT;
|
|
|
|
if ( bmh.flags & BM_FLAG_NO_LIGHTING ) GameBitmapFlags[i+1] |= BM_FLAG_NO_LIGHTING;
|
|
|
|
if ( bmh.flags & BM_FLAG_RLE ) GameBitmapFlags[i+1] |= BM_FLAG_RLE;
|
|
|
|
|
|
|
|
GameBitmapOffset[i+1] = bmh.offset + header_size + (sizeof(int)*2) + Pigdata_start;
|
|
|
|
Assert( (i+1) == Num_bitmap_files );
|
|
|
|
|
|
|
|
//size -= sizeof(DiskBitmapHeader);
|
|
|
|
memcpy( temp_name_read, bmh.name, 8 );
|
|
|
|
temp_name_read[8] = 0;
|
|
|
|
if ( bmh.dflags & DBM_FLAG_ABM )
|
|
|
|
sprintf( temp_name, "%s#%d", temp_name_read, bmh.dflags & 63 );
|
|
|
|
else
|
|
|
|
strcpy( temp_name, temp_name_read );
|
|
|
|
|
2014-07-04 04:15:35 +00:00
|
|
|
grs_bitmap temp_bitmap{};
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(temp_bitmap, 0, 0, 0,
|
2013-03-03 01:03:33 +00:00
|
|
|
(bmh.dflags & DBM_FLAG_LARGE) ? bmh.width + 256 : bmh.width, bmh.height,
|
|
|
|
(bmh.dflags & DBM_FLAG_LARGE) ? bmh.width + 256 : bmh.width, Piggy_bitmap_cache_data);
|
|
|
|
temp_bitmap.bm_flags |= BM_FLAG_PAGED_OUT;
|
|
|
|
temp_bitmap.avg_color = bmh.avg_color;
|
|
|
|
|
|
|
|
if (MacPig)
|
|
|
|
{
|
|
|
|
// HACK HACK HACK!!!!!
|
|
|
|
if (!d_strnicmp(bmh.name, "cockpit", 7) || !d_strnicmp(bmh.name, "status", 6) || !d_strnicmp(bmh.name, "rearview", 8)) {
|
|
|
|
temp_bitmap.bm_w = temp_bitmap.bm_rowsize = 640;
|
|
|
|
if (GameBitmapFlags[i+1] & BM_FLAG_RLE)
|
|
|
|
GameBitmapFlags[i+1] |= BM_FLAG_RLE_BIG;
|
|
|
|
}
|
|
|
|
if (!d_strnicmp(bmh.name, "cockpit", 7) || !d_strnicmp(bmh.name, "rearview", 8))
|
|
|
|
temp_bitmap.bm_h = 480;
|
|
|
|
}
|
|
|
|
|
|
|
|
piggy_register_bitmap( &temp_bitmap, temp_name, 1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; !MacPig && i<N_sounds; i++ ) {
|
|
|
|
DiskSoundHeader_read(&sndh, Piggy_fp);
|
|
|
|
|
|
|
|
//size -= sizeof(DiskSoundHeader);
|
|
|
|
#ifdef ALLEGRO
|
|
|
|
temp_sound.len = sndh.length;
|
|
|
|
#else
|
|
|
|
temp_sound.length = sndh.length;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//added on 11/13/99 by Victor Rachels to ready for changing freq
|
|
|
|
temp_sound.bits = 8;
|
|
|
|
temp_sound.freq = 11025;
|
|
|
|
//end this section addition - VR
|
|
|
|
temp_sound.data = (ubyte *)(sndh.offset + header_size + (sizeof(int)*2)+Pigdata_start);
|
|
|
|
SoundOffset[Num_sound_files] = sndh.offset + header_size + (sizeof(int)*2)+Pigdata_start;
|
|
|
|
if (PCSharePig)
|
|
|
|
SoundCompressed[Num_sound_files] = sndh.data_length;
|
|
|
|
memcpy( temp_name_read, sndh.name, 8 );
|
|
|
|
temp_name_read[8] = 0;
|
|
|
|
piggy_register_sound( &temp_sound, temp_name_read, 1 );
|
|
|
|
sbytes += sndh.length;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!MacPig)
|
|
|
|
{
|
2014-08-16 04:15:16 +00:00
|
|
|
SoundBits = make_unique<ubyte[]>(sbytes + 16);
|
2013-03-03 01:03:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#if 1 //def EDITOR
|
|
|
|
Piggy_bitmap_cache_size = size - header_size - sbytes + 16;
|
|
|
|
Assert( Piggy_bitmap_cache_size > 0 );
|
|
|
|
#else
|
|
|
|
Piggy_bitmap_cache_size = PIGGY_BUFFER_SIZE;
|
|
|
|
if (GameArg.SysLowMem)
|
|
|
|
Piggy_bitmap_cache_size = PIGGY_SMALL_BUFFER_SIZE;
|
|
|
|
#endif
|
2014-08-16 04:15:16 +00:00
|
|
|
BitmapBits = make_unique<ubyte[]>(Piggy_bitmap_cache_size);
|
2014-07-24 02:45:47 +00:00
|
|
|
Piggy_bitmap_cache_data = BitmapBits.get();
|
2013-03-03 01:03:33 +00:00
|
|
|
Piggy_bitmap_cache_next = 0;
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
//initialize a pigfile, reading headers
|
|
|
|
//returns the size of all the bitmap data
|
2012-11-11 00:14:30 +00:00
|
|
|
void piggy_init_pigfile(const char *filename)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
char temp_name[16];
|
|
|
|
char temp_name_read[16];
|
|
|
|
DiskBitmapHeader bmh;
|
2011-09-26 23:31:19 +00:00
|
|
|
int header_size, N_bitmaps, data_start;
|
|
|
|
#ifdef EDITOR
|
|
|
|
int data_size;
|
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
piggy_close_file(); //close old pig if still open
|
|
|
|
|
2010-09-25 03:35:23 +00:00
|
|
|
Piggy_fp = PHYSFSX_openReadBuffered(filename);
|
2007-05-20 02:00:57 +00:00
|
|
|
|
|
|
|
//try pigfile for shareware
|
|
|
|
if (!Piggy_fp)
|
2010-09-25 03:35:23 +00:00
|
|
|
Piggy_fp = PHYSFSX_openReadBuffered(DEFAULT_PIGFILE_SHAREWARE);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (Piggy_fp) { //make sure pig is valid type file & is up-to-date
|
|
|
|
int pig_id,pig_version;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
pig_id = PHYSFSX_readInt(Piggy_fp);
|
|
|
|
pig_version = PHYSFSX_readInt(Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
if (pig_id != PIGFILE_ID || pig_version != PIGFILE_VERSION) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(Piggy_fp); //out of date pig
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_fp = NULL; //..so pretend it's not here
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!Piggy_fp) {
|
|
|
|
|
|
|
|
#ifdef EDITOR
|
|
|
|
return; //if editor, ok to not have pig, because we'll build one
|
|
|
|
#else
|
|
|
|
Error("Cannot load required file <%s>",filename);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
strncpy(Current_pigfile,filename,sizeof(Current_pigfile));
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
N_bitmaps = PHYSFSX_readInt(Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
header_size = N_bitmaps * sizeof(DiskBitmapHeader);
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
data_start = header_size + PHYSFS_tell(Piggy_fp);
|
2011-09-26 23:31:19 +00:00
|
|
|
#ifdef EDITOR
|
2011-06-01 07:59:55 +00:00
|
|
|
data_size = PHYSFS_fileLength(Piggy_fp) - data_start;
|
2011-09-26 23:31:19 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
Num_bitmap_files = 1;
|
|
|
|
|
|
|
|
for (i=0; i<N_bitmaps; i++ )
|
2013-02-21 00:20:26 +00:00
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
int width;
|
|
|
|
grs_bitmap *bm = &GameBitmaps[i + 1];
|
|
|
|
|
|
|
|
DiskBitmapHeader_read(&bmh, Piggy_fp);
|
|
|
|
memcpy( temp_name_read, bmh.name, 8 );
|
|
|
|
temp_name_read[8] = 0;
|
|
|
|
if ( bmh.dflags & DBM_FLAG_ABM )
|
|
|
|
sprintf( temp_name, "%s#%d", temp_name_read, bmh.dflags & DBM_NUM_FRAMES );
|
|
|
|
else
|
|
|
|
strcpy( temp_name, temp_name_read );
|
|
|
|
width = bmh.width + ((short) (bmh.wh_extra & 0x0f) << 8);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(*bm, 0, 0, 0, width, bmh.height + ((short) (bmh.wh_extra & 0xf0) << 4), width, NULL);
|
2006-03-20 17:12:09 +00:00
|
|
|
bm->bm_flags = BM_FLAG_PAGED_OUT;
|
|
|
|
bm->avg_color = bmh.avg_color;
|
|
|
|
|
|
|
|
GameBitmapFlags[i+1] = bmh.flags & BM_FLAGS_TO_COPY;
|
|
|
|
|
|
|
|
GameBitmapOffset[i+1] = bmh.offset + data_start;
|
|
|
|
Assert( (i+1) == Num_bitmap_files );
|
|
|
|
piggy_register_bitmap(bm, temp_name, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef EDITOR
|
|
|
|
Piggy_bitmap_cache_size = data_size + (data_size/10); //extra mem for new bitmaps
|
|
|
|
Assert( Piggy_bitmap_cache_size > 0 );
|
|
|
|
#else
|
|
|
|
Piggy_bitmap_cache_size = PIGGY_BUFFER_SIZE;
|
2007-07-14 20:33:42 +00:00
|
|
|
if (GameArg.SysLowMem)
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_bitmap_cache_size = PIGGY_SMALL_BUFFER_SIZE;
|
|
|
|
#endif
|
2014-08-16 04:15:16 +00:00
|
|
|
BitmapBits = make_unique<ubyte[]>(Piggy_bitmap_cache_size);
|
2014-07-24 02:45:47 +00:00
|
|
|
Piggy_bitmap_cache_data = BitmapBits.get();
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_bitmap_cache_next = 0;
|
|
|
|
|
|
|
|
Pigfile_initialized=1;
|
|
|
|
}
|
|
|
|
|
|
|
|
//reads in a new pigfile (for new palette)
|
|
|
|
//returns the size of all the bitmap data
|
|
|
|
void piggy_new_pigfile(char *pigname)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
char temp_name[16];
|
|
|
|
char temp_name_read[16];
|
|
|
|
DiskBitmapHeader bmh;
|
2011-09-26 23:31:19 +00:00
|
|
|
int header_size, N_bitmaps, data_start;
|
|
|
|
#ifdef EDITOR
|
2006-03-20 17:12:09 +00:00
|
|
|
int must_rewrite_pig = 0;
|
2011-09-26 23:31:19 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2012-05-18 23:36:43 +00:00
|
|
|
d_strlwr(pigname);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2012-05-18 23:36:43 +00:00
|
|
|
if (d_strnicmp(Current_pigfile, pigname, sizeof(Current_pigfile)) == 0 // correct pig already loaded
|
2006-03-20 17:12:09 +00:00
|
|
|
&& !Bitmap_replacement_data) // no need to reload: no bitmaps were altered
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (!Pigfile_initialized) { //have we ever opened a pigfile?
|
|
|
|
piggy_init_pigfile(pigname); //..no, so do initialization stuff
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
piggy_close_file(); //close old pig if still open
|
|
|
|
|
|
|
|
Piggy_bitmap_cache_next = 0; //free up cache
|
|
|
|
|
|
|
|
strncpy(Current_pigfile,pigname,sizeof(Current_pigfile));
|
|
|
|
|
2010-09-25 03:35:23 +00:00
|
|
|
Piggy_fp = PHYSFSX_openReadBuffered(pigname);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2007-05-20 02:00:57 +00:00
|
|
|
//try pigfile for shareware
|
2006-03-20 17:12:09 +00:00
|
|
|
if (!Piggy_fp)
|
2010-09-25 03:35:23 +00:00
|
|
|
Piggy_fp = PHYSFSX_openReadBuffered(DEFAULT_PIGFILE_SHAREWARE);
|
2007-05-20 02:00:57 +00:00
|
|
|
|
2006-03-20 17:12:09 +00:00
|
|
|
if (Piggy_fp) { //make sure pig is valid type file & is up-to-date
|
|
|
|
int pig_id,pig_version;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
pig_id = PHYSFSX_readInt(Piggy_fp);
|
|
|
|
pig_version = PHYSFSX_readInt(Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
if (pig_id != PIGFILE_ID || pig_version != PIGFILE_VERSION) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(Piggy_fp); //out of date pig
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_fp = NULL; //..so pretend it's not here
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef EDITOR
|
|
|
|
if (!Piggy_fp)
|
|
|
|
Error("Cannot open correct version of <%s>", pigname);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (Piggy_fp) {
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
N_bitmaps = PHYSFSX_readInt(Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
header_size = N_bitmaps * sizeof(DiskBitmapHeader);
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
data_start = header_size + PHYSFS_tell(Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
for (i=1; i<=N_bitmaps; i++ )
|
|
|
|
{
|
|
|
|
grs_bitmap *bm = &GameBitmaps[i];
|
|
|
|
int width;
|
|
|
|
|
|
|
|
DiskBitmapHeader_read(&bmh, Piggy_fp);
|
|
|
|
memcpy( temp_name_read, bmh.name, 8 );
|
|
|
|
temp_name_read[8] = 0;
|
|
|
|
|
|
|
|
if ( bmh.dflags & DBM_FLAG_ABM )
|
|
|
|
sprintf( temp_name, "%s#%d", temp_name_read, bmh.dflags & DBM_NUM_FRAMES );
|
|
|
|
else
|
|
|
|
strcpy( temp_name, temp_name_read );
|
2011-09-26 23:31:19 +00:00
|
|
|
|
|
|
|
#ifdef EDITOR
|
2006-03-20 17:12:09 +00:00
|
|
|
//Make sure name matches
|
|
|
|
if (strcmp(temp_name,AllBitmaps[i].name)) {
|
|
|
|
//Int3(); //this pig is out of date. Delete it
|
|
|
|
must_rewrite_pig=1;
|
|
|
|
}
|
2011-09-26 23:31:19 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
strcpy(AllBitmaps[i].name,temp_name);
|
|
|
|
|
|
|
|
width = bmh.width + ((short) (bmh.wh_extra & 0x0f) << 8);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bm, NULL); // free ogl texture
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(*bm, 0, 0, 0, width, bmh.height + ((short) (bmh.wh_extra & 0xf0) << 4), width, NULL);
|
2006-03-20 17:12:09 +00:00
|
|
|
bm->bm_flags = BM_FLAG_PAGED_OUT;
|
|
|
|
bm->avg_color = bmh.avg_color;
|
|
|
|
|
|
|
|
GameBitmapFlags[i] = bmh.flags & BM_FLAGS_TO_COPY;
|
|
|
|
|
|
|
|
GameBitmapOffset[i] = bmh.offset + data_start;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
N_bitmaps = 0; //no pigfile, so no bitmaps
|
|
|
|
|
|
|
|
#ifndef EDITOR
|
|
|
|
|
|
|
|
Assert(N_bitmaps == Num_bitmap_files-1);
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
if (must_rewrite_pig || (N_bitmaps < Num_bitmap_files-1)) {
|
|
|
|
int size;
|
|
|
|
|
|
|
|
//re-read the bitmaps that aren't in this pig
|
|
|
|
|
|
|
|
for (i=N_bitmaps+1;i<Num_bitmap_files;i++) {
|
|
|
|
char *p;
|
|
|
|
|
|
|
|
p = strchr(AllBitmaps[i].name,'#');
|
|
|
|
|
|
|
|
if (p) { // this is an ABM == animated bitmap
|
|
|
|
char abmname[FILENAME_LEN];
|
2012-11-18 18:20:13 +00:00
|
|
|
unsigned fnum;
|
2006-03-20 17:12:09 +00:00
|
|
|
int iff_error; //reference parm to avoid warning message
|
2013-01-06 21:03:57 +00:00
|
|
|
palette_array_t newpal;
|
2006-03-20 17:12:09 +00:00
|
|
|
char basename[FILENAME_LEN];
|
2012-11-18 18:20:13 +00:00
|
|
|
unsigned nframes;
|
|
|
|
|
2006-03-20 17:12:09 +00:00
|
|
|
strcpy(basename,AllBitmaps[i].name);
|
|
|
|
basename[p-AllBitmaps[i].name] = 0; //cut off "#nn" part
|
|
|
|
|
|
|
|
sprintf( abmname, "%s.abm", basename );
|
|
|
|
|
2014-10-04 15:02:03 +00:00
|
|
|
array<std::unique_ptr<grs_bitmap>, MAX_BITMAPS_PER_BRUSH> bm;
|
2014-09-27 23:06:33 +00:00
|
|
|
iff_error = iff_read_animbrush(abmname,bm,&nframes,newpal);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (iff_error != IFF_NO_ERROR) {
|
|
|
|
Error("File %s - IFF error: %s",abmname,iff_errormsg(iff_error));
|
|
|
|
}
|
|
|
|
|
|
|
|
for (fnum=0;fnum<nframes; fnum++) {
|
|
|
|
char tempname[20];
|
|
|
|
int SuperX;
|
|
|
|
|
2014-01-07 21:01:33 +00:00
|
|
|
sprintf( tempname, "%s#%u", basename, fnum );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
//SuperX = (GameBitmaps[i+fnum].bm_flags&BM_FLAG_SUPER_TRANSPARENT)?254:-1;
|
|
|
|
SuperX = (GameBitmapFlags[i+fnum]&BM_FLAG_SUPER_TRANSPARENT)?254:-1;
|
|
|
|
//above makes assumption that supertransparent color is 254
|
|
|
|
|
|
|
|
if ( iff_has_transparency )
|
2014-09-27 23:14:50 +00:00
|
|
|
gr_remap_bitmap_good( bm[fnum].get(), newpal, iff_transparent_color, SuperX );
|
2006-03-20 17:12:09 +00:00
|
|
|
else
|
2014-09-27 23:14:50 +00:00
|
|
|
gr_remap_bitmap_good( bm[fnum].get(), newpal, -1, SuperX );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2014-09-27 23:14:50 +00:00
|
|
|
bm[fnum]->avg_color = compute_average_pixel(bm[fnum].get());
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2007-07-22 20:40:39 +00:00
|
|
|
if ( GameArg.EdiMacData )
|
2014-09-27 23:14:50 +00:00
|
|
|
swap_0_255( bm[fnum].get() );
|
2007-08-08 12:38:13 +00:00
|
|
|
|
2014-09-27 23:14:50 +00:00
|
|
|
if ( GameArg.DbgNoCompressPigBitmap ) gr_bitmap_rle_compress( bm[fnum].get() );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (bm[fnum]->bm_flags & BM_FLAG_RLE)
|
|
|
|
size = *((int *) bm[fnum]->bm_data);
|
|
|
|
else
|
|
|
|
size = bm[fnum]->bm_w * bm[fnum]->bm_h;
|
|
|
|
|
|
|
|
memcpy( &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next],bm[fnum]->bm_data,size);
|
2014-12-02 03:24:38 +00:00
|
|
|
d_free(bm[fnum]->bm_mdata);
|
|
|
|
bm[fnum]->bm_mdata = &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next];
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_bitmap_cache_next += size;
|
|
|
|
|
2014-10-04 15:02:03 +00:00
|
|
|
GameBitmaps[i+fnum] = std::move(*bm[fnum]);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
i += nframes-1; //filled in multiple bitmaps
|
|
|
|
}
|
|
|
|
else { //this is a BBM
|
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
grs_bitmap n;
|
2013-01-06 21:03:57 +00:00
|
|
|
palette_array_t newpal;
|
2006-03-20 17:12:09 +00:00
|
|
|
int iff_error;
|
|
|
|
char bbmname[FILENAME_LEN];
|
|
|
|
int SuperX;
|
|
|
|
|
|
|
|
sprintf( bbmname, "%s.bbm", AllBitmaps[i].name );
|
2013-01-06 21:03:57 +00:00
|
|
|
iff_error = iff_read_bitmap(bbmname,&n,BM_LINEAR,&newpal);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
n.bm_handle=0;
|
2006-03-20 17:12:09 +00:00
|
|
|
if (iff_error != IFF_NO_ERROR) {
|
|
|
|
Error("File %s - IFF error: %s",bbmname,iff_errormsg(iff_error));
|
|
|
|
}
|
|
|
|
|
|
|
|
SuperX = (GameBitmapFlags[i]&BM_FLAG_SUPER_TRANSPARENT)?254:-1;
|
|
|
|
//above makes assumption that supertransparent color is 254
|
|
|
|
|
|
|
|
if ( iff_has_transparency )
|
2013-12-08 17:05:51 +00:00
|
|
|
gr_remap_bitmap_good( &n, newpal, iff_transparent_color, SuperX );
|
2006-03-20 17:12:09 +00:00
|
|
|
else
|
2013-12-08 17:05:51 +00:00
|
|
|
gr_remap_bitmap_good( &n, newpal, -1, SuperX );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
n.avg_color = compute_average_pixel(&n);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2007-07-22 20:40:39 +00:00
|
|
|
if ( GameArg.EdiMacData )
|
2013-12-08 17:05:51 +00:00
|
|
|
swap_0_255( &n );
|
2007-08-08 12:38:13 +00:00
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
if ( GameArg.DbgNoCompressPigBitmap ) gr_bitmap_rle_compress( &n );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
if (n.bm_flags & BM_FLAG_RLE)
|
|
|
|
size = *((int *) n.bm_data);
|
2006-03-20 17:12:09 +00:00
|
|
|
else
|
2013-12-08 17:05:51 +00:00
|
|
|
size = n.bm_w * n.bm_h;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
memcpy( &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next],n.bm_data,size);
|
2014-12-02 03:24:38 +00:00
|
|
|
d_free(n.bm_mdata);
|
|
|
|
n.bm_mdata = &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next];
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_bitmap_cache_next += size;
|
|
|
|
|
2013-12-08 17:05:51 +00:00
|
|
|
GameBitmaps[i] = n;
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//@@Dont' do these things which are done when writing
|
|
|
|
//@@for (i=0; i < Num_bitmap_files; i++ ) {
|
|
|
|
//@@ bitmap_index bi;
|
|
|
|
//@@ bi.index = i;
|
|
|
|
//@@ PIGGY_PAGE_IN( bi );
|
|
|
|
//@@}
|
|
|
|
//@@
|
|
|
|
//@@piggy_close_file();
|
|
|
|
|
|
|
|
piggy_write_pigfile(pigname);
|
|
|
|
|
|
|
|
Current_pigfile[0] = 0; //say no pig, to force reload
|
|
|
|
|
|
|
|
piggy_new_pigfile(pigname); //read in just-generated pig
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif //ifdef EDITOR
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#define HAMFILE_ID MAKE_SIG('!','M','A','H') //HAM!
|
|
|
|
#define HAMFILE_VERSION 3
|
|
|
|
//version 1 -> 2: save marker_model_num
|
|
|
|
//version 2 -> 3: removed sound files
|
|
|
|
|
|
|
|
#define SNDFILE_ID MAKE_SIG('D','N','S','D') //DSND
|
|
|
|
#define SNDFILE_VERSION 1
|
|
|
|
|
|
|
|
int read_hamfile()
|
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file * ham_fp = NULL;
|
2006-03-20 17:12:09 +00:00
|
|
|
int ham_id;
|
|
|
|
int sound_offset = 0;
|
2008-10-31 13:09:30 +00:00
|
|
|
int shareware = 0;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2010-09-25 03:35:23 +00:00
|
|
|
ham_fp = PHYSFSX_openReadBuffered(DEFAULT_HAMFILE_REGISTERED);
|
2007-05-20 02:00:57 +00:00
|
|
|
|
|
|
|
if (!ham_fp)
|
2008-11-20 12:29:48 +00:00
|
|
|
{
|
2010-09-25 03:35:23 +00:00
|
|
|
ham_fp = PHYSFSX_openReadBuffered(DEFAULT_HAMFILE_SHAREWARE);
|
2008-11-20 12:29:48 +00:00
|
|
|
if (ham_fp)
|
|
|
|
{
|
|
|
|
shareware = 1;
|
|
|
|
GameArg.SndDigiSampleRate = SAMPLE_RATE_11K;
|
2013-06-27 09:41:46 +00:00
|
|
|
#ifdef USE_SDLMIXER
|
|
|
|
if (GameArg.SndDisableSdlMixer)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
digi_close();
|
|
|
|
digi_init();
|
|
|
|
}
|
2008-11-20 12:29:48 +00:00
|
|
|
}
|
|
|
|
}
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (ham_fp == NULL) {
|
|
|
|
Must_write_hamfile = 1;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
//make sure ham is valid type file & is up-to-date
|
2011-06-01 07:59:55 +00:00
|
|
|
ham_id = PHYSFSX_readInt(ham_fp);
|
|
|
|
Piggy_hamfile_version = PHYSFSX_readInt(ham_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
if (ham_id != HAMFILE_ID)
|
2007-05-20 02:00:57 +00:00
|
|
|
Error("Cannot open ham file %s or %s\n", DEFAULT_HAMFILE_REGISTERED, DEFAULT_HAMFILE_SHAREWARE);
|
2006-03-20 17:12:09 +00:00
|
|
|
#if 0
|
|
|
|
if (ham_id != HAMFILE_ID || Piggy_hamfile_version != HAMFILE_VERSION) {
|
|
|
|
Must_write_hamfile = 1;
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(ham_fp); //out of date ham
|
2006-03-20 17:12:09 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2008-10-31 13:09:30 +00:00
|
|
|
if (Piggy_hamfile_version < 3) // hamfile contains sound info, probably PC demo
|
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
sound_offset = PHYSFSX_readInt(ham_fp);
|
2008-10-31 13:09:30 +00:00
|
|
|
|
|
|
|
if (shareware) // deal with interactive PC demo
|
|
|
|
{
|
2013-11-10 16:38:06 +00:00
|
|
|
GameArg.GfxSkipHiresGFX = 1;
|
2011-06-04 09:35:41 +00:00
|
|
|
//GameArg.SysLowMem = 1;
|
2008-10-31 13:09:30 +00:00
|
|
|
}
|
|
|
|
}
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
#if 1 //ndef EDITOR
|
|
|
|
{
|
2008-10-31 13:09:30 +00:00
|
|
|
int i;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
bm_read_all(ham_fp);
|
2011-06-01 07:59:55 +00:00
|
|
|
//PHYSFS_read( ham_fp, GameBitmapXlat, sizeof(ushort)*MAX_BITMAP_FILES, 1 );
|
2008-10-31 13:09:30 +00:00
|
|
|
for (i = 0; i < MAX_BITMAP_FILES; i++)
|
2008-11-01 01:19:52 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
GameBitmapXlat[i] = PHYSFSX_readShort(ham_fp);
|
2008-11-01 01:19:52 +00:00
|
|
|
if (PHYSFS_eof(ham_fp))
|
|
|
|
break;
|
|
|
|
}
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (Piggy_hamfile_version < 3) {
|
|
|
|
int N_sounds;
|
|
|
|
int sound_start;
|
|
|
|
int header_size;
|
|
|
|
int i;
|
|
|
|
DiskSoundHeader sndh;
|
|
|
|
digi_sound temp_sound;
|
|
|
|
char temp_name_read[16];
|
|
|
|
int sbytes = 0;
|
2011-02-24 10:28:59 +00:00
|
|
|
static int justonce = 1;
|
|
|
|
|
|
|
|
if (!justonce)
|
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(ham_fp);
|
2011-02-24 10:28:59 +00:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
justonce = 0;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek(ham_fp, sound_offset, SEEK_SET);
|
|
|
|
N_sounds = PHYSFSX_readInt(ham_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
sound_start = PHYSFS_tell(ham_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
header_size = N_sounds * sizeof(DiskSoundHeader);
|
|
|
|
|
|
|
|
//Read sounds
|
|
|
|
|
|
|
|
for (i=0; i<N_sounds; i++ ) {
|
|
|
|
DiskSoundHeader_read(&sndh, ham_fp);
|
|
|
|
temp_sound.length = sndh.length;
|
2007-06-14 12:32:18 +00:00
|
|
|
temp_sound.data = (ubyte *)(size_t)(sndh.offset + header_size + sound_start);
|
2006-03-20 17:12:09 +00:00
|
|
|
SoundOffset[Num_sound_files] = sndh.offset + header_size + sound_start;
|
|
|
|
memcpy( temp_name_read, sndh.name, 8 );
|
|
|
|
temp_name_read[8] = 0;
|
|
|
|
piggy_register_sound( &temp_sound, temp_name_read, 1 );
|
|
|
|
if (piggy_is_needed(i))
|
|
|
|
sbytes += sndh.length;
|
|
|
|
}
|
2014-08-16 04:15:16 +00:00
|
|
|
SoundBits = make_unique<ubyte[]>(sbytes + 16);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(ham_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2013-10-27 22:00:14 +00:00
|
|
|
static int read_sndfile()
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file * snd_fp = NULL;
|
2006-03-20 17:12:09 +00:00
|
|
|
int snd_id,snd_version;
|
|
|
|
int N_sounds;
|
|
|
|
int sound_start;
|
|
|
|
int header_size;
|
2011-09-26 23:31:19 +00:00
|
|
|
int i;
|
2006-03-20 17:12:09 +00:00
|
|
|
DiskSoundHeader sndh;
|
|
|
|
digi_sound temp_sound;
|
|
|
|
char temp_name_read[16];
|
|
|
|
int sbytes = 0;
|
|
|
|
|
2010-09-25 03:35:23 +00:00
|
|
|
snd_fp = PHYSFSX_openReadBuffered(DEFAULT_SNDFILE);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (snd_fp == NULL)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
//make sure soundfile is valid type file & is up-to-date
|
2011-06-01 07:59:55 +00:00
|
|
|
snd_id = PHYSFSX_readInt(snd_fp);
|
|
|
|
snd_version = PHYSFSX_readInt(snd_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
if (snd_id != SNDFILE_ID || snd_version != SNDFILE_VERSION) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(snd_fp); //out of date sound file
|
2006-03-20 17:12:09 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
N_sounds = PHYSFSX_readInt(snd_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
sound_start = PHYSFS_tell(snd_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
header_size = N_sounds*sizeof(DiskSoundHeader);
|
|
|
|
|
|
|
|
//Read sounds
|
|
|
|
|
|
|
|
for (i=0; i<N_sounds; i++ ) {
|
|
|
|
DiskSoundHeader_read(&sndh, snd_fp);
|
|
|
|
temp_sound.length = sndh.length;
|
2007-06-14 12:32:18 +00:00
|
|
|
temp_sound.data = (ubyte *)(size_t)(sndh.offset + header_size + sound_start);
|
2006-03-20 17:12:09 +00:00
|
|
|
SoundOffset[Num_sound_files] = sndh.offset + header_size + sound_start;
|
|
|
|
memcpy( temp_name_read, sndh.name, 8 );
|
|
|
|
temp_name_read[8] = 0;
|
|
|
|
piggy_register_sound( &temp_sound, temp_name_read, 1 );
|
|
|
|
if (piggy_is_needed(i))
|
2008-12-07 12:26:43 +00:00
|
|
|
sbytes += sndh.length;
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
2014-08-16 04:15:16 +00:00
|
|
|
SoundBits = make_unique<ubyte[]>(sbytes + 16);
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(snd_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2008-02-11 12:12:57 +00:00
|
|
|
int properties_init(void)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int ham_ok=0,snd_ok=0;
|
|
|
|
int i;
|
|
|
|
for (i=0; i<MAX_SOUND_FILES; i++ ) {
|
|
|
|
GameSounds[i].length = 0;
|
|
|
|
GameSounds[i].data = NULL;
|
|
|
|
SoundOffset[i] = 0;
|
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
for (i=0; i<MAX_BITMAP_FILES; i++ ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
GameBitmapXlat[i] = i;
|
2013-03-03 01:03:33 +00:00
|
|
|
}
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if ( !bogus_bitmap_initialized ) {
|
|
|
|
int i;
|
|
|
|
ubyte c;
|
|
|
|
|
|
|
|
bogus_bitmap_initialized = 1;
|
|
|
|
c = gr_find_closest_color( 0, 0, 63 );
|
|
|
|
for (i=0; i<4096; i++ ) bogus_data[i] = c;
|
|
|
|
c = gr_find_closest_color( 63, 0, 0 );
|
|
|
|
// Make a big red X !
|
|
|
|
for (i=0; i<64; i++ ) {
|
|
|
|
bogus_data[i*64+i] = c;
|
|
|
|
bogus_data[i*64+(63-i)] = c;
|
|
|
|
}
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(GameBitmaps[Num_bitmap_files], 0, 0, 0, 64, 64, 64, bogus_data);
|
2006-03-20 17:12:09 +00:00
|
|
|
piggy_register_bitmap(&GameBitmaps[Num_bitmap_files], "bogus", 1);
|
|
|
|
bogus_sound.length = 64*64;
|
|
|
|
bogus_sound.data = bogus_data;
|
|
|
|
GameBitmapOffset[0] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
snd_ok = ham_ok = read_hamfile();
|
|
|
|
|
|
|
|
if (Piggy_hamfile_version >= 3)
|
2010-03-26 21:17:56 +00:00
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
snd_ok = read_sndfile();
|
2010-03-26 21:17:56 +00:00
|
|
|
if (!snd_ok)
|
|
|
|
Error("Cannot open sound file: %s\n", DEFAULT_SNDFILE);
|
|
|
|
}
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
return (ham_ok && snd_ok); //read ok
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
static int piggy_is_needed(int soundnum)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2007-07-22 20:40:39 +00:00
|
|
|
if ( !GameArg.SysLowMem ) return 1;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
for (i=0; i<MAX_SOUNDS; i++ ) {
|
|
|
|
if ( (AltSounds[i] < 255) && (Sounds[AltSounds[i]] == soundnum) )
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
void piggy_read_sounds(int pc_shareware)
|
|
|
|
{
|
|
|
|
ubyte * ptr;
|
|
|
|
int i, sbytes;
|
|
|
|
int lastsize = 0;
|
|
|
|
|
|
|
|
if (MacPig)
|
|
|
|
{
|
|
|
|
// Read Mac sounds converted to RAW format (too messy to read them directly from the resource fork code-wise)
|
|
|
|
char soundfile[32] = "Sounds/sounds.array";
|
|
|
|
PHYSFS_file *array = PHYSFSX_openReadBuffered(soundfile); // hack for Mac Demo
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
if (!array && (PHYSFSX_fsize(DEFAULT_PIGFILE_REGISTERED) == D1_MAC_SHARE_PIGSIZE))
|
|
|
|
{
|
|
|
|
con_printf(CON_URGENT,"Warning: Missing Sounds/sounds.array for Mac data files");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else if (array)
|
|
|
|
{
|
|
|
|
if (PHYSFS_read(array, Sounds, MAX_SOUNDS, 1) != 1) // make the 'Sounds' index array match with the sounds we're about to read in
|
|
|
|
{
|
|
|
|
con_printf(CON_URGENT,"Warning: Can't read Sounds/sounds.array: %s", PHYSFS_getLastError());
|
|
|
|
PHYSFS_close(array);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
PHYSFS_close(array);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < MAX_SOUND_FILES; i++)
|
|
|
|
{
|
|
|
|
sprintf(soundfile, "SND%04d.raw", i);
|
|
|
|
if (ds_load(0, soundfile) == 255)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-24 02:45:47 +00:00
|
|
|
ptr = SoundBits.get();
|
2013-03-03 01:03:33 +00:00
|
|
|
sbytes = 0;
|
|
|
|
|
2013-12-08 18:22:17 +00:00
|
|
|
RAIIdubyte lastbuf;
|
2013-03-03 01:03:33 +00:00
|
|
|
for (i=0; i<Num_sound_files; i++ )
|
|
|
|
{
|
|
|
|
digi_sound *snd = &GameSounds[i];
|
|
|
|
|
|
|
|
if ( SoundOffset[i] > 0 )
|
|
|
|
{
|
|
|
|
if ( piggy_is_needed(i) )
|
|
|
|
{
|
|
|
|
PHYSFSX_fseek( Piggy_fp, SoundOffset[i], SEEK_SET );
|
|
|
|
|
|
|
|
// Read in the sound data!!!
|
|
|
|
snd->data = ptr;
|
|
|
|
#ifdef ALLEGRO
|
|
|
|
ptr += snd->len;
|
|
|
|
sbytes += snd->len;
|
|
|
|
#else
|
|
|
|
ptr += snd->length;
|
|
|
|
sbytes += snd->length;
|
|
|
|
#endif
|
|
|
|
//Arne's decompress for shareware on all soundcards - Tim@Rikers.org
|
|
|
|
if (pc_shareware)
|
|
|
|
{
|
|
|
|
if (lastsize < SoundCompressed[i]) {
|
|
|
|
MALLOC(lastbuf, ubyte, SoundCompressed[i]);
|
|
|
|
}
|
|
|
|
PHYSFS_read( Piggy_fp, lastbuf, SoundCompressed[i], 1 );
|
|
|
|
sound_decompress( lastbuf, SoundCompressed[i], snd->data );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
#ifdef ALLEGRO
|
|
|
|
PHYSFS_read( Piggy_fp, snd->data, snd->len, 1 );
|
|
|
|
#else
|
|
|
|
PHYSFS_read( Piggy_fp, snd->data, snd->length, 1 );
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
void piggy_read_sounds(void)
|
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file * fp = NULL;
|
2006-03-20 17:12:09 +00:00
|
|
|
ubyte * ptr;
|
|
|
|
int i, sbytes;
|
|
|
|
|
2014-07-24 02:45:47 +00:00
|
|
|
ptr = SoundBits.get();
|
2006-03-20 17:12:09 +00:00
|
|
|
sbytes = 0;
|
|
|
|
|
2010-09-25 03:35:23 +00:00
|
|
|
fp = PHYSFSX_openReadBuffered(DEFAULT_SNDFILE);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (fp == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (i=0; i<Num_sound_files; i++ ) {
|
|
|
|
digi_sound *snd = &GameSounds[i];
|
|
|
|
|
|
|
|
if ( SoundOffset[i] > 0 ) {
|
|
|
|
if ( piggy_is_needed(i) ) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek( fp, SoundOffset[i], SEEK_SET );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
// Read in the sound data!!!
|
|
|
|
snd->data = ptr;
|
|
|
|
ptr += snd->length;
|
|
|
|
sbytes += snd->length;
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_read( fp, snd->data, snd->length, 1 );
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
snd->data = (ubyte *) -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
void piggy_bitmap_page_in( bitmap_index bitmap )
|
|
|
|
{
|
|
|
|
grs_bitmap * bmp;
|
2011-09-26 23:31:19 +00:00
|
|
|
int i,org_i;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
org_i = 0;
|
|
|
|
|
|
|
|
i = bitmap.index;
|
|
|
|
Assert( i >= 0 );
|
|
|
|
Assert( i < MAX_BITMAP_FILES );
|
|
|
|
Assert( i < Num_bitmap_files );
|
|
|
|
Assert( Piggy_bitmap_cache_size > 0 );
|
|
|
|
|
|
|
|
if ( i < 1 ) return;
|
|
|
|
if ( i >= MAX_BITMAP_FILES ) return;
|
|
|
|
if ( i >= Num_bitmap_files ) return;
|
|
|
|
|
|
|
|
if ( GameBitmapOffset[i] == 0 ) return; // A read-from-disk bitmap!!!
|
|
|
|
|
2007-07-14 20:33:42 +00:00
|
|
|
if ( GameArg.SysLowMem ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
org_i = i;
|
|
|
|
i = GameBitmapXlat[i]; // Xlat for low-memory settings!
|
|
|
|
}
|
|
|
|
|
|
|
|
bmp = &GameBitmaps[i];
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( bmp->bm_flags & BM_FLAG_PAGED_OUT ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
stop_time();
|
|
|
|
|
|
|
|
ReDoIt:
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek( Piggy_fp, GameBitmapOffset[i], SEEK_SET );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2014-11-30 22:09:21 +00:00
|
|
|
gr_set_bitmap_flags(*bmp, GameBitmapFlags[i]);
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data (*bmp, &Piggy_bitmap_cache_data [Piggy_bitmap_cache_next]);
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( bmp->bm_flags & BM_FLAG_RLE ) {
|
2013-10-06 16:20:00 +00:00
|
|
|
int zsize = PHYSFSX_readInt(Piggy_fp);
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
|
|
|
|
// GET JOHN NOW IF YOU GET THIS ASSERT!!!
|
|
|
|
Assert( Piggy_bitmap_cache_next+zsize < Piggy_bitmap_cache_size );
|
|
|
|
if ( Piggy_bitmap_cache_next+zsize >= Piggy_bitmap_cache_size ) {
|
|
|
|
piggy_bitmap_page_out_all();
|
|
|
|
goto ReDoIt;
|
|
|
|
}
|
|
|
|
memcpy( &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next], &zsize, sizeof(int) );
|
|
|
|
Piggy_bitmap_cache_next += sizeof(int);
|
|
|
|
PHYSFS_read( Piggy_fp, &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next], 1, zsize-4 );
|
|
|
|
if (MacPig)
|
|
|
|
{
|
|
|
|
rle_swap_0_255(bmp);
|
|
|
|
memcpy(&zsize, bmp->bm_data, 4);
|
|
|
|
}
|
|
|
|
Piggy_bitmap_cache_next += zsize-4;
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2013-10-06 16:20:00 +00:00
|
|
|
int pigsize = PHYSFS_fileLength(Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
// GET JOHN NOW IF YOU GET THIS ASSERT!!!
|
|
|
|
//Assert( Piggy_bitmap_cache_next+zsize < Piggy_bitmap_cache_size );
|
|
|
|
if ( Piggy_bitmap_cache_next+zsize >= Piggy_bitmap_cache_size ) {
|
|
|
|
Int3();
|
|
|
|
piggy_bitmap_page_out_all();
|
|
|
|
goto ReDoIt;
|
|
|
|
}
|
2011-09-26 23:31:19 +00:00
|
|
|
PHYSFS_read( Piggy_fp, &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next+4], 1, zsize-4 );
|
2006-03-20 17:12:09 +00:00
|
|
|
*((int *) (Piggy_bitmap_cache_data + Piggy_bitmap_cache_next)) = INTEL_INT(zsize);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bmp, &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next]);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
#ifndef MACDATA
|
|
|
|
switch (pigsize) {
|
|
|
|
default:
|
2007-07-22 20:40:39 +00:00
|
|
|
if (!GameArg.EdiMacData)
|
2006-03-20 17:12:09 +00:00
|
|
|
break;
|
|
|
|
// otherwise, fall through...
|
|
|
|
case MAC_ALIEN1_PIGSIZE:
|
|
|
|
case MAC_ALIEN2_PIGSIZE:
|
|
|
|
case MAC_FIRE_PIGSIZE:
|
|
|
|
case MAC_GROUPA_PIGSIZE:
|
|
|
|
case MAC_ICE_PIGSIZE:
|
|
|
|
case MAC_WATER_PIGSIZE:
|
|
|
|
rle_swap_0_255( bmp );
|
|
|
|
memcpy(&zsize, bmp->bm_data, 4);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
Piggy_bitmap_cache_next += zsize;
|
|
|
|
if ( Piggy_bitmap_cache_next+zsize >= Piggy_bitmap_cache_size ) {
|
|
|
|
Int3();
|
|
|
|
piggy_bitmap_page_out_all();
|
|
|
|
goto ReDoIt;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
} else {
|
|
|
|
// GET JOHN NOW IF YOU GET THIS ASSERT!!!
|
|
|
|
Assert( Piggy_bitmap_cache_next+(bmp->bm_h*bmp->bm_w) < Piggy_bitmap_cache_size );
|
|
|
|
if ( Piggy_bitmap_cache_next+(bmp->bm_h*bmp->bm_w) >= Piggy_bitmap_cache_size ) {
|
|
|
|
piggy_bitmap_page_out_all();
|
|
|
|
goto ReDoIt;
|
|
|
|
}
|
2011-09-26 23:31:19 +00:00
|
|
|
PHYSFS_read( Piggy_fp, &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next], 1, bmp->bm_h*bmp->bm_w );
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
Piggy_bitmap_cache_next+=bmp->bm_h*bmp->bm_w;
|
|
|
|
if (MacPig)
|
|
|
|
swap_0_255(bmp);
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
|
|
|
int pigsize = PHYSFS_fileLength(Piggy_fp);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bmp, &Piggy_bitmap_cache_data[Piggy_bitmap_cache_next]);
|
2006-03-20 17:12:09 +00:00
|
|
|
Piggy_bitmap_cache_next+=bmp->bm_h*bmp->bm_w;
|
|
|
|
|
|
|
|
#ifndef MACDATA
|
|
|
|
switch (pigsize) {
|
|
|
|
default:
|
2007-07-22 20:40:39 +00:00
|
|
|
if (!GameArg.EdiMacData)
|
2006-03-20 17:12:09 +00:00
|
|
|
break;
|
|
|
|
// otherwise, fall through...
|
|
|
|
case MAC_ALIEN1_PIGSIZE:
|
|
|
|
case MAC_ALIEN2_PIGSIZE:
|
|
|
|
case MAC_FIRE_PIGSIZE:
|
|
|
|
case MAC_GROUPA_PIGSIZE:
|
|
|
|
case MAC_ICE_PIGSIZE:
|
|
|
|
case MAC_WATER_PIGSIZE:
|
|
|
|
swap_0_255( bmp );
|
|
|
|
break;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
//@@if ( bmp->bm_selector ) {
|
|
|
|
//@@#if !defined(WINDOWS) && !defined(MACINTOSH)
|
|
|
|
//@@ if (!dpmi_modify_selector_base( bmp->bm_selector, bmp->bm_data ))
|
|
|
|
//@@ Error( "Error modifying selector base in piggy.c\n" );
|
|
|
|
//@@#endif
|
|
|
|
//@@}
|
|
|
|
|
2011-04-12 01:02:51 +00:00
|
|
|
compute_average_rgb(bmp, bmp->avg_color_rgb);
|
|
|
|
|
2006-03-20 17:12:09 +00:00
|
|
|
start_time();
|
|
|
|
}
|
|
|
|
|
2007-07-14 20:33:42 +00:00
|
|
|
if ( GameArg.SysLowMem ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
if ( org_i != i )
|
|
|
|
GameBitmaps[org_i] = GameBitmaps[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
//@@Removed from John's code:
|
|
|
|
//@@#ifndef WINDOWS
|
|
|
|
//@@ if ( bmp->bm_selector ) {
|
|
|
|
//@@ if (!dpmi_modify_selector_base( bmp->bm_selector, bmp->bm_data ))
|
|
|
|
//@@ Error( "Error modifying selector base in piggy.c\n" );
|
|
|
|
//@@ }
|
|
|
|
//@@#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void piggy_bitmap_page_out_all()
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
Piggy_bitmap_cache_next = 0;
|
|
|
|
|
|
|
|
piggy_page_flushed++;
|
|
|
|
|
|
|
|
texmerge_flush();
|
|
|
|
rle_cache_flush();
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
for (i=0; i<Num_bitmap_files; i++ ) {
|
|
|
|
if ( GameBitmapOffset[i] > 0 ) { // Don't page out bitmaps read from disk!!!
|
2006-03-20 17:12:09 +00:00
|
|
|
GameBitmaps[i].bm_flags = BM_FLAG_PAGED_OUT;
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data (GameBitmaps[i], Piggy_bitmap_cache_data);
|
2013-03-03 01:03:33 +00:00
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(GameBitmaps[i], NULL);
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void piggy_load_level_data()
|
|
|
|
{
|
|
|
|
piggy_bitmap_page_out_all();
|
|
|
|
paging_touch_all();
|
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2006-03-20 17:12:09 +00:00
|
|
|
#ifdef EDITOR
|
|
|
|
|
2013-09-22 22:26:27 +00:00
|
|
|
static void piggy_write_pigfile(const char *filename)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_file *pig_fp;
|
2006-03-20 17:12:09 +00:00
|
|
|
int bitmap_data_start, data_offset;
|
|
|
|
DiskBitmapHeader bmh;
|
|
|
|
int org_offset;
|
|
|
|
char subst_name[32];
|
|
|
|
int i;
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_file *fp1,*fp2;
|
2006-03-20 17:12:09 +00:00
|
|
|
char tname[FILENAME_LEN];
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
for (i=0; i < Num_bitmap_files; i++ ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
bitmap_index bi;
|
|
|
|
bi.index = i;
|
|
|
|
PIGGY_PAGE_IN( bi );
|
|
|
|
}
|
|
|
|
|
|
|
|
piggy_close_file();
|
|
|
|
|
2010-08-19 13:32:33 +00:00
|
|
|
pig_fp = PHYSFSX_openWriteBuffered( filename ); //open PIG file
|
2006-03-20 17:12:09 +00:00
|
|
|
Assert( pig_fp!=NULL );
|
|
|
|
|
|
|
|
write_int(PIGFILE_ID,pig_fp);
|
|
|
|
write_int(PIGFILE_VERSION,pig_fp);
|
|
|
|
|
|
|
|
Num_bitmap_files--;
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_write( pig_fp, &Num_bitmap_files, sizeof(int), 1 );
|
2006-03-20 17:12:09 +00:00
|
|
|
Num_bitmap_files++;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
bitmap_data_start = PHYSFS_tell(pig_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
bitmap_data_start += (Num_bitmap_files - 1) * sizeof(DiskBitmapHeader);
|
|
|
|
data_offset = bitmap_data_start;
|
|
|
|
|
|
|
|
change_filename_extension(tname,filename,"lst");
|
2010-08-19 13:32:33 +00:00
|
|
|
fp1 = PHYSFSX_openWriteBuffered( tname );
|
2006-03-20 17:12:09 +00:00
|
|
|
change_filename_extension(tname,filename,"all");
|
2010-08-19 13:32:33 +00:00
|
|
|
fp2 = PHYSFSX_openWriteBuffered( tname );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
for (i=1; i < Num_bitmap_files; i++ ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
int *size;
|
|
|
|
grs_bitmap *bmp;
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
char * p, *p1;
|
|
|
|
p = strchr(AllBitmaps[i].name, '#');
|
|
|
|
if (p) { // this is an ABM == animated bitmap
|
|
|
|
int n;
|
|
|
|
p1 = p; p1++;
|
|
|
|
n = atoi(p1);
|
|
|
|
*p = 0;
|
|
|
|
if (fp2 && n==0)
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFSX_printf( fp2, "%s.abm\n", AllBitmaps[i].name );
|
2006-03-20 17:12:09 +00:00
|
|
|
memcpy( bmh.name, AllBitmaps[i].name, 8 );
|
|
|
|
Assert( n <= DBM_NUM_FRAMES );
|
|
|
|
bmh.dflags = DBM_FLAG_ABM + n;
|
|
|
|
*p = '#';
|
|
|
|
} else {
|
|
|
|
if (fp2)
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFSX_printf( fp2, "%s.bbm\n", AllBitmaps[i].name );
|
2006-03-20 17:12:09 +00:00
|
|
|
memcpy( bmh.name, AllBitmaps[i].name, 8 );
|
|
|
|
bmh.dflags = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
bmp = &GameBitmaps[i];
|
|
|
|
|
|
|
|
Assert( !(bmp->bm_flags&BM_FLAG_PAGED_OUT) );
|
|
|
|
|
|
|
|
if (fp1)
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFSX_printf( fp1, "BMP: %s, size %d bytes", AllBitmaps[i].name, bmp->bm_rowsize * bmp->bm_h );
|
2011-06-01 07:59:55 +00:00
|
|
|
org_offset = PHYSFS_tell(pig_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
bmh.offset = data_offset - bitmap_data_start;
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek( pig_fp, data_offset, SEEK_SET );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( bmp->bm_flags & BM_FLAG_RLE ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
size = (int *)bmp->bm_data;
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_write( pig_fp, bmp->bm_data, sizeof(ubyte), *size );
|
2006-03-20 17:12:09 +00:00
|
|
|
data_offset += *size;
|
|
|
|
if (fp1)
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFSX_printf( fp1, ", and is already compressed to %d bytes.\n", *size );
|
2006-03-20 17:12:09 +00:00
|
|
|
} else {
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_write( pig_fp, bmp->bm_data, sizeof(ubyte), bmp->bm_rowsize * bmp->bm_h );
|
2006-03-20 17:12:09 +00:00
|
|
|
data_offset += bmp->bm_rowsize * bmp->bm_h;
|
|
|
|
if (fp1)
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFSX_printf( fp1, ".\n" );
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek( pig_fp, org_offset, SEEK_SET );
|
2006-03-20 17:12:09 +00:00
|
|
|
Assert( GameBitmaps[i].bm_w < 4096 );
|
|
|
|
bmh.width = (GameBitmaps[i].bm_w & 0xff);
|
|
|
|
bmh.wh_extra = ((GameBitmaps[i].bm_w >> 8) & 0x0f);
|
|
|
|
Assert( GameBitmaps[i].bm_h < 4096 );
|
|
|
|
bmh.height = GameBitmaps[i].bm_h;
|
|
|
|
bmh.wh_extra |= ((GameBitmaps[i].bm_h >> 4) & 0xf0);
|
|
|
|
bmh.flags = GameBitmaps[i].bm_flags;
|
2013-02-21 00:20:26 +00:00
|
|
|
if (piggy_is_substitutable_bitmap( AllBitmaps[i].name, subst_name )) {
|
2006-03-20 17:12:09 +00:00
|
|
|
bitmap_index other_bitmap;
|
|
|
|
other_bitmap = piggy_find_bitmap( subst_name );
|
|
|
|
GameBitmapXlat[i] = other_bitmap.index;
|
|
|
|
bmh.flags |= BM_FLAG_PAGED_OUT;
|
2013-02-21 00:20:26 +00:00
|
|
|
} else {
|
2006-03-20 17:12:09 +00:00
|
|
|
bmh.flags &= ~BM_FLAG_PAGED_OUT;
|
|
|
|
}
|
|
|
|
bmh.avg_color=GameBitmaps[i].avg_color;
|
2013-02-21 00:20:26 +00:00
|
|
|
PHYSFS_write(pig_fp, &bmh, sizeof(DiskBitmapHeader), 1); // Mark as a bitmap
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_close(pig_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFSX_printf( fp1, " Dumped %d assorted bitmaps.\n", Num_bitmap_files );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2010-08-19 13:32:33 +00:00
|
|
|
PHYSFS_close(fp1);
|
|
|
|
PHYSFS_close(fp2);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2010-08-19 13:32:33 +00:00
|
|
|
static void write_int(int i, PHYSFS_file *file)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2010-08-19 13:32:33 +00:00
|
|
|
if (PHYSFS_write( file, &i, sizeof(i), 1) != 1)
|
2006-03-20 17:12:09 +00:00
|
|
|
Error( "Error reading int in gamesave.c" );
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
void piggy_close()
|
|
|
|
{
|
2008-03-27 10:43:35 +00:00
|
|
|
int i;
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
custom_close();
|
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
piggy_close_file();
|
2014-07-24 02:45:47 +00:00
|
|
|
BitmapBits.reset();
|
2014-07-24 02:45:47 +00:00
|
|
|
SoundBits.reset();
|
2008-03-27 10:43:35 +00:00
|
|
|
for (i = 0; i < Num_sound_files; i++)
|
|
|
|
if (SoundOffset[i] == 0)
|
|
|
|
d_free(GameSounds[i].data);
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2008-11-14 16:56:40 +00:00
|
|
|
free_bitmap_replacements();
|
|
|
|
free_d1_tmap_nums();
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2014-08-23 16:27:28 +00:00
|
|
|
void remove_char( char * s, char c )
|
|
|
|
{
|
|
|
|
char *p = strchr(s,c);
|
|
|
|
if (p) *p = '\0';
|
|
|
|
}
|
|
|
|
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_II)
|
2013-10-27 22:00:14 +00:00
|
|
|
#ifdef EDITOR
|
2013-10-06 16:20:00 +00:00
|
|
|
static int piggy_does_bitmap_exist_slow(const char * name )
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
for (i=0; i<Num_bitmap_files; i++ ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
if ( !strcmp( AllBitmaps[i].name, name) )
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
static const char gauge_bitmap_names[][9] = {
|
|
|
|
"gauge01",
|
|
|
|
"gauge02",
|
|
|
|
"gauge06",
|
|
|
|
"targ01",
|
|
|
|
"targ02",
|
|
|
|
"targ03",
|
|
|
|
"targ04",
|
|
|
|
"targ05",
|
|
|
|
"targ06",
|
|
|
|
"gauge18",
|
2013-03-03 01:03:33 +00:00
|
|
|
#if defined(DXX_BUILD_DESCENT_I)
|
|
|
|
"targ01pc",
|
|
|
|
"targ02pc",
|
|
|
|
"targ03pc",
|
|
|
|
"gaug18pc"
|
|
|
|
#elif defined(DXX_BUILD_DESCENT_II)
|
2013-10-06 16:20:00 +00:00
|
|
|
"gauge01b",
|
|
|
|
"gauge02b",
|
|
|
|
"gauge06b",
|
|
|
|
"targ01b",
|
|
|
|
"targ02b",
|
|
|
|
"targ03b",
|
|
|
|
"targ04b",
|
|
|
|
"targ05b",
|
|
|
|
"targ06b",
|
|
|
|
"gauge18b",
|
|
|
|
"gauss1",
|
|
|
|
"helix1",
|
2006-03-20 17:12:09 +00:00
|
|
|
"phoenix1"
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
};
|
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
static int piggy_is_gauge_bitmap(const char * base_name )
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2013-10-06 16:20:00 +00:00
|
|
|
for (unsigned i=0; i<sizeof(gauge_bitmap_names)/sizeof(gauge_bitmap_names[0]); i++ ) {
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( !d_stricmp( base_name, gauge_bitmap_names[i] ))
|
2006-03-20 17:12:09 +00:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2013-02-21 00:20:26 +00:00
|
|
|
return 0;
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2013-09-22 22:26:27 +00:00
|
|
|
static int piggy_is_substitutable_bitmap( char * name, char * subst_name )
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int frame;
|
|
|
|
char * p;
|
|
|
|
char base_name[ 16 ];
|
|
|
|
|
|
|
|
strcpy( subst_name, name );
|
|
|
|
p = strchr( subst_name, '#' );
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( p ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
frame = atoi( &p[1] );
|
|
|
|
*p = 0;
|
|
|
|
strcpy( base_name, subst_name );
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( !piggy_is_gauge_bitmap( base_name )) {
|
2006-03-20 17:12:09 +00:00
|
|
|
sprintf( subst_name, "%s#%d", base_name, frame+1 );
|
2013-02-21 00:20:26 +00:00
|
|
|
if ( piggy_does_bitmap_exist_slow( subst_name ) ) {
|
2006-03-20 17:12:09 +00:00
|
|
|
if ( frame & 1 ) {
|
|
|
|
sprintf( subst_name, "%s#%d", base_name, frame-1 );
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
strcpy( subst_name, name );
|
|
|
|
return 0;
|
|
|
|
}
|
2013-09-22 22:26:27 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Functions for loading replacement textures
|
|
|
|
* 1) From .pog files
|
|
|
|
* 2) From descent.pig (for loading d1 levels)
|
|
|
|
*/
|
|
|
|
|
2013-10-06 16:20:00 +00:00
|
|
|
static void free_bitmap_replacements()
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2014-07-24 02:45:47 +00:00
|
|
|
Bitmap_replacement_data.reset();
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2013-06-08 22:24:17 +00:00
|
|
|
void load_bitmap_replacements(const char *level_name)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
char ifile_name[FILENAME_LEN];
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file *ifile;
|
2006-03-20 17:12:09 +00:00
|
|
|
int i;
|
|
|
|
|
|
|
|
//first, free up data allocated for old bitmaps
|
|
|
|
free_bitmap_replacements();
|
|
|
|
|
|
|
|
change_filename_extension(ifile_name, level_name, ".POG" );
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
ifile = PHYSFSX_openReadBuffered(ifile_name);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (ifile) {
|
|
|
|
int id,version,n_bitmaps;
|
|
|
|
int bitmap_data_size;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
id = PHYSFSX_readInt(ifile);
|
|
|
|
version = PHYSFSX_readInt(ifile);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (id != MAKE_SIG('G','O','P','D') || version != 1) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(ifile);
|
2006-03-20 17:12:09 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
n_bitmaps = PHYSFSX_readInt(ifile);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-12-08 18:22:17 +00:00
|
|
|
RAIIdmem<ushort> indices;
|
2006-03-20 17:12:09 +00:00
|
|
|
MALLOC( indices, ushort, n_bitmaps );
|
|
|
|
|
|
|
|
for (i = 0; i < n_bitmaps; i++)
|
2011-06-01 07:59:55 +00:00
|
|
|
indices[i] = PHYSFSX_readShort(ifile);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
bitmap_data_size = PHYSFS_fileLength(ifile) - PHYSFS_tell(ifile) - sizeof(DiskBitmapHeader) * n_bitmaps;
|
2014-08-16 04:15:16 +00:00
|
|
|
Bitmap_replacement_data = make_unique<ubyte[]>(bitmap_data_size);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
for (i=0;i<n_bitmaps;i++) {
|
|
|
|
DiskBitmapHeader bmh;
|
|
|
|
grs_bitmap *bm = &GameBitmaps[indices[i]];
|
|
|
|
int width;
|
|
|
|
|
|
|
|
DiskBitmapHeader_read(&bmh, ifile);
|
|
|
|
|
|
|
|
width = bmh.width + ((short) (bmh.wh_extra & 0x0f) << 8);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bm, NULL); // free ogl texture
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(*bm, 0, 0, 0, width, bmh.height + ((short) (bmh.wh_extra & 0xf0) << 4), width, NULL);
|
2006-03-20 17:12:09 +00:00
|
|
|
bm->avg_color = bmh.avg_color;
|
2007-06-14 12:32:18 +00:00
|
|
|
bm->bm_data = (ubyte *) (size_t)bmh.offset;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2014-11-30 22:09:21 +00:00
|
|
|
gr_set_bitmap_flags(*bm, bmh.flags & BM_FLAGS_TO_COPY);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
GameBitmapOffset[indices[i]] = 0; // don't try to read bitmap from current pigfile
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_read(ifile,Bitmap_replacement_data,1,bitmap_data_size);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
for (i = 0; i < n_bitmaps; i++)
|
|
|
|
{
|
|
|
|
grs_bitmap *bm = &GameBitmaps[indices[i]];
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bm, &Bitmap_replacement_data[(size_t) bm->bm_data]);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(ifile);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
last_palette_loaded_pig[0]= 0; //force pig re-load
|
|
|
|
|
|
|
|
texmerge_flush(); //for re-merging with new textures
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* calculate table to translate d1 bitmaps to current palette,
|
|
|
|
* return -1 on error
|
|
|
|
*/
|
2014-11-30 22:09:21 +00:00
|
|
|
static int get_d1_colormap( palette_array_t &d1_palette, array<color_t, 256> &colormap )
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file * palette_file = PHYSFSX_openReadBuffered(D1_PALETTE);
|
|
|
|
if (!palette_file || PHYSFS_fileLength(palette_file) != 9472)
|
2006-03-20 17:12:09 +00:00
|
|
|
return -1;
|
2013-01-06 21:11:53 +00:00
|
|
|
PHYSFS_read( palette_file, &d1_palette[0], sizeof(d1_palette[0]), d1_palette.size() );
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close( palette_file );
|
2014-11-30 22:09:21 +00:00
|
|
|
array<unsigned, 256> freq;
|
2006-03-20 17:12:09 +00:00
|
|
|
build_colormap_good( d1_palette, colormap, freq );
|
|
|
|
// don't change transparencies:
|
|
|
|
colormap[254] = 254;
|
|
|
|
colormap[255] = 255;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define JUST_IN_CASE 132 /* is enough for d1 pc registered */
|
2013-10-27 22:00:14 +00:00
|
|
|
static void bitmap_read_d1( grs_bitmap *bitmap, /* read into this bitmap */
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file *d1_Piggy_fp, /* read from this file */
|
2006-03-20 17:12:09 +00:00
|
|
|
int bitmap_data_start, /* specific to file */
|
|
|
|
DiskBitmapHeader *bmh, /* header info for bitmap */
|
|
|
|
ubyte **next_bitmap, /* where to write it (if 0, use malloc) */
|
2013-01-06 21:03:57 +00:00
|
|
|
palette_array_t &d1_palette, /* what palette the bitmap has */
|
2014-11-30 22:09:21 +00:00
|
|
|
array<color_t, 256> &colormap) /* how to translate bitmap's colors */
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
int zsize, pigsize = PHYSFS_fileLength(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
ubyte *data;
|
|
|
|
int width;
|
|
|
|
|
|
|
|
width = bmh->width + ((short) (bmh->wh_extra & 0x0f) << 8);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bitmap, NULL); // free ogl texture
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_init_bitmap(*bitmap, 0, 0, 0, width, bmh->height + ((short) (bmh->wh_extra & 0xf0) << 4), width, NULL);
|
2006-03-20 17:12:09 +00:00
|
|
|
bitmap->avg_color = bmh->avg_color;
|
2014-11-30 22:09:21 +00:00
|
|
|
gr_set_bitmap_flags(*bitmap, bmh->flags & BM_FLAGS_TO_COPY);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek(d1_Piggy_fp, bitmap_data_start + bmh->offset, SEEK_SET);
|
2006-03-20 17:12:09 +00:00
|
|
|
if (bmh->flags & BM_FLAG_RLE) {
|
2011-06-01 07:59:55 +00:00
|
|
|
zsize = PHYSFSX_readInt(d1_Piggy_fp);
|
|
|
|
PHYSFSX_fseek(d1_Piggy_fp, -4, SEEK_CUR);
|
2006-03-20 17:12:09 +00:00
|
|
|
} else
|
|
|
|
zsize = bitmap->bm_h * bitmap->bm_w;
|
|
|
|
|
|
|
|
if (next_bitmap) {
|
|
|
|
data = *next_bitmap;
|
|
|
|
*next_bitmap += zsize;
|
|
|
|
} else {
|
2013-10-24 03:08:58 +00:00
|
|
|
MALLOC(data, ubyte, zsize + JUST_IN_CASE);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
if (!data) return;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_read(d1_Piggy_fp, data, 1, zsize);
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(*bitmap, data);
|
2006-03-20 17:12:09 +00:00
|
|
|
switch(pigsize) {
|
|
|
|
case D1_MAC_PIGSIZE:
|
|
|
|
case D1_MAC_SHARE_PIGSIZE:
|
|
|
|
if (bmh->flags & BM_FLAG_RLE)
|
|
|
|
rle_swap_0_255(bitmap);
|
|
|
|
else
|
|
|
|
swap_0_255(bitmap);
|
|
|
|
}
|
|
|
|
if (bmh->flags & BM_FLAG_RLE)
|
|
|
|
rle_remap(bitmap, colormap);
|
|
|
|
else
|
|
|
|
gr_remap_bitmap_good(bitmap, d1_palette, TRANSPARENCY_COLOR, -1);
|
|
|
|
if (bmh->flags & BM_FLAG_RLE) { // size of bitmap could have changed!
|
|
|
|
int new_size;
|
|
|
|
memcpy(&new_size, bitmap->bm_data, 4);
|
|
|
|
if (next_bitmap) {
|
|
|
|
*next_bitmap += new_size - zsize;
|
|
|
|
} else {
|
|
|
|
Assert( zsize + JUST_IN_CASE >= new_size );
|
2014-12-02 03:24:38 +00:00
|
|
|
bitmap->bm_mdata = (ubyte *) d_realloc(bitmap->bm_mdata, new_size);
|
2006-03-20 17:12:09 +00:00
|
|
|
Assert(bitmap->bm_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#define D1_MAX_TEXTURES 800
|
|
|
|
#define D1_MAX_TMAP_NUM 1630 // 1621 in descent.pig Mac registered
|
|
|
|
|
|
|
|
/* the inverse of the d2 Textures array, but for the descent 1 pigfile.
|
|
|
|
* "Textures" looks up a d2 bitmap index given a d2 tmap_num.
|
|
|
|
* "d1_tmap_nums" looks up a d1 tmap_num given a d1 bitmap. "-1" means "None".
|
|
|
|
*/
|
2014-07-24 03:03:46 +00:00
|
|
|
typedef array<short, D1_MAX_TMAP_NUM> d1_tmap_nums_t;
|
|
|
|
static std::unique_ptr<d1_tmap_nums_t> d1_tmap_nums;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2013-10-27 22:00:14 +00:00
|
|
|
static void free_d1_tmap_nums() {
|
2014-07-24 03:03:46 +00:00
|
|
|
d1_tmap_nums.reset();
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2013-10-27 22:00:14 +00:00
|
|
|
static void bm_read_d1_tmap_nums(PHYSFS_file *d1pig)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i, d1_index;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek(d1pig, 8, SEEK_SET);
|
2014-08-16 04:15:16 +00:00
|
|
|
d1_tmap_nums = make_unique<d1_tmap_nums_t>();
|
2014-07-24 03:03:46 +00:00
|
|
|
d1_tmap_nums->fill(-1);
|
2006-03-20 17:12:09 +00:00
|
|
|
for (i = 0; i < D1_MAX_TEXTURES; i++) {
|
2011-06-01 07:59:55 +00:00
|
|
|
d1_index = PHYSFSX_readShort(d1pig);
|
2006-03-20 17:12:09 +00:00
|
|
|
Assert(d1_index >= 0 && d1_index < D1_MAX_TMAP_NUM);
|
2014-07-24 03:03:46 +00:00
|
|
|
(*d1_tmap_nums)[d1_index] = i;
|
2008-11-01 01:19:52 +00:00
|
|
|
if (PHYSFS_eof(d1pig))
|
|
|
|
break;
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-11-11 00:12:17 +00:00
|
|
|
const char space[3] = " \t";
|
|
|
|
const char equal_space[4] = " \t=";
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
// this function is at the same position in the d1 shareware piggy loading
|
|
|
|
// algorithm as bm_load_sub in main/bmread.c
|
2013-10-27 22:00:14 +00:00
|
|
|
static int get_d1_bm_index(char *filename, PHYSFS_file *d1_pig) {
|
2006-03-20 17:12:09 +00:00
|
|
|
int i, N_bitmaps;
|
|
|
|
DiskBitmapHeader bmh;
|
|
|
|
if (strchr (filename, '.'))
|
|
|
|
*strchr (filename, '.') = '\0'; // remove extension
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek (d1_pig, 0, SEEK_SET);
|
|
|
|
N_bitmaps = PHYSFSX_readInt (d1_pig);
|
|
|
|
PHYSFSX_fseek (d1_pig, 8, SEEK_SET);
|
2006-03-20 17:12:09 +00:00
|
|
|
for (i = 1; i <= N_bitmaps; i++) {
|
|
|
|
DiskBitmapHeader_d1_read(&bmh, d1_pig);
|
2012-05-18 23:36:43 +00:00
|
|
|
if (!d_strnicmp(bmh.name, filename, 8))
|
2006-03-20 17:12:09 +00:00
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2008-02-11 12:12:57 +00:00
|
|
|
// imitate the algorithm of gamedata_read_tbl in main/bmread.c
|
2013-10-27 22:00:14 +00:00
|
|
|
static void read_d1_tmap_nums_from_hog(PHYSFS_file *d1_pig)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
#define LINEBUF_SIZE 600
|
|
|
|
int reading_textures = 0;
|
|
|
|
short texture_count = 0;
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file * bitmaps;
|
2006-03-20 17:12:09 +00:00
|
|
|
int bitmaps_tbl_is_binary = 0;
|
|
|
|
int i;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
bitmaps = PHYSFSX_openReadBuffered ("bitmaps.tbl");
|
2006-03-20 17:12:09 +00:00
|
|
|
if (!bitmaps) {
|
2011-06-01 07:59:55 +00:00
|
|
|
bitmaps = PHYSFSX_openReadBuffered ("bitmaps.bin");
|
2006-03-20 17:12:09 +00:00
|
|
|
bitmaps_tbl_is_binary = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!bitmaps) {
|
|
|
|
Warning ("Could not find bitmaps.* for reading d1 textures");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-08-16 04:15:16 +00:00
|
|
|
d1_tmap_nums = make_unique<d1_tmap_nums_t>();
|
2014-07-24 03:03:46 +00:00
|
|
|
d1_tmap_nums->fill(-1);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2014-09-07 19:48:10 +00:00
|
|
|
for (PHYSFSX_gets_line_t<LINEBUF_SIZE> inputline; PHYSFSX_fgets (inputline, bitmaps);)
|
|
|
|
{
|
2006-03-20 17:12:09 +00:00
|
|
|
char *arg;
|
|
|
|
|
|
|
|
if (bitmaps_tbl_is_binary)
|
|
|
|
decode_text_line((inputline));
|
|
|
|
else
|
|
|
|
while (inputline[(i=strlen(inputline))-2]=='\\')
|
2014-09-07 19:48:10 +00:00
|
|
|
PHYSFSX_fgets(inputline,bitmaps,i-2); // strip comments
|
2006-03-20 17:12:09 +00:00
|
|
|
REMOVE_EOL(inputline);
|
|
|
|
if (strchr(inputline, ';')!=NULL) REMOVE_COMMENTS(inputline);
|
|
|
|
if (strlen(inputline) == LINEBUF_SIZE-1) {
|
|
|
|
Warning("Possible line truncation in BITMAPS.TBL");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
arg = strtok( inputline, space );
|
|
|
|
if (arg && arg[0] == '@') {
|
|
|
|
arg++;
|
|
|
|
//Registered_only = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
while (arg != NULL) {
|
|
|
|
if (*arg == '$')
|
|
|
|
reading_textures = 0; // default
|
|
|
|
if (!strcmp(arg, "$TEXTURES")) // BM_TEXTURES
|
|
|
|
reading_textures = 1;
|
2012-05-18 23:36:43 +00:00
|
|
|
else if (! d_stricmp(arg, "$ECLIP") // BM_ECLIP
|
|
|
|
|| ! d_stricmp(arg, "$WCLIP")) // BM_WCLIP
|
2006-03-20 17:12:09 +00:00
|
|
|
texture_count++;
|
|
|
|
else // not a special token, must be a bitmap!
|
|
|
|
if (reading_textures) {
|
|
|
|
while (*arg == '\t' || *arg == ' ')
|
|
|
|
arg++;//remove unwanted blanks
|
|
|
|
if (*arg == '\0')
|
|
|
|
break;
|
|
|
|
if (d1_tmap_num_unique(texture_count)) {
|
|
|
|
int d1_index = get_d1_bm_index(arg, d1_pig);
|
|
|
|
if (d1_index >= 0 && d1_index < D1_MAX_TMAP_NUM) {
|
2014-07-24 03:03:46 +00:00
|
|
|
(*d1_tmap_nums)[d1_index] = texture_count;
|
2006-03-20 17:12:09 +00:00
|
|
|
//int d2_index = d2_index_for_d1_index(d1_index);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Assert (texture_count < D1_MAX_TEXTURES);
|
|
|
|
texture_count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
arg = strtok (NULL, equal_space);
|
|
|
|
}
|
|
|
|
}
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close (bitmaps);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* If the given d1_index is the index of a bitmap we have to load
|
|
|
|
* (because it is unique to descent 1), then returns the d2_index that
|
|
|
|
* the given d1_index replaces.
|
|
|
|
* Returns -1 if the given d1_index is not unique to descent 1.
|
|
|
|
*/
|
2013-10-27 22:00:14 +00:00
|
|
|
static short d2_index_for_d1_index(short d1_index)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
Assert(d1_index >= 0 && d1_index < D1_MAX_TMAP_NUM);
|
2014-07-24 03:03:46 +00:00
|
|
|
if (! d1_tmap_nums || (*d1_tmap_nums)[d1_index] == -1
|
|
|
|
|| ! d1_tmap_num_unique((*d1_tmap_nums)[d1_index]))
|
2006-03-20 17:12:09 +00:00
|
|
|
return -1;
|
|
|
|
|
2014-07-24 03:03:46 +00:00
|
|
|
return Textures[convert_d1_tmap_num((*d1_tmap_nums)[d1_index])].index;
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#define D1_BITMAPS_SIZE 300000
|
|
|
|
void load_d1_bitmap_replacements()
|
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file * d1_Piggy_fp;
|
2006-03-20 17:12:09 +00:00
|
|
|
DiskBitmapHeader bmh;
|
|
|
|
int pig_data_start, bitmap_header_start, bitmap_data_start;
|
|
|
|
int N_bitmaps;
|
|
|
|
short d1_index, d2_index;
|
|
|
|
ubyte* next_bitmap;
|
2013-01-06 21:03:57 +00:00
|
|
|
palette_array_t d1_palette;
|
2006-03-20 17:12:09 +00:00
|
|
|
char *p;
|
|
|
|
int pigsize;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
d1_Piggy_fp = PHYSFSX_openReadBuffered( D1_PIGFILE );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
#define D1_PIG_LOAD_FAILED "Failed loading " D1_PIGFILE
|
|
|
|
if (!d1_Piggy_fp) {
|
|
|
|
Warning(D1_PIG_LOAD_FAILED);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
//first, free up data allocated for old bitmaps
|
|
|
|
free_bitmap_replacements();
|
|
|
|
|
2014-11-30 22:09:21 +00:00
|
|
|
array<color_t, 256> colormap;
|
2006-03-20 17:12:09 +00:00
|
|
|
if (get_d1_colormap( d1_palette, colormap ) != 0)
|
|
|
|
Warning("Could not load descent 1 color palette");
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
pigsize = PHYSFS_fileLength(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
switch (pigsize) {
|
|
|
|
case D1_SHARE_BIG_PIGSIZE:
|
|
|
|
case D1_SHARE_10_PIGSIZE:
|
|
|
|
case D1_SHARE_PIGSIZE:
|
|
|
|
case D1_10_BIG_PIGSIZE:
|
|
|
|
case D1_10_PIGSIZE:
|
|
|
|
pig_data_start = 0;
|
2008-02-11 12:12:57 +00:00
|
|
|
// OK, now we need to read d1_tmap_nums by emulating d1's gamedata_read_tbl()
|
2006-03-20 17:12:09 +00:00
|
|
|
read_d1_tmap_nums_from_hog(d1_Piggy_fp);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
Warning("Unknown size for " D1_PIGFILE);
|
|
|
|
Int3();
|
|
|
|
// fall through
|
|
|
|
case D1_PIGSIZE:
|
|
|
|
case D1_OEM_PIGSIZE:
|
|
|
|
case D1_MAC_PIGSIZE:
|
|
|
|
case D1_MAC_SHARE_PIGSIZE:
|
2011-06-01 07:59:55 +00:00
|
|
|
pig_data_start = PHYSFSX_readInt(d1_Piggy_fp );
|
2006-03-20 17:12:09 +00:00
|
|
|
bm_read_d1_tmap_nums(d1_Piggy_fp); //was: bm_read_all_d1(fp);
|
2011-06-01 07:59:55 +00:00
|
|
|
//for (i = 0; i < 1800; i++) GameBitmapXlat[i] = PHYSFSX_readShort(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek( d1_Piggy_fp, pig_data_start, SEEK_SET );
|
|
|
|
N_bitmaps = PHYSFSX_readInt(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
int N_sounds = PHYSFSX_readInt(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
int header_size = N_bitmaps * DISKBITMAPHEADER_D1_SIZE
|
|
|
|
+ N_sounds * sizeof(DiskSoundHeader);
|
|
|
|
bitmap_header_start = pig_data_start + 2 * sizeof(int);
|
|
|
|
bitmap_data_start = bitmap_header_start + header_size;
|
|
|
|
}
|
|
|
|
|
2014-08-16 04:15:16 +00:00
|
|
|
Bitmap_replacement_data = make_unique<ubyte[]>(D1_BITMAPS_SIZE);
|
2006-03-20 17:12:09 +00:00
|
|
|
if (!Bitmap_replacement_data) {
|
|
|
|
Warning(D1_PIG_LOAD_FAILED);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-07-24 02:45:47 +00:00
|
|
|
next_bitmap = Bitmap_replacement_data.get();
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
for (d1_index = 1; d1_index <= N_bitmaps; d1_index++ ) {
|
|
|
|
d2_index = d2_index_for_d1_index(d1_index);
|
|
|
|
// only change bitmaps which are unique to d1
|
|
|
|
if (d2_index != -1) {
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek(d1_Piggy_fp, bitmap_header_start + (d1_index-1) * DISKBITMAPHEADER_D1_SIZE, SEEK_SET);
|
2006-03-20 17:12:09 +00:00
|
|
|
DiskBitmapHeader_d1_read(&bmh, d1_Piggy_fp);
|
|
|
|
|
|
|
|
bitmap_read_d1( &GameBitmaps[d2_index], d1_Piggy_fp, bitmap_data_start, &bmh, &next_bitmap, d1_palette, colormap );
|
2014-07-24 02:45:47 +00:00
|
|
|
Assert(next_bitmap - Bitmap_replacement_data.get() < D1_BITMAPS_SIZE);
|
2006-03-20 17:12:09 +00:00
|
|
|
GameBitmapOffset[d2_index] = 0; // don't try to read bitmap from current d2 pigfile
|
|
|
|
GameBitmapFlags[d2_index] = bmh.flags;
|
|
|
|
|
|
|
|
if ( (p = strchr(AllBitmaps[d2_index].name, '#')) /* d2 BM is animated */
|
|
|
|
&& !(bmh.dflags & DBM_FLAG_ABM) ) { /* d1 bitmap is not animated */
|
|
|
|
int i, len = p - AllBitmaps[d2_index].name;
|
|
|
|
for (i = 0; i < Num_bitmap_files; i++)
|
|
|
|
if (i != d2_index && ! memcmp(AllBitmaps[d2_index].name, AllBitmaps[i].name, len))
|
|
|
|
{
|
2014-11-30 22:09:20 +00:00
|
|
|
gr_set_bitmap_data(GameBitmaps[i], NULL); // free ogl texture
|
2006-03-20 17:12:09 +00:00
|
|
|
GameBitmaps[i] = GameBitmaps[d2_index];
|
|
|
|
GameBitmapOffset[i] = 0;
|
|
|
|
GameBitmapFlags[i] = bmh.flags;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
last_palette_loaded_pig[0]= 0; //force pig re-load
|
|
|
|
|
|
|
|
texmerge_flush(); //for re-merging with new textures
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Find and load the named bitmap from descent.pig
|
|
|
|
* similar to read_extra_bitmap_iff
|
|
|
|
*/
|
2013-06-08 22:24:17 +00:00
|
|
|
bitmap_index read_extra_bitmap_d1_pig(const char *name)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
bitmap_index bitmap_num;
|
2012-11-18 18:21:50 +00:00
|
|
|
grs_bitmap * n = &GameBitmaps[extra_bitmap_num];
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
bitmap_num.index = 0;
|
|
|
|
|
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_file *d1_Piggy_fp;
|
2006-03-20 17:12:09 +00:00
|
|
|
DiskBitmapHeader bmh;
|
|
|
|
int pig_data_start, bitmap_header_start, bitmap_data_start;
|
|
|
|
int i, N_bitmaps;
|
2013-01-06 21:03:57 +00:00
|
|
|
palette_array_t d1_palette;
|
2006-03-20 17:12:09 +00:00
|
|
|
int pigsize;
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
d1_Piggy_fp = PHYSFSX_openReadBuffered(D1_PIGFILE);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
if (!d1_Piggy_fp)
|
|
|
|
{
|
|
|
|
Warning(D1_PIG_LOAD_FAILED);
|
|
|
|
return bitmap_num;
|
|
|
|
}
|
|
|
|
|
2014-11-30 22:09:21 +00:00
|
|
|
array<color_t, 256> colormap;
|
2006-03-20 17:12:09 +00:00
|
|
|
if (get_d1_colormap( d1_palette, colormap ) != 0)
|
|
|
|
Warning("Could not load descent 1 color palette");
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
pigsize = PHYSFS_fileLength(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
switch (pigsize) {
|
|
|
|
case D1_SHARE_BIG_PIGSIZE:
|
|
|
|
case D1_SHARE_10_PIGSIZE:
|
|
|
|
case D1_SHARE_PIGSIZE:
|
|
|
|
case D1_10_BIG_PIGSIZE:
|
|
|
|
case D1_10_PIGSIZE:
|
|
|
|
pig_data_start = 0;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
Warning("Unknown size for " D1_PIGFILE);
|
|
|
|
Int3();
|
|
|
|
// fall through
|
|
|
|
case D1_PIGSIZE:
|
|
|
|
case D1_OEM_PIGSIZE:
|
|
|
|
case D1_MAC_PIGSIZE:
|
|
|
|
case D1_MAC_SHARE_PIGSIZE:
|
2011-06-01 07:59:55 +00:00
|
|
|
pig_data_start = PHYSFSX_readInt(d1_Piggy_fp );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFSX_fseek( d1_Piggy_fp, pig_data_start, SEEK_SET );
|
|
|
|
N_bitmaps = PHYSFSX_readInt(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
int N_sounds = PHYSFSX_readInt(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
int header_size = N_bitmaps * DISKBITMAPHEADER_D1_SIZE
|
|
|
|
+ N_sounds * sizeof(DiskSoundHeader);
|
|
|
|
bitmap_header_start = pig_data_start + 2 * sizeof(int);
|
|
|
|
bitmap_data_start = bitmap_header_start + header_size;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 1; i <= N_bitmaps; i++)
|
|
|
|
{
|
|
|
|
DiskBitmapHeader_d1_read(&bmh, d1_Piggy_fp);
|
2012-05-18 23:36:43 +00:00
|
|
|
if (!d_strnicmp(bmh.name, name, 8))
|
2006-03-20 17:12:09 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-05-18 23:36:43 +00:00
|
|
|
if (d_strnicmp(bmh.name, name, 8))
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2013-12-07 00:47:27 +00:00
|
|
|
con_printf(CON_DEBUG, "could not find bitmap %s", name);
|
2006-03-20 17:12:09 +00:00
|
|
|
return bitmap_num;
|
|
|
|
}
|
|
|
|
|
2012-11-18 18:21:50 +00:00
|
|
|
bitmap_read_d1( n, d1_Piggy_fp, bitmap_data_start, &bmh, 0, d1_palette, colormap );
|
2006-03-20 17:12:09 +00:00
|
|
|
|
2011-06-01 07:59:55 +00:00
|
|
|
PHYSFS_close(d1_Piggy_fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
2012-11-18 18:21:50 +00:00
|
|
|
n->avg_color = 0; //compute_average_pixel(n);
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
bitmap_num.index = extra_bitmap_num;
|
|
|
|
|
2012-11-18 18:21:50 +00:00
|
|
|
GameBitmaps[extra_bitmap_num++] = *n;
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
return bitmap_num;
|
|
|
|
}
|
2013-03-03 01:03:33 +00:00
|
|
|
#endif
|
2006-03-20 17:12:09 +00:00
|
|
|
|
|
|
|
/*
|
2011-06-01 07:59:55 +00:00
|
|
|
* reads a bitmap_index structure from a PHYSFS_file
|
2006-03-20 17:12:09 +00:00
|
|
|
*/
|
2011-06-01 07:59:55 +00:00
|
|
|
void bitmap_index_read(bitmap_index *bi, PHYSFS_file *fp)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
2011-06-01 07:59:55 +00:00
|
|
|
bi->index = PHYSFSX_readShort(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2011-06-01 07:59:55 +00:00
|
|
|
* reads n bitmap_index structs from a PHYSFS_file
|
2006-03-20 17:12:09 +00:00
|
|
|
*/
|
2011-06-01 07:59:55 +00:00
|
|
|
int bitmap_index_read_n(bitmap_index *bi, int n, PHYSFS_file *fp)
|
2006-03-20 17:12:09 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < n; i++)
|
2011-06-01 07:59:55 +00:00
|
|
|
bi[i].index = PHYSFSX_readShort(fp);
|
2006-03-20 17:12:09 +00:00
|
|
|
return i;
|
|
|
|
}
|