# Conflicts:
#	wadsrc/static/compatibility.txt
This commit is contained in:
Christoph Oelckers 2016-12-22 11:29:44 +01:00
commit 3b823fa3eb
40 changed files with 580 additions and 466 deletions

View file

@ -4,7 +4,7 @@ project(libgme)
include (CheckCXXCompilerFlag) include (CheckCXXCompilerFlag)
# When version is changed, also change the one in gme/gme.h to match # When version is changed, also change the one in gme/gme.h to match
set(GME_VERSION 0.6.0 CACHE INTERNAL "libgme Version") set(GME_VERSION 0.6.1 CACHE INTERNAL "libgme Version")
# 2.6+ always assumes FATAL_ERROR, but 2.4 and below don't. # 2.6+ always assumes FATAL_ERROR, but 2.4 and below don't.
# Of course, 2.4 might work, in which case you're welcome to drop # Of course, 2.4 might work, in which case you're welcome to drop
@ -79,6 +79,9 @@ set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${ZD_FASTMATH_FLAG}" )
SET(USE_GME_NSF 1 BOOL "Enable NES NSF music emulation") SET(USE_GME_NSF 1 BOOL "Enable NES NSF music emulation")
#endif() #endif()
# [ZDoom] Set always to OFF.
set(BUILD_SHARED_LIBS OFF)
# Check for GCC "visibility" support. # Check for GCC "visibility" support.
if (CMAKE_COMPILER_IS_GNUCXX) if (CMAKE_COMPILER_IS_GNUCXX)
check_cxx_compiler_flag (-fvisibility=hidden __LIBGME_TEST_VISIBILITY) check_cxx_compiler_flag (-fvisibility=hidden __LIBGME_TEST_VISIBILITY)
@ -101,10 +104,17 @@ if (CMAKE_COMPILER_IS_GNUCXX)
endif() endif()
endif() endif()
endif() # test visibility endif() # test visibility
endif()
# Cache this result # Cache this result
set( LIBGME_HAVE_GCC_VISIBILITY ${ENABLE_VISIBILITY} CACHE BOOL "GCC support for hidden visibility") set( LIBGME_HAVE_GCC_VISIBILITY ${ENABLE_VISIBILITY} CACHE BOOL "GCC support for hidden visibility")
endif()
# Shared library defined here # Shared library defined here
add_subdirectory(gme) add_subdirectory(gme)
# EXCLUDE_FROM_ALL adds build rules but keeps it out of default build
# [ZDoom] Not needed.
if( FALSE )
add_subdirectory(player EXCLUDE_FROM_ALL)
add_subdirectory(demo EXCLUDE_FROM_ALL)
endif()

View file

@ -1,6 +1,18 @@
Game_Music_Emu Change Log Game_Music_Emu Change Log
------------------------- -------------------------
Game_Music_Emu 0.6.1
--------------------
- Moved repository to Bitbucket since Google Code announced they would
shutdown this year.
- Packaging improvements:
- Honor $LIB_SUFFIX for installed pkg-config metadata.
- Support setting BUILD_SHARED_LIBS to OFF to build libgme as a static
library. (Pass -DBUILD_SHARED_LIBS=OFF when running cmake).
Thanks to lachs0r.
Game_Music_Emu 0.6.0 Game_Music_Emu 0.6.0
-------------------- --------------------

View file

@ -1,10 +1,11 @@
Game_Music_Emu 0.6.0 Game_Music_Emu 0.6.1
-------------------- --------------------
Author : Shay Green <gblargg@gmail.com> Author : Shay Green <gblargg@gmail.com>
Website: http://www.slack.net/~ant/libs/ Maintainer : Michael Pyne <mpyne@purinchu.net>
Forum : http://groups.google.com/group/blargg-sound-libs Website : http://www.slack.net/~ant/libs/
Source : https://code.google.com/p/game-music-emu/ Forum : http://groups.google.com/group/blargg-sound-libs
License: GNU Lesser General Public License (LGPL) Source : https://bitbucket.org/mpyne/game-music-emu/
License : GNU Lesser General Public License (LGPL), see LICENSE.txt
Contents Contents
-------- --------

View file

@ -131,6 +131,12 @@ set (EXPORTED_HEADERS gme.h)
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/gme_types.h.in configure_file(${CMAKE_CURRENT_SOURCE_DIR}/gme_types.h.in
${CMAKE_CURRENT_BINARY_DIR}/gme_types.h) ${CMAKE_CURRENT_BINARY_DIR}/gme_types.h)
# [ZDoom] Not needed.
if( FALSE )
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/libgme.pc.in
${CMAKE_CURRENT_BINARY_DIR}/libgme.pc @ONLY)
endif()
# On some platforms we may need to change headers or whatnot based on whether # On some platforms we may need to change headers or whatnot based on whether
# we're building the library or merely using the library. The following is # we're building the library or merely using the library. The following is
# only defined when building the library to allow us to tell which is which. # only defined when building the library to allow us to tell which is which.
@ -147,7 +153,18 @@ add_library(gme ${libgme_SRCS})
# to the API), the SOVERSION should be the same even when bumping up VERSION. # to the API), the SOVERSION should be the same even when bumping up VERSION.
# The way gme.h is designed, SOVERSION should very rarely be bumped, if ever. # The way gme.h is designed, SOVERSION should very rarely be bumped, if ever.
# Hopefully the API can stay compatible with old versions. # Hopefully the API can stay compatible with old versions.
#set_target_properties(gme # [ZDoom] Not needed.
# PROPERTIES VERSION ${GME_VERSION} if( FALSE )
# SOVERSION 0) set_target_properties(gme
PROPERTIES VERSION ${GME_VERSION}
SOVERSION 0)
install(TARGETS gme LIBRARY DESTINATION lib${LIB_SUFFIX}
RUNTIME DESTINATION bin # DLL platforms
ARCHIVE DESTINATION lib) # DLL platforms
install(FILES ${EXPORTED_HEADERS} DESTINATION include/gme)
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/libgme.pc DESTINATION lib${LIB_SUFFIX}/pkgconfig)
endif()
target_link_libraries(gme) target_link_libraries(gme)

View file

@ -129,6 +129,8 @@ private:
}; };
#ifdef HAVE_ZLIB_H #ifdef HAVE_ZLIB_H
#include <zlib.h>
// Gzip compressed file reader // Gzip compressed file reader
class Gzip_File_Reader : public File_Reader { class Gzip_File_Reader : public File_Reader {
public: public:
@ -143,7 +145,7 @@ public:
long tell() const; long tell() const;
blargg_err_t seek( long ); blargg_err_t seek( long );
private: private:
void* file_; gzFile file_;
long size_; long size_;
}; };
#endif #endif

View file

@ -178,6 +178,11 @@ blargg_long Music_Emu::msec_to_samples( blargg_long msec ) const
return (sec * sample_rate() + msec * sample_rate() / 1000) * stereo; return (sec * sample_rate() + msec * sample_rate() / 1000) * stereo;
} }
long Music_Emu::tell_samples() const
{
return out_time;
}
long Music_Emu::tell() const long Music_Emu::tell() const
{ {
blargg_long rate = sample_rate() * stereo; blargg_long rate = sample_rate() * stereo;
@ -185,14 +190,18 @@ long Music_Emu::tell() const
return sec * 1000 + (out_time - sec * rate) * 1000 / rate; return sec * 1000 + (out_time - sec * rate) * 1000 / rate;
} }
blargg_err_t Music_Emu::seek( long msec ) blargg_err_t Music_Emu::seek_samples( long time )
{ {
blargg_long time = msec_to_samples( msec );
if ( time < out_time ) if ( time < out_time )
RETURN_ERR( start_track( current_track_ ) ); RETURN_ERR( start_track( current_track_ ) );
return skip( time - out_time ); return skip( time - out_time );
} }
blargg_err_t Music_Emu::seek( long msec )
{
return seek_samples( msec_to_samples( msec ) );
}
blargg_err_t Music_Emu::skip( long count ) blargg_err_t Music_Emu::skip( long count )
{ {
require( current_track() >= 0 ); // start_track() must have been called already require( current_track() >= 0 ); // start_track() must have been called already

View file

@ -41,9 +41,15 @@ public:
// Number of milliseconds (1000 msec = 1 second) played since beginning of track // Number of milliseconds (1000 msec = 1 second) played since beginning of track
long tell() const; long tell() const;
// Number of samples generated since beginning of track
long tell_samples() const;
// Seek to new time in track. Seeking backwards or far forward can take a while. // Seek to new time in track. Seeking backwards or far forward can take a while.
blargg_err_t seek( long msec ); blargg_err_t seek( long msec );
// Equivalent to restarting track then skipping n samples
blargg_err_t seek_samples( long n );
// Skip n samples // Skip n samples
blargg_err_t skip( long n ); blargg_err_t skip( long n );

View file

@ -433,9 +433,7 @@ void Snes_Spc::cpu_write( int data, int addr, rel_time_t time )
#endif #endif
// Registers other than $F2 and $F4-$F7 // Registers other than $F2 and $F4-$F7
//if ( reg != 2 && reg != 4 && reg != 5 && reg != 6 && reg != 7 ) if ( reg != 2 && (reg < 4 || reg > 7) ) // 36%
// TODO: this is a bit on the fragile side
if ( ((~0x2F00 << (bits_in_int - 16)) << reg) < 0 ) // 36%
cpu_write_smp_reg( data, time, reg ); cpu_write_smp_reg( data, time, reg );
} }
// High mem/address wrap-around // High mem/address wrap-around

View file

@ -77,7 +77,7 @@ Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */
#define SPC_NO_SP_WRAPAROUND 0 #define SPC_NO_SP_WRAPAROUND 0
#define SET_SP( v ) (sp = ram + 0x101 + ((uint8_t) v)) #define SET_SP( v ) (sp = ram + 0x101 + ((uint8_t) v))
#define GET_SP() (uint8_t) (sp - 0x101 - ram) #define GET_SP() (uint8_t (sp - 0x101 - ram))
#if SPC_NO_SP_WRAPAROUND #if SPC_NO_SP_WRAPAROUND
#define PUSH16( v ) (sp -= 2, SET_LE16( sp, v )) #define PUSH16( v ) (sp -= 2, SET_LE16( sp, v ))

View file

@ -337,7 +337,9 @@ BLARGG_EXPORT gme_err_t gme_play ( Music_Emu* me, int n, short* p )
BLARGG_EXPORT void gme_set_fade ( Music_Emu* me, int start_msec ) { me->set_fade( start_msec ); } BLARGG_EXPORT void gme_set_fade ( Music_Emu* me, int start_msec ) { me->set_fade( start_msec ); }
BLARGG_EXPORT int gme_track_ended ( Music_Emu const* me ) { return me->track_ended(); } BLARGG_EXPORT int gme_track_ended ( Music_Emu const* me ) { return me->track_ended(); }
BLARGG_EXPORT int gme_tell ( Music_Emu const* me ) { return me->tell(); } BLARGG_EXPORT int gme_tell ( Music_Emu const* me ) { return me->tell(); }
BLARGG_EXPORT int gme_tell_samples ( Music_Emu const* me ) { return me->tell_samples(); }
BLARGG_EXPORT gme_err_t gme_seek ( Music_Emu* me, int msec ) { return me->seek( msec ); } BLARGG_EXPORT gme_err_t gme_seek ( Music_Emu* me, int msec ) { return me->seek( msec ); }
BLARGG_EXPORT gme_err_t gme_seek_samples ( Music_Emu* me, int n ) { return me->seek_samples( n ); }
BLARGG_EXPORT int gme_voice_count ( Music_Emu const* me ) { return me->voice_count(); } BLARGG_EXPORT int gme_voice_count ( Music_Emu const* me ) { return me->voice_count(); }
BLARGG_EXPORT void gme_ignore_silence ( Music_Emu* me, int disable ) { me->ignore_silence( disable != 0 ); } BLARGG_EXPORT void gme_ignore_silence ( Music_Emu* me, int disable ) { me->ignore_silence( disable != 0 ); }
BLARGG_EXPORT void gme_set_tempo ( Music_Emu* me, double t ) { me->set_tempo( t ); } BLARGG_EXPORT void gme_set_tempo ( Music_Emu* me, double t ) { me->set_tempo( t ); }

View file

@ -1,6 +1,6 @@
/* Game music emulator library C interface (also usable from C++) */ /* Game music emulator library C interface (also usable from C++) */
/* Game_Music_Emu 0.6.0 */ /* Game_Music_Emu 0.6.1 */
#ifndef GME_H #ifndef GME_H
#define GME_H #define GME_H
@ -8,7 +8,7 @@
extern "C" { extern "C" {
#endif #endif
#define GME_VERSION 0x000600 /* 1 byte major, 1 byte minor, 1 byte patch-level */ #define GME_VERSION 0x000601 /* 1 byte major, 1 byte minor, 1 byte patch-level */
/* Error string returned by library functions, or NULL if no error (success) */ /* Error string returned by library functions, or NULL if no error (success) */
typedef const char* gme_err_t; typedef const char* gme_err_t;
@ -47,9 +47,15 @@ int gme_track_ended( Music_Emu const* );
/* Number of milliseconds (1000 = one second) played since beginning of track */ /* Number of milliseconds (1000 = one second) played since beginning of track */
int gme_tell( Music_Emu const* ); int gme_tell( Music_Emu const* );
/* Number of samples generated since beginning of track */
int gme_tell_samples( Music_Emu const* );
/* Seek to new time in track. Seeking backwards or far forward can take a while. */ /* Seek to new time in track. Seeking backwards or far forward can take a while. */
gme_err_t gme_seek( Music_Emu*, int msec ); gme_err_t gme_seek( Music_Emu*, int msec );
/* Equivalent to restarting track then skipping n samples */
gme_err_t gme_seek_samples( Music_Emu*, int n );
/******** Informational ********/ /******** Informational ********/

View file

@ -1,4 +1,4 @@
Game_Music_Emu 0.6.0: Game Music Emulators Game_Music_Emu 0.6.1: Game Music Emulators
------------------------------------------ ------------------------------------------
Game_Music_Emu is a collection of video game music file emulators that Game_Music_Emu is a collection of video game music file emulators that
support the following formats and systems: support the following formats and systems:
@ -38,26 +38,42 @@ Website: http://www.slack.net/~ant/
Forum : http://groups.google.com/group/blargg-sound-libs Forum : http://groups.google.com/group/blargg-sound-libs
License: GNU Lesser General Public License (LGPL) License: GNU Lesser General Public License (LGPL)
Current Maintainer: Michael Pyne <mpyne@purinchu.net>
Getting Started Getting Started
--------------- ---------------
Build a program consisting of demo/basics.c, demo/Wave_Writer.cpp, and Build a program consisting of demo/basics.c, demo/Wave_Writer.cpp, and
all source files in gme/. If you have CMake 2.6 or later, execute all source files in gme/.
run cmake Or, if you have CMake 2.6 or later, execute at a command prompt (from the
cd demo extracted source directory):
run make
Be sure "test.nsf" is in the same directory as the program. Running it mkdir build
cd build
cmake ../ # <-- Pass any needed CMake flags here
make # To build the library
cd demo
make # To build the demo itself
Be sure "test.nsf" is in the same directory as the demo program. Running it
should generate the recording "out.wav". should generate the recording "out.wav".
You can use "make install" to install the library. To choose where to install
the library to, use the CMake argument "-DCMAKE_INSTALL_PREFIX=/usr/local"
(and replace /usr/local with the base path you wish to use). Alternately, you
can specify the base path to install to when you run "make install" by passing
'DESTDIR=/usr/local' on the make install command line (again, replace
/usr/local as appropriate).
To build a static library instead of shared (the default), pass
-DBUILD_SHARED_LIBS=OFF to the cmake command when running cmake.
A slightly more extensive demo application is available in the player/ A slightly more extensive demo application is available in the player/
directory. It requires SDL to build. directory. It requires SDL to build.
Read gme.txt for more information. Post to the discussion forum for Read gme.txt for more information. Post to the discussion forum for
assistance. assistance.
Files Files
----- -----
gme.txt General notes about the library gme.txt General notes about the library

View file

@ -1523,8 +1523,6 @@ static bool C_HandleKey (event_t *ev, FCommandBuffer &buffer)
buffer.Text.StripLeftRight(); buffer.Text.StripLeftRight();
Printf(127, TEXTCOLOR_WHITE "]%s\n", buffer.Text.GetChars()); Printf(127, TEXTCOLOR_WHITE "]%s\n", buffer.Text.GetChars());
AddCommandString(buffer.Text.LockBuffer());
buffer.Text.UnlockBuffer();
if (buffer.Text.Len() == 0) if (buffer.Text.Len() == 0)
{ {
@ -1568,7 +1566,21 @@ static bool C_HandleKey (event_t *ev, FCommandBuffer &buffer)
} }
} }
HistPos = NULL; HistPos = NULL;
buffer.SetString(""); {
// Work with a copy of command to avoid side effects caused by
// exception raised during execution, like with 'error' CCMD.
// It's problematic to maintain FString's lock symmetry.
static TArray<char> command;
const size_t length = buffer.Text.Len();
command.Resize(length + 1);
memcpy(&command[0], buffer.Text.GetChars(), length);
command[length] = '\0';
buffer.SetString("");
AddCommandString(&command[0]);
}
TabbedLast = false; TabbedLast = false;
TabbedList = false; TabbedList = false;
break; break;

View file

@ -80,6 +80,7 @@ enum
CP_CLEARSPECIAL, CP_CLEARSPECIAL,
CP_SETACTIVATION, CP_SETACTIVATION,
CP_SECTORFLOOROFFSET, CP_SECTORFLOOROFFSET,
CP_SETSECTORSPECIAL,
CP_SETWALLYSCALE, CP_SETWALLYSCALE,
CP_SETTHINGZ, CP_SETTHINGZ,
CP_SETTAG, CP_SETTAG,
@ -294,6 +295,15 @@ void ParseCompatibility()
sc.MustGetFloat(); sc.MustGetFloat();
CompatParams.Push(int(sc.Float*65536.)); CompatParams.Push(int(sc.Float*65536.));
} }
else if (sc.Compare("setsectorspecial"))
{
if (flags.ExtCommandIndex == ~0u) flags.ExtCommandIndex = CompatParams.Size();
CompatParams.Push(CP_SETSECTORSPECIAL);
sc.MustGetNumber();
CompatParams.Push(sc.Number);
sc.MustGetNumber();
CompatParams.Push(sc.Number);
}
else if (sc.Compare("setwallyscale")) else if (sc.Compare("setwallyscale"))
{ {
if (flags.ExtCommandIndex == ~0u) flags.ExtCommandIndex = CompatParams.Size(); if (flags.ExtCommandIndex == ~0u) flags.ExtCommandIndex = CompatParams.Size();
@ -529,6 +539,16 @@ void SetCompatibilityParams()
i += 3; i += 3;
break; break;
} }
case CP_SETSECTORSPECIAL:
{
const int index = CompatParams[i + 1];
if (index < numsectors)
{
sectors[index].special = CompatParams[i + 2];
}
i += 3;
break;
}
case CP_SETWALLYSCALE: case CP_SETWALLYSCALE:
{ {
if (CompatParams[i+1] < numlines) if (CompatParams[i+1] < numlines)

View file

@ -1232,6 +1232,7 @@ DThinker *FDecalStretcherAnim::CreateThinker (DBaseDecal *actor, side_t *wall) c
} }
else else
{ {
thinker->GoalX = 0;
thinker->bStretchX = false; thinker->bStretchX = false;
} }
if (GoalY >= 0) if (GoalY >= 0)
@ -1241,6 +1242,7 @@ DThinker *FDecalStretcherAnim::CreateThinker (DBaseDecal *actor, side_t *wall) c
} }
else else
{ {
thinker->GoalY = 0;
thinker->bStretchY = false; thinker->bStretchY = false;
} }
thinker->bStarted = false; thinker->bStarted = false;

View file

@ -6846,3 +6846,33 @@ DEFINE_ACTION_FUNCTION(AActor, A_CheckTerrain)
} }
return 0; return 0;
} }
DEFINE_ACTION_FUNCTION(AActor, A_SetSize)
{
PARAM_SELF_PROLOGUE(AActor);
PARAM_FLOAT(newradius);
PARAM_FLOAT_DEF(newheight);
PARAM_BOOL_DEF(testpos);
if (newradius < 0.) newradius = self->radius;
if (newheight < 0.) newheight = self->Height;
double oldradius = self->radius;
double oldheight = self->Height;
self->UnlinkFromWorld();
self->radius = newradius;
self->Height = newheight;
self->LinkToWorld();
if (testpos && !P_TestMobjLocation(self))
{
self->UnlinkFromWorld();
self->radius = oldradius;
self->Height = oldheight;
self->LinkToWorld();
ACTION_RETURN_BOOL(false);
}
ACTION_RETURN_BOOL(true);
}

View file

@ -31,6 +31,7 @@
#include "p_lnspec.h" #include "p_lnspec.h"
#include "doomstat.h" #include "doomstat.h"
#include "p_maputl.h"
// State. // State.
#include "r_state.h" #include "r_state.h"
@ -914,7 +915,7 @@ void DPhased::Tick ()
int DPhased::PhaseHelper (sector_t *sector, int index, int light, sector_t *prev) int DPhased::PhaseHelper (sector_t *sector, int index, int light, sector_t *prev)
{ {
if (!sector) if (!sector || sector->validcount == validcount)
{ {
return index; return index;
} }
@ -922,6 +923,7 @@ int DPhased::PhaseHelper (sector_t *sector, int index, int light, sector_t *prev
{ {
DPhased *l; DPhased *l;
int baselevel = sector->lightlevel ? sector->lightlevel : light; int baselevel = sector->lightlevel ? sector->lightlevel : light;
sector->validcount = validcount;
if (index == 0) if (index == 0)
{ {
@ -958,6 +960,7 @@ DPhased::DPhased (sector_t *sector, int baselevel)
DPhased::DPhased (sector_t *sector) DPhased::DPhased (sector_t *sector)
: DLighting (sector) : DLighting (sector)
{ {
validcount++;
PhaseHelper (sector, 0, 0, NULL); PhaseHelper (sector, 0, 0, NULL);
} }

View file

@ -96,17 +96,15 @@ namespace swrenderer
uint8_t *dc_destorg; uint8_t *dc_destorg;
int dc_destheight; int dc_destheight;
int dc_count; int dc_count;
uint32_t vplce[4]; uint32_t dc_wall_texturefrac[4];
uint32_t vince[4]; uint32_t dc_wall_iscale[4];
uint8_t *palookupoffse[4]; uint8_t *dc_wall_colormap[4];
fixed_t palookuplight[4]; fixed_t dc_wall_light[4];
const uint8_t *bufplce[4]; const uint8_t *dc_wall_source[4];
const uint8_t *bufplce2[4]; const uint8_t *dc_wall_source2[4];
uint32_t buftexturefracx[4]; uint32_t dc_wall_texturefracx[4];
uint32_t bufheight[4]; uint32_t dc_wall_sourceheight[4];
int vlinebits; int dc_wall_fracbits;
int mvlinebits;
int tmvlinebits;
int ds_y; int ds_y;
int ds_x1; int ds_x1;
int ds_x2; int ds_x2;
@ -497,50 +495,35 @@ namespace swrenderer
return tex->GetColumn(col, nullptr); return tex->GetColumn(col, nullptr);
} }
bool R_GetTransMaskDrawers(fixed_t(**tmvline1)(), void(**tmvline4)()) bool R_GetTransMaskDrawers(void(**drawCol1)(), void(**drawCol4)())
{ {
if (colfunc == R_DrawAddColumn) if (colfunc == R_DrawAddColumn)
{ {
*tmvline1 = tmvline1_add; *drawCol1 = R_DrawWallAddCol1;
*tmvline4 = tmvline4_add; *drawCol4 = R_DrawWallAddCol4;
return true; return true;
} }
if (colfunc == R_DrawAddClampColumn) if (colfunc == R_DrawAddClampColumn)
{ {
*tmvline1 = tmvline1_addclamp; *drawCol1 = R_DrawWallAddClampCol1;
*tmvline4 = tmvline4_addclamp; *drawCol4 = R_DrawWallAddClampCol4;
return true; return true;
} }
if (colfunc == R_DrawSubClampColumn) if (colfunc == R_DrawSubClampColumn)
{ {
*tmvline1 = tmvline1_subclamp; *drawCol1 = R_DrawWallSubClampCol1;
*tmvline4 = tmvline4_subclamp; *drawCol4 = R_DrawWallSubClampCol4;
return true; return true;
} }
if (colfunc == R_DrawRevSubClampColumn) if (colfunc == R_DrawRevSubClampColumn)
{ {
*tmvline1 = tmvline1_revsubclamp; *drawCol1 = R_DrawWallRevSubClampCol1;
*tmvline4 = tmvline4_revsubclamp; *drawCol4 = R_DrawWallRevSubClampCol4;
return true; return true;
} }
return false; return false;
} }
void setupvline(int fracbits)
{
drawerargs::vlinebits = fracbits;
}
void setupmvline(int fracbits)
{
drawerargs::mvlinebits = fracbits;
}
void setuptmvline(int fracbits)
{
drawerargs::tmvlinebits = fracbits;
}
void R_SetColorMapLight(lighttable_t *base_colormap, float light, int shade) void R_SetColorMapLight(lighttable_t *base_colormap, float light, int shade)
{ {
using namespace drawerargs; using namespace drawerargs;
@ -548,6 +531,11 @@ namespace swrenderer
dc_colormap = base_colormap + (GETPALOOKUP(light, shade) << COLORMAPSHIFT); dc_colormap = base_colormap + (GETPALOOKUP(light, shade) << COLORMAPSHIFT);
} }
void R_SetColorMapLight(FDynamicColormap *base_colormap, float light, int shade)
{
R_SetColorMapLight(base_colormap->Maps, light, shade);
}
void R_SetDSColorMapLight(lighttable_t *base_colormap, float light, int shade) void R_SetDSColorMapLight(lighttable_t *base_colormap, float light, int shade)
{ {
using namespace drawerargs; using namespace drawerargs;
@ -555,6 +543,11 @@ namespace swrenderer
ds_colormap = base_colormap + (GETPALOOKUP(light, shade) << COLORMAPSHIFT); ds_colormap = base_colormap + (GETPALOOKUP(light, shade) << COLORMAPSHIFT);
} }
void R_SetDSColorMapLight(FDynamicColormap *base_colormap, float light, int shade)
{
R_SetDSColorMapLight(base_colormap->Maps, light, shade);
}
void R_SetTranslationMap(lighttable_t *translation) void R_SetTranslationMap(lighttable_t *translation)
{ {
using namespace drawerargs; using namespace drawerargs;
@ -963,118 +956,64 @@ namespace swrenderer
rt_revsubclamp4cols(sx, yl, yh); rt_revsubclamp4cols(sx, yl, yh);
} }
uint32_t vlinec1() void R_DrawWallCol1()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWall1PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWall1PalCommand>();
return dc_texturefrac + dc_count * dc_iscale;
} }
void vlinec4() void R_DrawWallCol4()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWall4PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWall4PalCommand>();
for (int i = 0; i < 4; i++)
vplce[i] += vince[i] * dc_count;
} }
uint32_t mvlinec1() void R_DrawWallMaskedCol1()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallMasked1PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallMasked1PalCommand>();
return dc_texturefrac + dc_count * dc_iscale;
} }
void mvlinec4() void R_DrawWallMaskedCol4()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallMasked4PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallMasked4PalCommand>();
for (int i = 0; i < 4; i++)
vplce[i] += vince[i] * dc_count;
} }
fixed_t tmvline1_add() void R_DrawWallAddCol1()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallAdd1PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallAdd1PalCommand>();
return dc_texturefrac + dc_count * dc_iscale;
} }
void tmvline4_add() void R_DrawWallAddCol4()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallAdd4PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallAdd4PalCommand>();
for (int i = 0; i < 4; i++)
vplce[i] += vince[i] * dc_count;
} }
fixed_t tmvline1_addclamp() void R_DrawWallAddClampCol1()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallAddClamp1PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallAddClamp1PalCommand>();
return dc_texturefrac + dc_count * dc_iscale;
} }
void tmvline4_addclamp() void R_DrawWallAddClampCol4()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallAddClamp4PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallAddClamp4PalCommand>();
for (int i = 0; i < 4; i++)
vplce[i] += vince[i] * dc_count;
} }
fixed_t tmvline1_subclamp() void R_DrawWallSubClampCol1()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallSubClamp1PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallSubClamp1PalCommand>();
return dc_texturefrac + dc_count * dc_iscale;
} }
void tmvline4_subclamp() void R_DrawWallSubClampCol4()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallSubClamp4PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallSubClamp4PalCommand>();
for (int i = 0; i < 4; i++)
vplce[i] += vince[i] * dc_count;
} }
fixed_t tmvline1_revsubclamp() void R_DrawWallRevSubClampCol1()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallRevSubClamp1PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallRevSubClamp1PalCommand>();
return dc_texturefrac + dc_count * dc_iscale;
} }
void tmvline4_revsubclamp() void R_DrawWallRevSubClampCol4()
{ {
using namespace drawerargs;
DrawerCommandQueue::QueueCommand<DrawWallRevSubClamp4PalCommand>(); DrawerCommandQueue::QueueCommand<DrawWallRevSubClamp4PalCommand>();
for (int i = 0; i < 4; i++)
vplce[i] += vince[i] * dc_count;
} }
void R_DrawSingleSkyCol1(uint32_t solid_top, uint32_t solid_bottom) void R_DrawSingleSkyCol1(uint32_t solid_top, uint32_t solid_bottom)

View file

@ -41,17 +41,15 @@ namespace swrenderer
extern int dc_destheight; extern int dc_destheight;
extern int dc_count; extern int dc_count;
extern uint32_t vplce[4]; extern uint32_t dc_wall_texturefrac[4];
extern uint32_t vince[4]; extern uint32_t dc_wall_iscale[4];
extern uint8_t *palookupoffse[4]; extern uint8_t *dc_wall_colormap[4];
extern fixed_t palookuplight[4]; extern fixed_t dc_wall_light[4];
extern const uint8_t *bufplce[4]; extern const uint8_t *dc_wall_source[4];
extern const uint8_t *bufplce2[4]; extern const uint8_t *dc_wall_source2[4];
extern uint32_t buftexturefracx[4]; extern uint32_t dc_wall_texturefracx[4];
extern uint32_t bufheight[4]; extern uint32_t dc_wall_sourceheight[4];
extern int vlinebits; extern int dc_wall_fracbits;
extern int mvlinebits;
extern int tmvlinebits;
extern int ds_y; extern int ds_y;
extern int ds_x1; extern int ds_x1;
@ -100,7 +98,7 @@ namespace swrenderer
ESPSResult R_SetPatchStyle(FRenderStyle style, fixed_t alpha, int translation, uint32_t color); ESPSResult R_SetPatchStyle(FRenderStyle style, fixed_t alpha, int translation, uint32_t color);
ESPSResult R_SetPatchStyle(FRenderStyle style, float alpha, int translation, uint32_t color); ESPSResult R_SetPatchStyle(FRenderStyle style, float alpha, int translation, uint32_t color);
void R_FinishSetPatchStyle(); // Call this after finished drawing the current thing, in case its style was STYLE_Shade void R_FinishSetPatchStyle(); // Call this after finished drawing the current thing, in case its style was STYLE_Shade
bool R_GetTransMaskDrawers(fixed_t(**tmvline1)(), void(**tmvline4)()); bool R_GetTransMaskDrawers(void(**drawCol1)(), void(**drawCol4)());
const uint8_t *R_GetColumn(FTexture *tex, int col); const uint8_t *R_GetColumn(FTexture *tex, int col);
@ -162,29 +160,21 @@ namespace swrenderer
void R_SetupDrawSlab(uint8_t *colormap); void R_SetupDrawSlab(uint8_t *colormap);
void R_DrawSlab(int dx, fixed_t v, int dy, fixed_t vi, const uint8_t *vptr, uint8_t *p); void R_DrawSlab(int dx, fixed_t v, int dy, fixed_t vi, const uint8_t *vptr, uint8_t *p);
void R_DrawFogBoundary(int x1, int x2, short *uclip, short *dclip); void R_DrawFogBoundary(int x1, int x2, short *uclip, short *dclip);
uint32_t vlinec1();
void vlinec4();
uint32_t mvlinec1();
void mvlinec4();
fixed_t tmvline1_add();
void tmvline4_add();
fixed_t tmvline1_addclamp();
void tmvline4_addclamp();
fixed_t tmvline1_subclamp();
void tmvline4_subclamp();
fixed_t tmvline1_revsubclamp();
void tmvline4_revsubclamp();
void R_FillColumnHoriz(); void R_FillColumnHoriz();
void R_FillSpan(); void R_FillSpan();
inline uint32_t dovline1() { return vlinec1(); } void R_DrawWallCol1();
inline void dovline4() { vlinec4(); } void R_DrawWallCol4();
inline uint32_t domvline1() { return mvlinec1(); } void R_DrawWallMaskedCol1();
inline void domvline4() { mvlinec4(); } void R_DrawWallMaskedCol4();
void R_DrawWallAddCol1();
void setupvline(int fracbits); void R_DrawWallAddCol4();
void setupmvline(int fracbits); void R_DrawWallAddClampCol1();
void setuptmvline(int fracbits); void R_DrawWallAddClampCol4();
void R_DrawWallSubClampCol1();
void R_DrawWallSubClampCol4();
void R_DrawWallRevSubClampCol1();
void R_DrawWallRevSubClampCol4();
void R_DrawSingleSkyCol1(uint32_t solid_top, uint32_t solid_bottom); void R_DrawSingleSkyCol1(uint32_t solid_top, uint32_t solid_bottom);
void R_DrawSingleSkyCol4(uint32_t solid_top, uint32_t solid_bottom); void R_DrawSingleSkyCol4(uint32_t solid_top, uint32_t solid_bottom);
@ -192,7 +182,9 @@ namespace swrenderer
void R_DrawDoubleSkyCol4(uint32_t solid_top, uint32_t solid_bottom); void R_DrawDoubleSkyCol4(uint32_t solid_top, uint32_t solid_bottom);
void R_SetColorMapLight(lighttable_t *base_colormap, float light, int shade); void R_SetColorMapLight(lighttable_t *base_colormap, float light, int shade);
void R_SetColorMapLight(FDynamicColormap *base_colormap, float light, int shade);
void R_SetDSColorMapLight(lighttable_t *base_colormap, float light, int shade); void R_SetDSColorMapLight(lighttable_t *base_colormap, float light, int shade);
void R_SetDSColorMapLight(FDynamicColormap *base_colormap, float light, int shade);
void R_SetTranslationMap(lighttable_t *translation); void R_SetTranslationMap(lighttable_t *translation);
void R_SetupSpanBits(FTexture *tex); void R_SetupSpanBits(FTexture *tex);

View file

@ -95,9 +95,7 @@ namespace swrenderer
_count = dc_count; _count = dc_count;
_source = dc_source; _source = dc_source;
_dest = dc_dest; _dest = dc_dest;
_vlinebits = vlinebits; _fracbits = dc_wall_fracbits;
_mvlinebits = mvlinebits;
_tmvlinebits = tmvlinebits;
_pitch = dc_pitch; _pitch = dc_pitch;
_srcblend = dc_srcblend; _srcblend = dc_srcblend;
_destblend = dc_destblend; _destblend = dc_destblend;
@ -110,15 +108,13 @@ namespace swrenderer
_dest = dc_dest; _dest = dc_dest;
_count = dc_count; _count = dc_count;
_pitch = dc_pitch; _pitch = dc_pitch;
_vlinebits = vlinebits; _fracbits = dc_wall_fracbits;
_mvlinebits = mvlinebits;
_tmvlinebits = tmvlinebits;
for (int col = 0; col < 4; col++) for (int col = 0; col < 4; col++)
{ {
_palookupoffse[col] = palookupoffse[col]; _colormap[col] = dc_wall_colormap[col];
_bufplce[col] = bufplce[col]; _source[col] = dc_wall_source[col];
_vince[col] = vince[col]; _iscale[col] = dc_wall_iscale[col];
_vplce[col] = vplce[col]; _texturefrac[col] = dc_wall_texturefrac[col];
} }
_srcblend = dc_srcblend; _srcblend = dc_srcblend;
_destblend = dc_destblend; _destblend = dc_destblend;
@ -132,7 +128,7 @@ namespace swrenderer
int count = _count; int count = _count;
const uint8_t *source = _source; const uint8_t *source = _source;
uint8_t *dest = _dest; uint8_t *dest = _dest;
int bits = _vlinebits; int bits = _fracbits;
int pitch = _pitch; int pitch = _pitch;
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
@ -156,24 +152,24 @@ namespace swrenderer
{ {
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int bits = _vlinebits; int bits = _fracbits;
uint32_t place; uint32_t place;
auto pal0 = _palookupoffse[0]; auto pal0 = _colormap[0];
auto pal1 = _palookupoffse[1]; auto pal1 = _colormap[1];
auto pal2 = _palookupoffse[2]; auto pal2 = _colormap[2];
auto pal3 = _palookupoffse[3]; auto pal3 = _colormap[3];
auto buf0 = _bufplce[0]; auto buf0 = _source[0];
auto buf1 = _bufplce[1]; auto buf1 = _source[1];
auto buf2 = _bufplce[2]; auto buf2 = _source[2];
auto buf3 = _bufplce[3]; auto buf3 = _source[3];
auto vince0 = _vince[0]; auto dc_wall_iscale0 = _iscale[0];
auto vince1 = _vince[1]; auto dc_wall_iscale1 = _iscale[1];
auto vince2 = _vince[2]; auto dc_wall_iscale2 = _iscale[2];
auto vince3 = _vince[3]; auto dc_wall_iscale3 = _iscale[3];
auto vplce0 = _vplce[0]; auto dc_wall_texturefrac0 = _texturefrac[0];
auto vplce1 = _vplce[1]; auto dc_wall_texturefrac1 = _texturefrac[1];
auto vplce2 = _vplce[2]; auto dc_wall_texturefrac2 = _texturefrac[2];
auto vplce3 = _vplce[3]; auto dc_wall_texturefrac3 = _texturefrac[3];
auto pitch = _pitch; auto pitch = _pitch;
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
@ -182,22 +178,22 @@ namespace swrenderer
int skipped = thread->skipped_by_thread(_dest_y); int skipped = thread->skipped_by_thread(_dest_y);
dest = thread->dest_for_thread(_dest_y, pitch, dest); dest = thread->dest_for_thread(_dest_y, pitch, dest);
vplce0 += vince0 * skipped; dc_wall_texturefrac0 += dc_wall_iscale0 * skipped;
vplce1 += vince1 * skipped; dc_wall_texturefrac1 += dc_wall_iscale1 * skipped;
vplce2 += vince2 * skipped; dc_wall_texturefrac2 += dc_wall_iscale2 * skipped;
vplce3 += vince3 * skipped; dc_wall_texturefrac3 += dc_wall_iscale3 * skipped;
vince0 *= thread->num_cores; dc_wall_iscale0 *= thread->num_cores;
vince1 *= thread->num_cores; dc_wall_iscale1 *= thread->num_cores;
vince2 *= thread->num_cores; dc_wall_iscale2 *= thread->num_cores;
vince3 *= thread->num_cores; dc_wall_iscale3 *= thread->num_cores;
pitch *= thread->num_cores; pitch *= thread->num_cores;
do do
{ {
dest[0] = pal0[buf0[(place = vplce0) >> bits]]; vplce0 = place + vince0; dest[0] = pal0[buf0[(place = dc_wall_texturefrac0) >> bits]]; dc_wall_texturefrac0 = place + dc_wall_iscale0;
dest[1] = pal1[buf1[(place = vplce1) >> bits]]; vplce1 = place + vince1; dest[1] = pal1[buf1[(place = dc_wall_texturefrac1) >> bits]]; dc_wall_texturefrac1 = place + dc_wall_iscale1;
dest[2] = pal2[buf2[(place = vplce2) >> bits]]; vplce2 = place + vince2; dest[2] = pal2[buf2[(place = dc_wall_texturefrac2) >> bits]]; dc_wall_texturefrac2 = place + dc_wall_iscale2;
dest[3] = pal3[buf3[(place = vplce3) >> bits]]; vplce3 = place + vince3; dest[3] = pal3[buf3[(place = dc_wall_texturefrac3) >> bits]]; dc_wall_texturefrac3 = place + dc_wall_iscale3;
dest += pitch; dest += pitch;
} while (--count); } while (--count);
} }
@ -210,7 +206,7 @@ namespace swrenderer
int count = _count; int count = _count;
const uint8_t *source = _source; const uint8_t *source = _source;
uint8_t *dest = _dest; uint8_t *dest = _dest;
int bits = _mvlinebits; int bits = _fracbits;
int pitch = _pitch; int pitch = _pitch;
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
@ -238,24 +234,24 @@ namespace swrenderer
{ {
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int bits = _mvlinebits; int bits = _fracbits;
uint32_t place; uint32_t place;
auto pal0 = _palookupoffse[0]; auto pal0 = _colormap[0];
auto pal1 = _palookupoffse[1]; auto pal1 = _colormap[1];
auto pal2 = _palookupoffse[2]; auto pal2 = _colormap[2];
auto pal3 = _palookupoffse[3]; auto pal3 = _colormap[3];
auto buf0 = _bufplce[0]; auto buf0 = _source[0];
auto buf1 = _bufplce[1]; auto buf1 = _source[1];
auto buf2 = _bufplce[2]; auto buf2 = _source[2];
auto buf3 = _bufplce[3]; auto buf3 = _source[3];
auto vince0 = _vince[0]; auto dc_wall_iscale0 = _iscale[0];
auto vince1 = _vince[1]; auto dc_wall_iscale1 = _iscale[1];
auto vince2 = _vince[2]; auto dc_wall_iscale2 = _iscale[2];
auto vince3 = _vince[3]; auto dc_wall_iscale3 = _iscale[3];
auto vplce0 = _vplce[0]; auto dc_wall_texturefrac0 = _texturefrac[0];
auto vplce1 = _vplce[1]; auto dc_wall_texturefrac1 = _texturefrac[1];
auto vplce2 = _vplce[2]; auto dc_wall_texturefrac2 = _texturefrac[2];
auto vplce3 = _vplce[3]; auto dc_wall_texturefrac3 = _texturefrac[3];
auto pitch = _pitch; auto pitch = _pitch;
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
@ -264,24 +260,24 @@ namespace swrenderer
int skipped = thread->skipped_by_thread(_dest_y); int skipped = thread->skipped_by_thread(_dest_y);
dest = thread->dest_for_thread(_dest_y, pitch, dest); dest = thread->dest_for_thread(_dest_y, pitch, dest);
vplce0 += vince0 * skipped; dc_wall_texturefrac0 += dc_wall_iscale0 * skipped;
vplce1 += vince1 * skipped; dc_wall_texturefrac1 += dc_wall_iscale1 * skipped;
vplce2 += vince2 * skipped; dc_wall_texturefrac2 += dc_wall_iscale2 * skipped;
vplce3 += vince3 * skipped; dc_wall_texturefrac3 += dc_wall_iscale3 * skipped;
vince0 *= thread->num_cores; dc_wall_iscale0 *= thread->num_cores;
vince1 *= thread->num_cores; dc_wall_iscale1 *= thread->num_cores;
vince2 *= thread->num_cores; dc_wall_iscale2 *= thread->num_cores;
vince3 *= thread->num_cores; dc_wall_iscale3 *= thread->num_cores;
pitch *= thread->num_cores; pitch *= thread->num_cores;
do do
{ {
uint8_t pix; uint8_t pix;
pix = buf0[(place = vplce0) >> bits]; if (pix) dest[0] = pal0[pix]; vplce0 = place + vince0; pix = buf0[(place = dc_wall_texturefrac0) >> bits]; if (pix) dest[0] = pal0[pix]; dc_wall_texturefrac0 = place + dc_wall_iscale0;
pix = buf1[(place = vplce1) >> bits]; if (pix) dest[1] = pal1[pix]; vplce1 = place + vince1; pix = buf1[(place = dc_wall_texturefrac1) >> bits]; if (pix) dest[1] = pal1[pix]; dc_wall_texturefrac1 = place + dc_wall_iscale1;
pix = buf2[(place = vplce2) >> bits]; if (pix) dest[2] = pal2[pix]; vplce2 = place + vince2; pix = buf2[(place = dc_wall_texturefrac2) >> bits]; if (pix) dest[2] = pal2[pix]; dc_wall_texturefrac2 = place + dc_wall_iscale2;
pix = buf3[(place = vplce3) >> bits]; if (pix) dest[3] = pal3[pix]; vplce3 = place + vince3; pix = buf3[(place = dc_wall_texturefrac3) >> bits]; if (pix) dest[3] = pal3[pix]; dc_wall_texturefrac3 = place + dc_wall_iscale3;
dest += pitch; dest += pitch;
} while (--count); } while (--count);
} }
@ -294,7 +290,7 @@ namespace swrenderer
int count = _count; int count = _count;
const uint8_t *source = _source; const uint8_t *source = _source;
uint8_t *dest = _dest; uint8_t *dest = _dest;
int bits = _tmvlinebits; int bits = _fracbits;
int pitch = _pitch; int pitch = _pitch;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
@ -328,13 +324,13 @@ namespace swrenderer
{ {
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int bits = _tmvlinebits; int bits = _fracbits;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
uint32_t *bg2rgb = _destblend; uint32_t *bg2rgb = _destblend;
uint32_t vplce[4] = { _vplce[0], _vplce[1], _vplce[2], _vplce[3] }; uint32_t dc_wall_texturefrac[4] = { _texturefrac[0], _texturefrac[1], _texturefrac[2], _texturefrac[3] };
uint32_t vince[4] = { _vince[0], _vince[1], _vince[2], _vince[3] }; uint32_t dc_wall_iscale[4] = { _iscale[0], _iscale[1], _iscale[2], _iscale[3] };
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
if (count <= 0) if (count <= 0)
@ -345,8 +341,8 @@ namespace swrenderer
dest = thread->dest_for_thread(_dest_y, pitch, dest); dest = thread->dest_for_thread(_dest_y, pitch, dest);
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
vplce[i] += vince[i] * skipped; dc_wall_texturefrac[i] += dc_wall_iscale[i] * skipped;
vince[i] *= thread->num_cores; dc_wall_iscale[i] *= thread->num_cores;
} }
pitch *= thread->num_cores; pitch *= thread->num_cores;
@ -354,15 +350,15 @@ namespace swrenderer
{ {
for (int i = 0; i < 4; ++i) for (int i = 0; i < 4; ++i)
{ {
uint8_t pix = _bufplce[i][vplce[i] >> bits]; uint8_t pix = _source[i][dc_wall_texturefrac[i] >> bits];
if (pix != 0) if (pix != 0)
{ {
uint32_t fg = fg2rgb[_palookupoffse[i][pix]]; uint32_t fg = fg2rgb[_colormap[i][pix]];
uint32_t bg = bg2rgb[dest[i]]; uint32_t bg = bg2rgb[dest[i]];
fg = (fg + bg) | 0x1f07c1f; fg = (fg + bg) | 0x1f07c1f;
dest[i] = RGB32k.All[fg & (fg >> 15)]; dest[i] = RGB32k.All[fg & (fg >> 15)];
} }
vplce[i] += vince[i]; dc_wall_texturefrac[i] += dc_wall_iscale[i];
} }
dest += pitch; dest += pitch;
} while (--count); } while (--count);
@ -376,7 +372,7 @@ namespace swrenderer
int count = _count; int count = _count;
const uint8_t *source = _source; const uint8_t *source = _source;
uint8_t *dest = _dest; uint8_t *dest = _dest;
int bits = _tmvlinebits; int bits = _fracbits;
int pitch = _pitch; int pitch = _pitch;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
@ -415,13 +411,13 @@ namespace swrenderer
{ {
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int bits = _tmvlinebits; int bits = _fracbits;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
uint32_t *bg2rgb = _destblend; uint32_t *bg2rgb = _destblend;
uint32_t vplce[4] = { _vplce[0], _vplce[1], _vplce[2], _vplce[3] }; uint32_t dc_wall_texturefrac[4] = { _texturefrac[0], _texturefrac[1], _texturefrac[2], _texturefrac[3] };
uint32_t vince[4] = { _vince[0], _vince[1], _vince[2], _vince[3] }; uint32_t dc_wall_iscale[4] = { _iscale[0], _iscale[1], _iscale[2], _iscale[3] };
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
if (count <= 0) if (count <= 0)
@ -432,8 +428,8 @@ namespace swrenderer
dest = thread->dest_for_thread(_dest_y, pitch, dest); dest = thread->dest_for_thread(_dest_y, pitch, dest);
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
vplce[i] += vince[i] * skipped; dc_wall_texturefrac[i] += dc_wall_iscale[i] * skipped;
vince[i] *= thread->num_cores; dc_wall_iscale[i] *= thread->num_cores;
} }
pitch *= thread->num_cores; pitch *= thread->num_cores;
@ -441,10 +437,10 @@ namespace swrenderer
{ {
for (int i = 0; i < 4; ++i) for (int i = 0; i < 4; ++i)
{ {
uint8_t pix = _bufplce[i][vplce[i] >> bits]; uint8_t pix = _source[i][dc_wall_texturefrac[i] >> bits];
if (pix != 0) if (pix != 0)
{ {
uint32_t a = fg2rgb[_palookupoffse[i][pix]] + bg2rgb[dest[i]]; uint32_t a = fg2rgb[_colormap[i][pix]] + bg2rgb[dest[i]];
uint32_t b = a; uint32_t b = a;
a |= 0x01f07c1f; a |= 0x01f07c1f;
@ -454,7 +450,7 @@ namespace swrenderer
a |= b; a |= b;
dest[i] = RGB32k.All[a & (a >> 15)]; dest[i] = RGB32k.All[a & (a >> 15)];
} }
vplce[i] += vince[i]; dc_wall_texturefrac[i] += dc_wall_iscale[i];
} }
dest += pitch; dest += pitch;
} while (--count); } while (--count);
@ -468,7 +464,7 @@ namespace swrenderer
int count = _count; int count = _count;
const uint8_t *source = _source; const uint8_t *source = _source;
uint8_t *dest = _dest; uint8_t *dest = _dest;
int bits = _tmvlinebits; int bits = _fracbits;
int pitch = _pitch; int pitch = _pitch;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
@ -506,13 +502,13 @@ namespace swrenderer
{ {
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int bits = _tmvlinebits; int bits = _fracbits;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
uint32_t *bg2rgb = _destblend; uint32_t *bg2rgb = _destblend;
uint32_t vplce[4] = { _vplce[0], _vplce[1], _vplce[2], _vplce[3] }; uint32_t dc_wall_texturefrac[4] = { _texturefrac[0], _texturefrac[1], _texturefrac[2], _texturefrac[3] };
uint32_t vince[4] = { _vince[0], _vince[1], _vince[2], _vince[3] }; uint32_t dc_wall_iscale[4] = { _iscale[0], _iscale[1], _iscale[2], _iscale[3] };
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
if (count <= 0) if (count <= 0)
@ -523,8 +519,8 @@ namespace swrenderer
dest = thread->dest_for_thread(_dest_y, pitch, dest); dest = thread->dest_for_thread(_dest_y, pitch, dest);
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
vplce[i] += vince[i] * skipped; dc_wall_texturefrac[i] += dc_wall_iscale[i] * skipped;
vince[i] *= thread->num_cores; dc_wall_iscale[i] *= thread->num_cores;
} }
pitch *= thread->num_cores; pitch *= thread->num_cores;
@ -532,10 +528,10 @@ namespace swrenderer
{ {
for (int i = 0; i < 4; ++i) for (int i = 0; i < 4; ++i)
{ {
uint8_t pix = _bufplce[i][vplce[i] >> bits]; uint8_t pix = _source[i][dc_wall_texturefrac[i] >> bits];
if (pix != 0) if (pix != 0)
{ {
uint32_t a = (fg2rgb[_palookupoffse[i][pix]] | 0x40100400) - bg2rgb[dest[i]]; uint32_t a = (fg2rgb[_colormap[i][pix]] | 0x40100400) - bg2rgb[dest[i]];
uint32_t b = a; uint32_t b = a;
b &= 0x40100400; b &= 0x40100400;
@ -544,7 +540,7 @@ namespace swrenderer
a |= 0x01f07c1f; a |= 0x01f07c1f;
dest[i] = RGB32k.All[a & (a >> 15)]; dest[i] = RGB32k.All[a & (a >> 15)];
} }
vplce[i] += vince[i]; dc_wall_texturefrac[i] += dc_wall_iscale[i];
} }
dest += pitch; dest += pitch;
} while (--count); } while (--count);
@ -558,7 +554,7 @@ namespace swrenderer
int count = _count; int count = _count;
const uint8_t *source = _source; const uint8_t *source = _source;
uint8_t *dest = _dest; uint8_t *dest = _dest;
int bits = _tmvlinebits; int bits = _fracbits;
int pitch = _pitch; int pitch = _pitch;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
@ -596,13 +592,13 @@ namespace swrenderer
{ {
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int bits = _tmvlinebits; int bits = _fracbits;
uint32_t *fg2rgb = _srcblend; uint32_t *fg2rgb = _srcblend;
uint32_t *bg2rgb = _destblend; uint32_t *bg2rgb = _destblend;
uint32_t vplce[4] = { _vplce[0], _vplce[1], _vplce[2], _vplce[3] }; uint32_t dc_wall_texturefrac[4] = { _texturefrac[0], _texturefrac[1], _texturefrac[2], _texturefrac[3] };
uint32_t vince[4] = { _vince[0], _vince[1], _vince[2], _vince[3] }; uint32_t dc_wall_iscale[4] = { _iscale[0], _iscale[1], _iscale[2], _iscale[3] };
count = thread->count_for_thread(_dest_y, count); count = thread->count_for_thread(_dest_y, count);
if (count <= 0) if (count <= 0)
@ -613,8 +609,8 @@ namespace swrenderer
dest = thread->dest_for_thread(_dest_y, pitch, dest); dest = thread->dest_for_thread(_dest_y, pitch, dest);
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
vplce[i] += vince[i] * skipped; dc_wall_texturefrac[i] += dc_wall_iscale[i] * skipped;
vince[i] *= thread->num_cores; dc_wall_iscale[i] *= thread->num_cores;
} }
pitch *= thread->num_cores; pitch *= thread->num_cores;
@ -622,10 +618,10 @@ namespace swrenderer
{ {
for (int i = 0; i < 4; ++i) for (int i = 0; i < 4; ++i)
{ {
uint8_t pix = _bufplce[i][vplce[i] >> bits]; uint8_t pix = _source[i][dc_wall_texturefrac[i] >> bits];
if (pix != 0) if (pix != 0)
{ {
uint32_t a = (bg2rgb[dest[i]] | 0x40100400) - fg2rgb[_palookupoffse[i][pix]]; uint32_t a = (bg2rgb[dest[i]] | 0x40100400) - fg2rgb[_colormap[i][pix]];
uint32_t b = a; uint32_t b = a;
b &= 0x40100400; b &= 0x40100400;
@ -634,7 +630,7 @@ namespace swrenderer
a |= 0x01f07c1f; a |= 0x01f07c1f;
dest[i] = RGB32k.All[a & (a >> 15)]; dest[i] = RGB32k.All[a & (a >> 15)];
} }
vplce[i] += vince[i]; dc_wall_texturefrac[i] += dc_wall_iscale[i];
} }
dest += _pitch; dest += _pitch;
} while (--count); } while (--count);
@ -651,11 +647,11 @@ namespace swrenderer
_pitch = dc_pitch; _pitch = dc_pitch;
for (int col = 0; col < 4; col++) for (int col = 0; col < 4; col++)
{ {
_bufplce[col] = bufplce[col]; _source[col] = dc_wall_source[col];
_bufplce2[col] = bufplce2[col]; _source2[col] = dc_wall_source2[col];
_bufheight[col] = bufheight[col]; _sourceheight[col] = dc_wall_sourceheight[col];
_vince[col] = vince[col]; _iscale[col] = dc_wall_iscale[col];
_vplce[col] = vplce[col]; _texturefrac[col] = dc_wall_texturefrac[col];
} }
} }
@ -664,11 +660,11 @@ namespace swrenderer
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int pitch = _pitch; int pitch = _pitch;
const uint8_t *source0 = _bufplce[0]; const uint8_t *source0 = _source[0];
int textureheight0 = _bufheight[0]; int textureheight0 = _sourceheight[0];
int32_t frac = _vplce[0]; int32_t frac = _texturefrac[0];
int32_t fracstep = _vince[0]; int32_t fracstep = _iscale[0];
int start_fade = 2; // How fast it should fade out int start_fade = 2; // How fast it should fade out
@ -729,11 +725,11 @@ namespace swrenderer
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int pitch = _pitch; int pitch = _pitch;
const uint8_t *source0[4] = { _bufplce[0], _bufplce[1], _bufplce[2], _bufplce[3] }; const uint8_t *source0[4] = { _source[0], _source[1], _source[2], _source[3] };
int textureheight0 = _bufheight[0]; int textureheight0 = _sourceheight[0];
const uint32_t *palette = (const uint32_t *)GPalette.BaseColors; const uint32_t *palette = (const uint32_t *)GPalette.BaseColors;
int32_t frac[4] = { (int32_t)_vplce[0], (int32_t)_vplce[1], (int32_t)_vplce[2], (int32_t)_vplce[3] }; int32_t frac[4] = { (int32_t)_texturefrac[0], (int32_t)_texturefrac[1], (int32_t)_texturefrac[2], (int32_t)_texturefrac[3] };
int32_t fracstep[4] = { (int32_t)_vince[0], (int32_t)_vince[1], (int32_t)_vince[2], (int32_t)_vince[3] }; int32_t fracstep[4] = { (int32_t)_iscale[0], (int32_t)_iscale[1], (int32_t)_iscale[2], (int32_t)_iscale[3] };
uint8_t output[4]; uint8_t output[4];
int start_fade = 2; // How fast it should fade out int start_fade = 2; // How fast it should fade out
@ -870,13 +866,13 @@ namespace swrenderer
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int pitch = _pitch; int pitch = _pitch;
const uint8_t *source0 = _bufplce[0]; const uint8_t *source0 = _source[0];
const uint8_t *source1 = _bufplce2[0]; const uint8_t *source1 = _source2[0];
int textureheight0 = _bufheight[0]; int textureheight0 = _sourceheight[0];
uint32_t maxtextureheight1 = _bufheight[1] - 1; uint32_t maxtextureheight1 = _sourceheight[1] - 1;
int32_t frac = _vplce[0]; int32_t frac = _texturefrac[0];
int32_t fracstep = _vince[0]; int32_t fracstep = _iscale[0];
int start_fade = 2; // How fast it should fade out int start_fade = 2; // How fast it should fade out
@ -942,13 +938,13 @@ namespace swrenderer
uint8_t *dest = _dest; uint8_t *dest = _dest;
int count = _count; int count = _count;
int pitch = _pitch; int pitch = _pitch;
const uint8_t *source0[4] = { _bufplce[0], _bufplce[1], _bufplce[2], _bufplce[3] }; const uint8_t *source0[4] = { _source[0], _source[1], _source[2], _source[3] };
const uint8_t *source1[4] = { _bufplce2[0], _bufplce2[1], _bufplce2[2], _bufplce2[3] }; const uint8_t *source1[4] = { _source2[0], _source2[1], _source2[2], _source2[3] };
int textureheight0 = _bufheight[0]; int textureheight0 = _sourceheight[0];
uint32_t maxtextureheight1 = _bufheight[1] - 1; uint32_t maxtextureheight1 = _sourceheight[1] - 1;
const uint32_t *palette = (const uint32_t *)GPalette.BaseColors; const uint32_t *palette = (const uint32_t *)GPalette.BaseColors;
int32_t frac[4] = { (int32_t)_vplce[0], (int32_t)_vplce[1], (int32_t)_vplce[2], (int32_t)_vplce[3] }; int32_t frac[4] = { (int32_t)_texturefrac[0], (int32_t)_texturefrac[1], (int32_t)_texturefrac[2], (int32_t)_texturefrac[3] };
int32_t fracstep[4] = { (int32_t)_vince[0], (int32_t)_vince[1], (int32_t)_vince[2], (int32_t)_vince[3] }; int32_t fracstep[4] = { (int32_t)_iscale[0], (int32_t)_iscale[1], (int32_t)_iscale[2], (int32_t)_iscale[3] };
uint8_t output[4]; uint8_t output[4];
int start_fade = 2; // How fast it should fade out int start_fade = 2; // How fast it should fade out

View file

@ -20,9 +20,7 @@ namespace swrenderer
int _count; int _count;
const uint8_t *_source; const uint8_t *_source;
uint8_t *_dest; uint8_t *_dest;
int _vlinebits; int _fracbits;
int _mvlinebits;
int _tmvlinebits;
int _pitch; int _pitch;
uint32_t *_srcblend; uint32_t *_srcblend;
uint32_t *_destblend; uint32_t *_destblend;
@ -38,13 +36,11 @@ namespace swrenderer
uint8_t *_dest; uint8_t *_dest;
int _count; int _count;
int _pitch; int _pitch;
int _vlinebits; int _fracbits;
int _mvlinebits; uint8_t *_colormap[4];
int _tmvlinebits; const uint8_t *_source[4];
uint8_t *_palookupoffse[4]; uint32_t _iscale[4];
const uint8_t *_bufplce[4]; uint32_t _texturefrac[4];
uint32_t _vince[4];
uint32_t _vplce[4];
uint32_t *_srcblend; uint32_t *_srcblend;
uint32_t *_destblend; uint32_t *_destblend;
}; };
@ -75,11 +71,11 @@ namespace swrenderer
uint8_t *_dest; uint8_t *_dest;
int _count; int _count;
int _pitch; int _pitch;
const uint8_t *_bufplce[4]; const uint8_t *_source[4];
const uint8_t *_bufplce2[4]; const uint8_t *_source2[4];
int _bufheight[4]; int _sourceheight[4];
uint32_t _vince[4]; uint32_t _iscale[4];
uint32_t _vplce[4]; uint32_t _texturefrac[4];
}; };
class DrawSingleSky1PalCommand : public PalSkyCommand { public: using PalSkyCommand::PalSkyCommand; void Execute(DrawerThread *thread) override; }; class DrawSingleSky1PalCommand : public PalSkyCommand { public: using PalSkyCommand::PalSkyCommand; void Execute(DrawerThread *thread) override; };

View file

@ -85,6 +85,9 @@ extern bool r_dontmaplines;
// Change R_CalcTiltedLighting() when this changes. // Change R_CalcTiltedLighting() when this changes.
#define GETPALOOKUP(vis,shade) (clamp<int> (((shade)-FLOAT2FIXED(MIN(MAXLIGHTVIS,double(vis))))>>FRACBITS, 0, NUMCOLORMAPS-1)) #define GETPALOOKUP(vis,shade) (clamp<int> (((shade)-FLOAT2FIXED(MIN(MAXLIGHTVIS,double(vis))))>>FRACBITS, 0, NUMCOLORMAPS-1))
// Converts fixedlightlev into a shade value
#define FIXEDLIGHT2SHADE(lightlev) (((lightlev) >> COLORMAPSHIFT) << FRACBITS)
extern double GlobVis; extern double GlobVis;
void R_SetVisibility(double visibility); void R_SetVisibility(double visibility);

View file

@ -240,8 +240,7 @@ void R_MapPlane (int y, int x1)
if (plane_shade) if (plane_shade)
{ {
// Determine lighting based on the span's distance from the viewer. // Determine lighting based on the span's distance from the viewer.
ds_colormap = basecolormap->Maps + (GETPALOOKUP ( R_SetDSColorMapLight(basecolormap, GlobVis * fabs(CenterY - y), planeshade);
GlobVis * fabs(CenterY - y), planeshade) << COLORMAPSHIFT);
} }
ds_y = y; ds_y = y;
@ -706,15 +705,15 @@ static void R_DrawSkyColumnStripe(int start_x, int y1, int y2, int columns, doub
angle1 = (DWORD)((UMulScale16(ang, frontcyl) + frontpos) >> FRACBITS); angle1 = (DWORD)((UMulScale16(ang, frontcyl) + frontpos) >> FRACBITS);
angle2 = (DWORD)((UMulScale16(ang, backcyl) + backpos) >> FRACBITS); angle2 = (DWORD)((UMulScale16(ang, backcyl) + backpos) >> FRACBITS);
bufplce[i] = (const BYTE *)frontskytex->GetColumn(angle1, nullptr); dc_wall_source[i] = (const BYTE *)frontskytex->GetColumn(angle1, nullptr);
bufplce2[i] = backskytex ? (const BYTE *)backskytex->GetColumn(angle2, nullptr) : nullptr; dc_wall_source2[i] = backskytex ? (const BYTE *)backskytex->GetColumn(angle2, nullptr) : nullptr;
vince[i] = uv_step; dc_wall_iscale[i] = uv_step;
vplce[i] = uv_pos; dc_wall_texturefrac[i] = uv_pos;
} }
bufheight[0] = height; dc_wall_sourceheight[0] = height;
bufheight[1] = backskytex ? backskytex->GetHeight() : height; dc_wall_sourceheight[1] = backskytex ? backskytex->GetHeight() : height;
dc_dest = (ylookup[y1] + start_x) + dc_destorg; dc_dest = (ylookup[y1] + start_x) + dc_destorg;
dc_count = y2 - y1; dc_count = y2 - y1;
@ -1043,7 +1042,7 @@ void R_DrawSinglePlane (visplane_t *pl, fixed_t alpha, bool additive, bool maske
R_SetupSpanBits(tex); R_SetupSpanBits(tex);
double xscale = pl->xform.xScale * tex->Scale.X; double xscale = pl->xform.xScale * tex->Scale.X;
double yscale = pl->xform.yScale * tex->Scale.Y; double yscale = pl->xform.yScale * tex->Scale.Y;
ds_source = tex->GetPixels (); R_SetSpanSource(tex);
basecolormap = pl->colormap; basecolormap = pl->colormap;
planeshade = LIGHT2SHADE(pl->lightlevel); planeshade = LIGHT2SHADE(pl->lightlevel);
@ -1405,12 +1404,13 @@ void R_DrawSkyPlane (visplane_t *pl)
bool fakefixed = false; bool fakefixed = false;
if (fixedcolormap) if (fixedcolormap)
{ {
dc_colormap = fixedcolormap; R_SetColorMapLight(fixedcolormap, 0, 0);
} }
else else
{ {
fakefixed = true; fakefixed = true;
fixedcolormap = dc_colormap = NormalLight.Maps; fixedcolormap = NormalLight.Maps;
R_SetColorMapLight(fixedcolormap, 0, 0);
} }
R_DrawSky (pl); R_DrawSky (pl);
@ -1484,12 +1484,21 @@ void R_DrawNormalPlane (visplane_t *pl, double _xscale, double _yscale, fixed_t
planeheight = fabs(pl->height.Zat0() - ViewPos.Z); planeheight = fabs(pl->height.Zat0() - ViewPos.Z);
GlobVis = r_FloorVisibility / planeheight; GlobVis = r_FloorVisibility / planeheight;
ds_light = 0;
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
ds_colormap = basecolormap->Maps + fixedlightlev, plane_shade = false; {
R_SetDSColorMapLight(basecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
plane_shade = false;
}
else if (fixedcolormap) else if (fixedcolormap)
ds_colormap = fixedcolormap, plane_shade = false; {
R_SetDSColorMapLight(fixedcolormap, 0, 0);
plane_shade = false;
}
else else
{
plane_shade = true; plane_shade = true;
}
if (spanfunc != R_FillSpan) if (spanfunc != R_FillSpan)
{ {
@ -1645,11 +1654,20 @@ void R_DrawTiltedPlane (visplane_t *pl, double _xscale, double _yscale, fixed_t
planelightfloat = -planelightfloat; planelightfloat = -planelightfloat;
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
ds_colormap = basecolormap->Maps + fixedlightlev, plane_shade = false; {
R_SetDSColorMapLight(basecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
plane_shade = false;
}
else if (fixedcolormap) else if (fixedcolormap)
ds_colormap = fixedcolormap, plane_shade = false; {
R_SetDSColorMapLight(fixedcolormap, 0, 0);
plane_shade = false;
}
else else
ds_colormap = basecolormap->Maps, plane_shade = true; {
R_SetDSColorMapLight(basecolormap, 0, 0);
plane_shade = true;
}
// Hack in support for 1 x Z and Z x 1 texture sizes // Hack in support for 1 x Z and Z x 1 texture sizes
if (ds_ybits == 0) if (ds_ybits == 0)
@ -1766,4 +1784,4 @@ bool R_PlaneInitData ()
return true; return true;
} }
} }

View file

@ -44,6 +44,7 @@
#include "r_plane.h" #include "r_plane.h"
#include "r_segs.h" #include "r_segs.h"
#include "r_3dfloors.h" #include "r_3dfloors.h"
#include "r_draw.h"
#include "v_palette.h" #include "v_palette.h"
#include "r_data/colormaps.h" #include "r_data/colormaps.h"
@ -156,7 +157,7 @@ static void BlastMaskedColumn (FTexture *tex, bool useRt)
// calculate lighting // calculate lighting
if (fixedcolormap == NULL && fixedlightlev < 0) if (fixedcolormap == NULL && fixedlightlev < 0)
{ {
dc_colormap = basecolormap->Maps + (GETPALOOKUP (rw_light, wallshade) << COLORMAPSHIFT); R_SetColorMapLight(basecolormap, rw_light, wallshade);
} }
dc_iscale = xs_Fix<16>::ToFix(MaskedSWall[dc_x] * MaskedScaleY); dc_iscale = xs_Fix<16>::ToFix(MaskedSWall[dc_x] * MaskedScaleY);
@ -174,9 +175,7 @@ static void BlastMaskedColumn (FTexture *tex, bool useRt)
// when forming multipatched textures (see r_data.c). // when forming multipatched textures (see r_data.c).
// draw the texture // draw the texture
const FTexture::Span *spans; R_DrawMaskedColumn(tex, maskedtexturecol[dc_x], useRt);
const BYTE *pixels = tex->GetColumn (maskedtexturecol[dc_x] >> FRACBITS, &spans);
R_DrawMaskedColumn(pixels, spans, useRt);
rw_light += rw_lightstep; rw_light += rw_lightstep;
spryscale += rw_scalestep; spryscale += rw_scalestep;
} }
@ -292,9 +291,9 @@ void R_RenderMaskedSegRange (drawseg_t *ds, int x1, int x2)
rw_scalestep = ds->iscalestep; rw_scalestep = ds->iscalestep;
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
dc_colormap = (r_fullbrightignoresectorcolor) ? (FullNormalLight.Maps + fixedlightlev) : (basecolormap->Maps + fixedlightlev); R_SetColorMapLight((r_fullbrightignoresectorcolor) ? &FullNormalLight : basecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
else if (fixedcolormap != NULL) else if (fixedcolormap != NULL)
dc_colormap = fixedcolormap; R_SetColorMapLight(fixedcolormap, 0, 0);
// find positioning // find positioning
texheight = tex->GetScaledHeightDouble(); texheight = tex->GetScaledHeightDouble();
@ -440,7 +439,7 @@ void R_RenderMaskedSegRange (drawseg_t *ds, int x1, int x2)
while (dc_x < stop) while (dc_x < stop)
{ {
rt_initcols(); rt_initcols(nullptr);
BlastMaskedColumn (tex, true); dc_x++; BlastMaskedColumn (tex, true); dc_x++;
BlastMaskedColumn (tex, true); dc_x++; BlastMaskedColumn (tex, true); dc_x++;
BlastMaskedColumn (tex, true); dc_x++; BlastMaskedColumn (tex, true); dc_x++;
@ -609,9 +608,9 @@ void R_RenderFakeWall(drawseg_t *ds, int x1, int x2, F3DFloor *rover)
} }
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
dc_colormap = (r_fullbrightignoresectorcolor) ? (FullNormalLight.Maps + fixedlightlev) : (basecolormap->Maps + fixedlightlev); R_SetColorMapLight((r_fullbrightignoresectorcolor) ? &FullNormalLight : basecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
else if (fixedcolormap != NULL) else if (fixedcolormap != NULL)
dc_colormap = fixedcolormap; R_SetColorMapLight(fixedcolormap, 0, 0);
WallC.sz1 = ds->sz1; WallC.sz1 = ds->sz1;
WallC.sz2 = ds->sz2; WallC.sz2 = ds->sz2;
@ -1061,9 +1060,9 @@ void R_RenderSegLoop ()
fixed_t xoffset = rw_offset; fixed_t xoffset = rw_offset;
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
dc_colormap = (r_fullbrightignoresectorcolor) ? (FullNormalLight.Maps + fixedlightlev) : (basecolormap->Maps + fixedlightlev); R_SetColorMapLight((r_fullbrightignoresectorcolor) ? &FullNormalLight : basecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
else if (fixedcolormap != NULL) else if (fixedcolormap != NULL)
dc_colormap = fixedcolormap; R_SetColorMapLight(fixedcolormap, 0, 0);
// clip wall to the floor and ceiling // clip wall to the floor and ceiling
for (x = x1; x < x2; ++x) for (x = x1; x < x2; ++x)
@ -2304,11 +2303,11 @@ static void R_RenderDecal (side_t *wall, DBaseDecal *decal, drawseg_t *clipper,
rw_light = rw_lightleft + (x1 - savecoord.sx1) * rw_lightstep; rw_light = rw_lightleft + (x1 - savecoord.sx1) * rw_lightstep;
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
dc_colormap = (r_fullbrightignoresectorcolor) ? (FullNormalLight.Maps + fixedlightlev) : (usecolormap->Maps + fixedlightlev); R_SetColorMapLight((r_fullbrightignoresectorcolor) ? &FullNormalLight : usecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
else if (fixedcolormap != NULL) else if (fixedcolormap != NULL)
dc_colormap = fixedcolormap; R_SetColorMapLight(fixedcolormap, 0, 0);
else if (!foggy && (decal->RenderFlags & RF_FULLBRIGHT)) else if (!foggy && (decal->RenderFlags & RF_FULLBRIGHT))
dc_colormap = (r_fullbrightignoresectorcolor) ? FullNormalLight.Maps : usecolormap->Maps; R_SetColorMapLight((r_fullbrightignoresectorcolor) ? &FullNormalLight : usecolormap, 0, 0);
else else
calclighting = true; calclighting = true;
@ -2359,7 +2358,7 @@ static void R_RenderDecal (side_t *wall, DBaseDecal *decal, drawseg_t *clipper,
{ {
if (calclighting) if (calclighting)
{ // calculate lighting { // calculate lighting
dc_colormap = usecolormap->Maps + (GETPALOOKUP (rw_light, wallshade) << COLORMAPSHIFT); R_SetColorMapLight(usecolormap, rw_light, wallshade);
} }
R_WallSpriteColumn (false); R_WallSpriteColumn (false);
dc_x++; dc_x++;
@ -2369,9 +2368,9 @@ static void R_RenderDecal (side_t *wall, DBaseDecal *decal, drawseg_t *clipper,
{ {
if (calclighting) if (calclighting)
{ // calculate lighting { // calculate lighting
dc_colormap = usecolormap->Maps + (GETPALOOKUP (rw_light, wallshade) << COLORMAPSHIFT); R_SetColorMapLight(usecolormap, rw_light, wallshade);
} }
rt_initcols(); rt_initcols(nullptr);
for (int zz = 4; zz; --zz) for (int zz = 4; zz; --zz)
{ {
R_WallSpriteColumn (true); R_WallSpriteColumn (true);
@ -2384,7 +2383,7 @@ static void R_RenderDecal (side_t *wall, DBaseDecal *decal, drawseg_t *clipper,
{ {
if (calclighting) if (calclighting)
{ // calculate lighting { // calculate lighting
dc_colormap = usecolormap->Maps + (GETPALOOKUP (rw_light, wallshade) << COLORMAPSHIFT); R_SetColorMapLight(usecolormap, rw_light, wallshade);
} }
R_WallSpriteColumn (false); R_WallSpriteColumn (false);
dc_x++; dc_x++;
@ -2408,4 +2407,4 @@ done:
WallC = savecoord; WallC = savecoord;
} }
} }

View file

@ -256,8 +256,23 @@ double sprtopscreen;
bool sprflipvert; bool sprflipvert;
void R_DrawMaskedColumn (const BYTE *column, const FTexture::Span *span, bool useRt) void R_DrawMaskedColumn (FTexture *tex, fixed_t col, bool useRt, bool unmasked)
{ {
const FTexture::Span *span;
const BYTE *column;
column = tex->GetColumn(col >> FRACBITS, &span);
FTexture::Span unmaskedSpan[2];
if (unmasked)
{
span = unmaskedSpan;
unmaskedSpan[0].TopOffset = 0;
unmaskedSpan[0].Length = tex->GetHeight();
unmaskedSpan[1].TopOffset = 0;
unmaskedSpan[1].Length = 0;
}
while (span->Length != 0) while (span->Length != 0)
{ {
const int length = span->Length; const int length = span->Length;
@ -377,8 +392,6 @@ static inline bool R_ClipSpriteColumnWithPortals(vissprite_t* spr)
// //
void R_DrawVisSprite (vissprite_t *vis) void R_DrawVisSprite (vissprite_t *vis)
{ {
const BYTE *pixels;
const FTexture::Span *spans;
fixed_t frac; fixed_t frac;
FTexture *tex; FTexture *tex;
int x2, stop4; int x2, stop4;
@ -392,7 +405,7 @@ void R_DrawVisSprite (vissprite_t *vis)
} }
fixed_t centeryfrac = FLOAT2FIXED(CenterY); fixed_t centeryfrac = FLOAT2FIXED(CenterY);
dc_colormap = vis->Style.colormap; R_SetColorMapLight(vis->Style.colormap, 0.0f, 0);
mode = R_SetPatchStyle (vis->Style.RenderStyle, vis->Style.Alpha, vis->Translation, vis->FillColor); mode = R_SetPatchStyle (vis->Style.RenderStyle, vis->Style.Alpha, vis->Translation, vis->FillColor);
@ -400,7 +413,7 @@ void R_DrawVisSprite (vissprite_t *vis)
{ // For shaded sprites, R_SetPatchStyle sets a dc_colormap to an alpha table, but { // For shaded sprites, R_SetPatchStyle sets a dc_colormap to an alpha table, but
// it is the brightest one. We need to get back to the proper light level for // it is the brightest one. We need to get back to the proper light level for
// this sprite. // this sprite.
dc_colormap += vis->ColormapNum << COLORMAPSHIFT; R_SetColorMapLight(dc_colormap, 0, vis->ColormapNum << FRACBITS);
} }
if (mode != DontDraw) if (mode != DontDraw)
@ -445,21 +458,19 @@ void R_DrawVisSprite (vissprite_t *vis)
{ {
while ((dc_x < stop4) && (dc_x & 3)) while ((dc_x < stop4) && (dc_x & 3))
{ {
pixels = tex->GetColumn (frac >> FRACBITS, &spans);
if (ispsprite || !R_ClipSpriteColumnWithPortals(vis)) if (ispsprite || !R_ClipSpriteColumnWithPortals(vis))
R_DrawMaskedColumn (pixels, spans, false); R_DrawMaskedColumn (tex, frac, false);
dc_x++; dc_x++;
frac += xiscale; frac += xiscale;
} }
while (dc_x < stop4) while (dc_x < stop4)
{ {
rt_initcols(); rt_initcols(nullptr);
for (int zz = 4; zz; --zz) for (int zz = 4; zz; --zz)
{ {
pixels = tex->GetColumn (frac >> FRACBITS, &spans);
if (ispsprite || !R_ClipSpriteColumnWithPortals(vis)) if (ispsprite || !R_ClipSpriteColumnWithPortals(vis))
R_DrawMaskedColumn (pixels, spans, true); R_DrawMaskedColumn (tex, frac, true);
dc_x++; dc_x++;
frac += xiscale; frac += xiscale;
} }
@ -468,9 +479,8 @@ void R_DrawVisSprite (vissprite_t *vis)
while (dc_x < x2) while (dc_x < x2)
{ {
pixels = tex->GetColumn (frac >> FRACBITS, &spans);
if (ispsprite || !R_ClipSpriteColumnWithPortals(vis)) if (ispsprite || !R_ClipSpriteColumnWithPortals(vis))
R_DrawMaskedColumn (pixels, spans, false); R_DrawMaskedColumn (tex, frac, false);
dc_x++; dc_x++;
frac += xiscale; frac += xiscale;
} }
@ -522,11 +532,11 @@ void R_DrawWallSprite(vissprite_t *spr)
rw_lightstep = float((GlobVis / spr->wallc.sz2 - rw_lightleft) / (spr->wallc.sx2 - spr->wallc.sx1)); rw_lightstep = float((GlobVis / spr->wallc.sz2 - rw_lightleft) / (spr->wallc.sx2 - spr->wallc.sx1));
rw_light = rw_lightleft + (x1 - spr->wallc.sx1) * rw_lightstep; rw_light = rw_lightleft + (x1 - spr->wallc.sx1) * rw_lightstep;
if (fixedlightlev >= 0) if (fixedlightlev >= 0)
dc_colormap = usecolormap->Maps + fixedlightlev; R_SetColorMapLight(usecolormap, 0, FIXEDLIGHT2SHADE(fixedlightlev));
else if (fixedcolormap != NULL) else if (fixedcolormap != NULL)
dc_colormap = fixedcolormap; R_SetColorMapLight(fixedcolormap, 0, 0);
else if (!foggy && (spr->renderflags & RF_FULLBRIGHT)) else if (!foggy && (spr->renderflags & RF_FULLBRIGHT))
dc_colormap = (r_fullbrightignoresectorcolor) ? FullNormalLight.Maps : usecolormap->Maps; R_SetColorMapLight((r_fullbrightignoresectorcolor) ? &FullNormalLight : usecolormap, 0, 0);
else else
calclighting = true; calclighting = true;
@ -577,7 +587,7 @@ void R_DrawWallSprite(vissprite_t *spr)
{ {
if (calclighting) if (calclighting)
{ // calculate lighting { // calculate lighting
dc_colormap = usecolormap->Maps + (GETPALOOKUP (rw_light, shade) << COLORMAPSHIFT); R_SetColorMapLight(usecolormap, rw_light, shade);
} }
if (!R_ClipSpriteColumnWithPortals(spr)) if (!R_ClipSpriteColumnWithPortals(spr))
R_WallSpriteColumn(false); R_WallSpriteColumn(false);
@ -588,9 +598,9 @@ void R_DrawWallSprite(vissprite_t *spr)
{ {
if (calclighting) if (calclighting)
{ // calculate lighting { // calculate lighting
dc_colormap = usecolormap->Maps + (GETPALOOKUP (rw_light, shade) << COLORMAPSHIFT); R_SetColorMapLight(usecolormap, rw_light, shade);
} }
rt_initcols(); rt_initcols(nullptr);
for (int zz = 4; zz; --zz) for (int zz = 4; zz; --zz)
{ {
if (!R_ClipSpriteColumnWithPortals(spr)) if (!R_ClipSpriteColumnWithPortals(spr))
@ -604,7 +614,7 @@ void R_DrawWallSprite(vissprite_t *spr)
{ {
if (calclighting) if (calclighting)
{ // calculate lighting { // calculate lighting
dc_colormap = usecolormap->Maps + (GETPALOOKUP (rw_light, shade) << COLORMAPSHIFT); R_SetColorMapLight(usecolormap, rw_light, shade);
} }
if (!R_ClipSpriteColumnWithPortals(spr)) if (!R_ClipSpriteColumnWithPortals(spr))
R_WallSpriteColumn(false); R_WallSpriteColumn(false);
@ -624,11 +634,8 @@ void R_WallSpriteColumn (bool useRt)
else else
sprtopscreen = CenterY - dc_texturemid * spryscale; sprtopscreen = CenterY - dc_texturemid * spryscale;
const BYTE *column;
const FTexture::Span *spans;
column = WallSpriteTile->GetColumn (lwall[dc_x] >> FRACBITS, &spans);
dc_texturefrac = 0; dc_texturefrac = 0;
R_DrawMaskedColumn(column, spans, useRt); R_DrawMaskedColumn(WallSpriteTile, lwall[dc_x], useRt);
rw_light += rw_lightstep; rw_light += rw_lightstep;
} }
@ -638,7 +645,7 @@ void R_DrawVisVoxel(vissprite_t *spr, int minslabz, int maxslabz, short *cliptop
int flags = 0; int flags = 0;
// Do setup for blending. // Do setup for blending.
dc_colormap = spr->Style.colormap; R_SetColorMapLight(spr->Style.colormap, 0.0f, 0);
mode = R_SetPatchStyle(spr->Style.RenderStyle, spr->Style.Alpha, spr->Translation, spr->FillColor); mode = R_SetPatchStyle(spr->Style.RenderStyle, spr->Style.Alpha, spr->Translation, spr->FillColor);
if (mode == DontDraw) if (mode == DontDraw)
@ -689,10 +696,7 @@ void R_DrawVisVoxel(vissprite_t *spr, int minslabz, int maxslabz, short *cliptop
} }
else else
{ {
unsigned int **tspan = &dc_ctspan[x & 3]; rt_span_coverage(x, span->Start, span->Stop - 1);
(*tspan)[0] = span->Start;
(*tspan)[1] = span->Stop - 1;
*tspan += 2;
} }
} }
if (!(flags & DVF_SPANSONLY) && (x & 3) == 3) if (!(flags & DVF_SPANSONLY) && (x & 3) == 3)
@ -2044,7 +2048,7 @@ void R_DrawSprite (vissprite_t *spr)
else else
{ // diminished light { // diminished light
spriteshade = LIGHT2SHADE(sec->lightlevel + r_actualextralight); spriteshade = LIGHT2SHADE(sec->lightlevel + r_actualextralight);
spr->Style.colormap = mybasecolormap->Maps + (GETPALOOKUP ( spr->Style.colormap = mybasecolormap->Maps + (GETPALOOKUP(
r_SpriteVisibility / MAX(MINZ, (double)spr->depth), spriteshade) << COLORMAPSHIFT); r_SpriteVisibility / MAX(MINZ, (double)spr->depth), spriteshade) << COLORMAPSHIFT);
} }
} }
@ -3249,4 +3253,4 @@ void R_CheckOffscreenBuffer(int width, int height, bool spansonly)
OffscreenBufferHeight = height; OffscreenBufferHeight = height;
} }
} }

View file

@ -128,7 +128,7 @@ extern double pspriteyscale;
extern FTexture *WallSpriteTile; extern FTexture *WallSpriteTile;
void R_DrawMaskedColumn (const BYTE *column, const FTexture::Span *spans, bool useRt); void R_DrawMaskedColumn (FTexture *texture, fixed_t column, bool useRt, bool unmasked = false);
void R_WallSpriteColumn (bool useRt); void R_WallSpriteColumn (bool useRt);
void R_CacheSprite (spritedef_t *sprite); void R_CacheSprite (spritedef_t *sprite);

View file

@ -96,7 +96,7 @@ WallSampler::WallSampler(int y1, float swal, double yrepeat, fixed_t xoffset, FT
} }
// Draw a column with support for non-power-of-two ranges // Draw a column with support for non-power-of-two ranges
static void Draw1Column(int x, int y1, int y2, WallSampler &sampler, DWORD(*draw1column)()) static void Draw1Column(int x, int y1, int y2, WallSampler &sampler, void(*draw1column)())
{ {
if (sampler.uv_max == 0 || sampler.uv_step == 0) // power of two if (sampler.uv_max == 0 || sampler.uv_step == 0) // power of two
{ {
@ -151,9 +151,9 @@ static void Draw4Columns(int x, int y1, int y2, WallSampler *sampler, void(*draw
int count = y2 - y1; int count = y2 - y1;
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
bufplce[i] = sampler[i].source; dc_wall_source[i] = sampler[i].source;
vplce[i] = sampler[i].uv_pos; dc_wall_texturefrac[i] = sampler[i].uv_pos;
vince[i] = sampler[i].uv_step; dc_wall_iscale[i] = sampler[i].uv_step;
uint64_t step64 = sampler[i].uv_step; uint64_t step64 = sampler[i].uv_step;
uint64_t pos64 = sampler[i].uv_pos; uint64_t pos64 = sampler[i].uv_pos;
@ -168,7 +168,7 @@ static void Draw4Columns(int x, int y1, int y2, WallSampler *sampler, void(*draw
dc_dest = (ylookup[y1] + x) + dc_destorg; dc_dest = (ylookup[y1] + x) + dc_destorg;
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
bufplce[i] = sampler[i].source; dc_wall_source[i] = sampler[i].source;
} }
uint32_t left = y2 - y1; uint32_t left = y2 - y1;
@ -188,8 +188,8 @@ static void Draw4Columns(int x, int y1, int y2, WallSampler *sampler, void(*draw
// Draw until that column wraps // Draw until that column wraps
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
vplce[i] = sampler[i].uv_pos; dc_wall_texturefrac[i] = sampler[i].uv_pos;
vince[i] = sampler[i].uv_step; dc_wall_iscale[i] = sampler[i].uv_step;
} }
dc_count = count; dc_count = count;
draw4columns(); draw4columns();
@ -207,13 +207,11 @@ static void Draw4Columns(int x, int y1, int y2, WallSampler *sampler, void(*draw
} }
} }
typedef DWORD(*Draw1ColumnFuncPtr)(); typedef void(*DrawColumnFuncPtr)();
typedef void(*Draw4ColumnsFuncPtr)();
static void ProcessWallWorker( static void ProcessWallWorker(
int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat,
const BYTE *(*getcol)(FTexture *tex, int x), const BYTE *(*getcol)(FTexture *tex, int x), DrawColumnFuncPtr draw1column, DrawColumnFuncPtr draw4columns)
void(setupProcessNormalWall(int bits, Draw1ColumnFuncPtr &draw1, Draw4ColumnsFuncPtr &draw2)))
{ {
if (rw_pic->UseType == FTexture::TEX_Null) if (rw_pic->UseType == FTexture::TEX_Null)
return; return;
@ -228,17 +226,15 @@ static void ProcessWallWorker(
dc_texturemid = 0; dc_texturemid = 0;
} }
DWORD(*draw1column)(); dc_wall_fracbits = fracbits;
void(*draw4columns)();
setupProcessNormalWall(fracbits, draw1column, draw4columns);
bool fixed = (fixedcolormap != NULL || fixedlightlev >= 0); bool fixed = (fixedcolormap != NULL || fixedlightlev >= 0);
if (fixed) if (fixed)
{ {
palookupoffse[0] = dc_colormap; dc_wall_colormap[0] = dc_colormap;
palookupoffse[1] = dc_colormap; dc_wall_colormap[1] = dc_colormap;
palookupoffse[2] = dc_colormap; dc_wall_colormap[2] = dc_colormap;
palookupoffse[3] = dc_colormap; dc_wall_colormap[3] = dc_colormap;
} }
if (fixedcolormap) if (fixedcolormap)
@ -331,7 +327,7 @@ static void ProcessWallWorker(
{ {
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
{ {
palookupoffse[i] = basecolormap->Maps + (GETPALOOKUP(lights[i], wallshade) << COLORMAPSHIFT); dc_wall_colormap[i] = basecolormap->Maps + (GETPALOOKUP(lights[i], wallshade) << COLORMAPSHIFT);
} }
} }
Draw4Columns(x, middle_y1, middle_y2, sampler, draw4columns); Draw4Columns(x, middle_y1, middle_y2, sampler, draw4columns);
@ -367,12 +363,7 @@ static void ProcessWallWorker(
static void ProcessNormalWall(int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, const BYTE *(*getcol)(FTexture *tex, int x) = R_GetColumn) static void ProcessNormalWall(int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, const BYTE *(*getcol)(FTexture *tex, int x) = R_GetColumn)
{ {
ProcessWallWorker(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol, [](int bits, Draw1ColumnFuncPtr &line1, Draw4ColumnsFuncPtr &line4) ProcessWallWorker(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol, R_DrawWallCol1, R_DrawWallCol4);
{
setupvline(bits);
line1 = dovline1;
line4 = dovline4;
});
} }
static void ProcessMaskedWall(int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, const BYTE *(*getcol)(FTexture *tex, int x) = R_GetColumn) static void ProcessMaskedWall(int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, const BYTE *(*getcol)(FTexture *tex, int x) = R_GetColumn)
@ -383,32 +374,22 @@ static void ProcessMaskedWall(int x1, int x2, short *uwal, short *dwal, float *s
} }
else else
{ {
ProcessWallWorker(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol, [](int bits, Draw1ColumnFuncPtr &line1, Draw4ColumnsFuncPtr &line4) ProcessWallWorker(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol, R_DrawWallMaskedCol1, R_DrawWallMaskedCol4);
{
setupmvline(bits);
line1 = domvline1;
line4 = domvline4;
});
} }
} }
static void ProcessTranslucentWall(int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, const BYTE *(*getcol)(FTexture *tex, int x) = R_GetColumn) static void ProcessTranslucentWall(int x1, int x2, short *uwal, short *dwal, float *swal, fixed_t *lwal, double yrepeat, const BYTE *(*getcol)(FTexture *tex, int x) = R_GetColumn)
{ {
static fixed_t(*tmvline1)(); void (*drawcol1)();
static void(*tmvline4)(); void (*drawcol4)();
if (!R_GetTransMaskDrawers(&tmvline1, &tmvline4)) if (!R_GetTransMaskDrawers(&drawcol1, &drawcol4))
{ {
// The current translucency is unsupported, so draw with regular ProcessMaskedWall instead. // The current translucency is unsupported, so draw with regular ProcessMaskedWall instead.
ProcessMaskedWall(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol); ProcessMaskedWall(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol);
} }
else else
{ {
ProcessWallWorker(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol, [](int bits, Draw1ColumnFuncPtr &line1, Draw4ColumnsFuncPtr &line4) ProcessWallWorker(x1, x2, uwal, dwal, swal, lwal, yrepeat, getcol, drawcol1, drawcol4);
{
setuptmvline(bits);
line1 = reinterpret_cast<DWORD(*)()>(tmvline1);
line4 = tmvline4;
});
} }
} }

View file

@ -527,7 +527,9 @@ inline bool Writer<StringBuffer>::WriteDouble(double d) {
if (!(kWriteDefaultFlags & kWriteNanAndInfFlag)) if (!(kWriteDefaultFlags & kWriteNanAndInfFlag))
{ {
// At least ensure that the output does not get broken. // At least ensure that the output does not get broken.
PutReserve(*os_, 1); PutReserve(*os_, 3);
PutUnsafe(*os_, '0');
PutUnsafe(*os_, '.');
PutUnsafe(*os_, '0'); PutUnsafe(*os_, '0');
return false; return false;
} }

View file

@ -8955,7 +8955,7 @@ ExpEmit FxIfStatement::Emit(VMFunctionBuilder *build)
size_t jumpspot = ~0u; size_t jumpspot = ~0u;
TArray<size_t> yes, no; TArray<size_t> yes, no;
Condition->EmitCompare(build, false, yes, no); Condition->EmitCompare(build, WhenTrue == nullptr, yes, no);
if (WhenTrue != nullptr) if (WhenTrue != nullptr)
{ {
@ -8964,11 +8964,14 @@ ExpEmit FxIfStatement::Emit(VMFunctionBuilder *build)
} }
if (WhenFalse != nullptr) if (WhenFalse != nullptr)
{ {
if (!WhenTrue->CheckReturn()) jumpspot = build->Emit(OP_JMP, 0); // no need to emit a jump if the block returns. if (WhenTrue != nullptr)
build->BackpatchListToHere(no); {
if (!WhenTrue->CheckReturn()) jumpspot = build->Emit(OP_JMP, 0); // no need to emit a jump if the block returns.
build->BackpatchListToHere(no);
}
WhenFalse->EmitStatement(build); WhenFalse->EmitStatement(build);
if (jumpspot != ~0u) build->BackpatchToHere(jumpspot); if (jumpspot != ~0u) build->BackpatchToHere(jumpspot);
if (WhenTrue == nullptr) build->BackpatchListToHere(yes); if (WhenTrue == nullptr) build->BackpatchListToHere(no);
} }
else else
{ {

View file

@ -551,7 +551,7 @@ void FDDSTexture::ReadRGB (FWadLump &lump, BYTE *tcbuf)
DWORD r = (c & RMask) << RShiftL; r |= r >> RShiftR; DWORD r = (c & RMask) << RShiftL; r |= r >> RShiftR;
DWORD g = (c & GMask) << GShiftL; g |= g >> GShiftR; DWORD g = (c & GMask) << GShiftL; g |= g >> GShiftR;
DWORD b = (c & BMask) << BShiftL; b |= b >> BShiftR; DWORD b = (c & BMask) << BShiftL; b |= b >> BShiftR;
*pixelp = RGB32k.RGB[r >> 27][g >> 27][b >> 27]; *pixelp = RGB256k.RGB[r >> 26][g >> 26][b >> 26];
} }
else else
{ {
@ -637,7 +637,7 @@ void FDDSTexture::DecompressDXT1 (FWadLump &lump, BYTE *tcbuf)
// Pick colors from the palette for each of the four colors. // Pick colors from the palette for each of the four colors.
/*if (!tcbuf)*/ for (i = 3; i >= 0; --i) /*if (!tcbuf)*/ for (i = 3; i >= 0; --i)
{ {
palcol[i] = color[i].a ? RGB32k.RGB[color[i].r >> 3][color[i].g >> 3][color[i].b >> 3] : 0; palcol[i] = color[i].a ? RGB256k.RGB[color[i].r >> 2][color[i].g >> 2][color[i].b >> 2] : 0;
} }
// Now decode this 4x4 block to the pixel buffer. // Now decode this 4x4 block to the pixel buffer.
for (y = 0; y < 4; ++y) for (y = 0; y < 4; ++y)
@ -717,7 +717,7 @@ void FDDSTexture::DecompressDXT3 (FWadLump &lump, bool premultiplied, BYTE *tcbu
// Pick colors from the palette for each of the four colors. // Pick colors from the palette for each of the four colors.
if (!tcbuf) for (i = 3; i >= 0; --i) if (!tcbuf) for (i = 3; i >= 0; --i)
{ {
palcol[i] = RGB32k.RGB[color[i].r >> 3][color[i].g >> 3][color[i].b >> 3]; palcol[i] = RGB256k.RGB[color[i].r >> 2][color[i].g >> 2][color[i].b >> 2];
} }
// Now decode this 4x4 block to the pixel buffer. // Now decode this 4x4 block to the pixel buffer.
for (y = 0; y < 4; ++y) for (y = 0; y < 4; ++y)
@ -822,7 +822,7 @@ void FDDSTexture::DecompressDXT5 (FWadLump &lump, bool premultiplied, BYTE *tcbu
// Pick colors from the palette for each of the four colors. // Pick colors from the palette for each of the four colors.
if (!tcbuf) for (i = 3; i >= 0; --i) if (!tcbuf) for (i = 3; i >= 0; --i)
{ {
palcol[i] = RGB32k.RGB[color[i].r >> 3][color[i].g >> 3][color[i].b >> 3]; palcol[i] = RGB256k.RGB[color[i].r >> 2][color[i].g >> 2][color[i].b >> 2];
} }
// Now decode this 4x4 block to the pixel buffer. // Now decode this 4x4 block to the pixel buffer.
for (y = 0; y < 4; ++y) for (y = 0; y < 4; ++y)

View file

@ -406,7 +406,7 @@ void FJPEGTexture::MakeTexture ()
case JCS_RGB: case JCS_RGB:
for (int x = Width; x > 0; --x) for (int x = Width; x > 0; --x)
{ {
*out = RGB32k.RGB[in[0]>>3][in[1]>>3][in[2]>>3]; *out = RGB256k.RGB[in[0]>>2][in[1]>>2][in[2]>>2];
out += Height; out += Height;
in += 3; in += 3;
} }
@ -430,7 +430,7 @@ void FJPEGTexture::MakeTexture ()
int r = in[3] - (((256-in[0])*in[3]) >> 8); int r = in[3] - (((256-in[0])*in[3]) >> 8);
int g = in[3] - (((256-in[1])*in[3]) >> 8); int g = in[3] - (((256-in[1])*in[3]) >> 8);
int b = in[3] - (((256-in[2])*in[3]) >> 8); int b = in[3] - (((256-in[2])*in[3]) >> 8);
*out = RGB32k.RGB[r >> 3][g >> 3][b >> 3]; *out = RGB256k.RGB[r >> 2][g >> 2][b >> 2];
out += Height; out += Height;
in += 4; in += 4;
} }

View file

@ -531,7 +531,7 @@ void FMultiPatchTexture::MakeTexture ()
{ {
if (*out == 0 && in[3] != 0) if (*out == 0 && in[3] != 0)
{ {
*out = RGB32k.RGB[in[2]>>3][in[1]>>3][in[0]>>3]; *out = RGB256k.RGB[in[2]>>2][in[1]>>2][in[0]>>2];
} }
out += Height; out += Height;
in += 4; in += 4;

View file

@ -528,7 +528,7 @@ void FPCXTexture::MakeTexture()
{ {
for(int x=0; x < Width; x++) for(int x=0; x < Width; x++)
{ {
Pixels[y+Height*x] = RGB32k.RGB[row[0]>>3][row[1]>>3][row[2]>>3]; Pixels[y+Height*x] = RGB256k.RGB[row[0]>>2][row[1]>>2][row[2]>>2];
row+=3; row+=3;
} }
} }

View file

@ -536,7 +536,7 @@ void FPNGTexture::MakeTexture ()
{ {
if (!HaveTrans) if (!HaveTrans)
{ {
*out++ = RGB32k.RGB[in[0]>>3][in[1]>>3][in[2]>>3]; *out++ = RGB256k.RGB[in[0]>>2][in[1]>>2][in[2]>>2];
} }
else else
{ {
@ -548,7 +548,7 @@ void FPNGTexture::MakeTexture ()
} }
else else
{ {
*out++ = RGB32k.RGB[in[0]>>3][in[1]>>3][in[2]>>3]; *out++ = RGB256k.RGB[in[0]>>2][in[1]>>2][in[2]>>2];
} }
} }
in += pitch; in += pitch;
@ -593,7 +593,7 @@ void FPNGTexture::MakeTexture ()
{ {
for (y = Height; y > 0; --y) for (y = Height; y > 0; --y)
{ {
*out++ = in[3] < 128 ? 0 : RGB32k.RGB[in[0]>>3][in[1]>>3][in[2]>>3]; *out++ = in[3] < 128 ? 0 : RGB256k.RGB[in[0]>>2][in[1]>>2][in[2]>>2];
in += pitch; in += pitch;
} }
in -= backstep; in -= backstep;

View file

@ -393,7 +393,7 @@ void FTGATexture::MakeTexture ()
for(int x=0;x<Width;x++) for(int x=0;x<Width;x++)
{ {
int v = LittleLong(*p); int v = LittleLong(*p);
Pixels[x*Height+y] = RGB32k.RGB[(v>>10) & 0x1f][(v>>5) & 0x1f][v & 0x1f]; Pixels[x*Height+y] = RGB256k.RGB[((v>>10) & 0x1f)*2][((v>>5) & 0x1f)*2][(v & 0x1f)*2];
p+=step_x; p+=step_x;
} }
} }
@ -405,7 +405,7 @@ void FTGATexture::MakeTexture ()
BYTE * p = ptr + y * Pitch; BYTE * p = ptr + y * Pitch;
for(int x=0;x<Width;x++) for(int x=0;x<Width;x++)
{ {
Pixels[x*Height+y] = RGB32k.RGB[p[2]>>3][p[1]>>3][p[0]>>3]; Pixels[x*Height+y] = RGB256k.RGB[p[2]>>2][p[1]>>2][p[0]>>2];
p+=step_x; p+=step_x;
} }
} }
@ -419,7 +419,7 @@ void FTGATexture::MakeTexture ()
BYTE * p = ptr + y * Pitch; BYTE * p = ptr + y * Pitch;
for(int x=0;x<Width;x++) for(int x=0;x<Width;x++)
{ {
Pixels[x*Height+y] = RGB32k.RGB[p[2]>>3][p[1]>>3][p[0]>>3]; Pixels[x*Height+y] = RGB256k.RGB[p[2]>>2][p[1]>>2][p[0]>>2];
p+=step_x; p+=step_x;
} }
} }
@ -431,7 +431,7 @@ void FTGATexture::MakeTexture ()
BYTE * p = ptr + y * Pitch; BYTE * p = ptr + y * Pitch;
for(int x=0;x<Width;x++) for(int x=0;x<Width;x++)
{ {
Pixels[x*Height+y] = p[3] >= 128? RGB32k.RGB[p[2]>>3][p[1]>>3][p[0]>>3] : 0; Pixels[x*Height+y] = p[3] >= 128? RGB256k.RGB[p[2]>>2][p[1]>>2][p[0]>>2] : 0;
p+=step_x; p+=step_x;
} }
} }

View file

@ -135,20 +135,9 @@ void DCanvas::DrawTextureParms(FTexture *img, DrawParms &parms)
using namespace swrenderer; using namespace swrenderer;
using namespace drawerargs; using namespace drawerargs;
FTexture::Span unmaskedSpan[2];
const FTexture::Span **spanptr, *spans;
static short bottomclipper[MAXWIDTH], topclipper[MAXWIDTH]; static short bottomclipper[MAXWIDTH], topclipper[MAXWIDTH];
const BYTE *translation = NULL; const BYTE *translation = NULL;
if (parms.masked)
{
spanptr = &spans;
}
else
{
spanptr = NULL;
}
if (APART(parms.colorOverlay) != 0) if (APART(parms.colorOverlay) != 0)
{ {
// The software renderer cannot invert the source without inverting the overlay // The software renderer cannot invert the source without inverting the overlay
@ -198,18 +187,8 @@ void DCanvas::DrawTextureParms(FTexture *img, DrawParms &parms)
if (mode != DontDraw) if (mode != DontDraw)
{ {
const BYTE *pixels;
int stop4; int stop4;
if (spanptr == NULL)
{ // Create a single span for forced unmasked images
spans = unmaskedSpan;
unmaskedSpan[0].TopOffset = 0;
unmaskedSpan[0].Length = img->GetHeight();
unmaskedSpan[1].TopOffset = 0;
unmaskedSpan[1].Length = 0;
}
double centeryback = CenterY; double centeryback = CenterY;
CenterY = 0; CenterY = 0;
@ -301,8 +280,7 @@ void DCanvas::DrawTextureParms(FTexture *img, DrawParms &parms)
{ {
while ((dc_x < stop4) && (dc_x & 3)) while ((dc_x < stop4) && (dc_x & 3))
{ {
pixels = img->GetColumn(frac >> FRACBITS, spanptr); R_DrawMaskedColumn(img, frac, false, !parms.masked);
R_DrawMaskedColumn(pixels, spans, false);
dc_x++; dc_x++;
frac += xiscale_i; frac += xiscale_i;
} }
@ -312,8 +290,7 @@ void DCanvas::DrawTextureParms(FTexture *img, DrawParms &parms)
rt_initcols(); rt_initcols();
for (int zz = 4; zz; --zz) for (int zz = 4; zz; --zz)
{ {
pixels = img->GetColumn(frac >> FRACBITS, spanptr); R_DrawMaskedColumn(img, frac, true, !parms.masked);
R_DrawMaskedColumn(pixels, spans, true);
dc_x++; dc_x++;
frac += xiscale_i; frac += xiscale_i;
} }
@ -322,8 +299,7 @@ void DCanvas::DrawTextureParms(FTexture *img, DrawParms &parms)
while (dc_x < x2_i) while (dc_x < x2_i)
{ {
pixels = img->GetColumn(frac >> FRACBITS, spanptr); R_DrawMaskedColumn(img, frac, false, !parms.masked);
R_DrawMaskedColumn(pixels, spans, false);
dc_x++; dc_x++;
frac += xiscale_i; frac += xiscale_i;
} }

View file

@ -144,8 +144,10 @@ DWORD Col2RGB8[65][256];
DWORD *Col2RGB8_LessPrecision[65]; DWORD *Col2RGB8_LessPrecision[65];
DWORD Col2RGB8_Inverse[65][256]; DWORD Col2RGB8_Inverse[65][256];
ColorTable32k RGB32k; ColorTable32k RGB32k;
ColorTable256k RGB256k;
} }
static DWORD Col2RGB8_2[63][256]; static DWORD Col2RGB8_2[63][256];
// [RH] The framebuffer is no longer a mere byte array. // [RH] The framebuffer is no longer a mere byte array.
@ -669,6 +671,11 @@ static void BuildTransTable (const PalEntry *palette)
for (g = 0; g < 32; g++) for (g = 0; g < 32; g++)
for (b = 0; b < 32; b++) for (b = 0; b < 32; b++)
RGB32k.RGB[r][g][b] = ColorMatcher.Pick ((r<<3)|(r>>2), (g<<3)|(g>>2), (b<<3)|(b>>2)); RGB32k.RGB[r][g][b] = ColorMatcher.Pick ((r<<3)|(r>>2), (g<<3)|(g>>2), (b<<3)|(b>>2));
// create the RGB666 lookup table
for (r = 0; r < 64; r++)
for (g = 0; g < 64; g++)
for (b = 0; b < 64; b++)
RGB256k.RGB[r][g][b] = ColorMatcher.Pick ((r<<2)|(r>>4), (g<<2)|(g>>4), (b<<2)|(b>>4));
int x, y; int x, y;

View file

@ -462,6 +462,14 @@ union ColorTable32k
}; };
extern "C" ColorTable32k RGB32k; extern "C" ColorTable32k RGB32k;
// [SP] RGB666 support
union ColorTable256k
{
BYTE RGB[64][64][64];
BYTE All[64 *64 *64];
};
extern "C" ColorTable256k RGB256k;
// Col2RGB8 is a pre-multiplied palette for color lookup. It is stored in a // Col2RGB8 is a pre-multiplied palette for color lookup. It is stored in a
// special R10B10G10 format for efficient blending computation. // special R10B10G10 format for efficient blending computation.
// --RRRRRrrr--BBBBBbbb--GGGGGggg-- at level 64 // --RRRRRrrr--BBBBBbbb--GGGGGggg-- at level 64

View file

@ -454,6 +454,49 @@ D7F6E9F08C39A17026349A04F8C0B0BE // Return to Hadron, e1m9
pointonline pointonline
} }
// Remove unreachable secrets
F6EE16F770AD309D608EA0B1F1E249FC // Ultimate Doom, e4m3
{
setsectorspecial 124 0
setsectorspecial 125 0
// clear staircase to secret area
setsectorspecial 127 0
setsectorspecial 128 0
setsectorspecial 129 0
setsectorspecial 130 0
setsectorspecial 131 0
setsectorspecial 132 0
setsectorspecial 133 0
setsectorspecial 134 0
setsectorspecial 136 0
setsectorspecial 137 0
setsectorspecial 138 0
setsectorspecial 147 0
setsectorspecial 148 0
setsectorspecial 149 0
setsectorspecial 150 0
setsectorspecial 151 0
setsectorspecial 152 0
setsectorspecial 155 0
}
94D4C869A0C02EF4F7375022B36AAE45 // Ultimate Doom, e4m7
{
setsectorspecial 263 0
setsectorspecial 264 0
}
1A540BA717BF9EC85F8522594C352F2A // Doom II, map15
{
setsectorspecial 147 0
}
110F84DE041052B59307FAF0293E6BC0 // Doom II, map27
{
setsectorspecial 93 0
}
ABC4EB5A1535ECCD0061AD14F3547908 // Plutonia Experiment, map26
{
setsectorspecial 156 0
}
712BB4CFBD0753178CA0C6814BE4C288 // map12 BTSX_E1 - patch some rendering glitches that are problematic to detect 712BB4CFBD0753178CA0C6814BE4C288 // map12 BTSX_E1 - patch some rendering glitches that are problematic to detect
{ {
setsectortag 545 32000 setsectortag 545 32000

View file

@ -793,6 +793,7 @@ class Actor : Thinker native
native bool A_CopySpriteFrame(int from, int to, int flags = 0); native bool A_CopySpriteFrame(int from, int to, int flags = 0);
native bool A_SetVisibleRotation(double anglestart = 0, double angleend = 0, double pitchstart = 0, double pitchend = 0, int flags = 0, int ptr = AAPTR_DEFAULT); native bool A_SetVisibleRotation(double anglestart = 0, double angleend = 0, double pitchstart = 0, double pitchend = 0, int flags = 0, int ptr = AAPTR_DEFAULT);
native void A_SetTranslation(name transname); native void A_SetTranslation(name transname);
native bool A_SetSize(double newradius, double newheight = -1, bool testpos = false);
native void A_RearrangePointers(int newtarget, int newmaster = AAPTR_DEFAULT, int newtracer = AAPTR_DEFAULT, int flags=0); native void A_RearrangePointers(int newtarget, int newmaster = AAPTR_DEFAULT, int newtracer = AAPTR_DEFAULT, int flags=0);
native void A_TransferPointer(int ptr_source, int ptr_recepient, int sourcefield, int recepientfield=AAPTR_DEFAULT, int flags=0); native void A_TransferPointer(int ptr_source, int ptr_recepient, int sourcefield, int recepientfield=AAPTR_DEFAULT, int flags=0);