dxx-rebirth/common/2d/pixel.cpp
Kp 62b58e9890 Move OGL to dxxsconf.h; rename to DXX_USE_OGL
Rename symbol OGL to DXX_USE_OGL to show that it is a DXX
symbol, not one inherited from a library.  Move it to dxxsconf.h to
shorten the command line.

This is a mostly automated transform, but the changes to SConstruct were
manual.

git grep -lzw OGL -- '*.h' '*.cpp' | xargs -0 sed -i -e 's/\(\s*#\s*if\)def\s*OGL/\1 DXX_USE_OGL/' -e 's/\(\s*#\s*if\)ndef OGL/\1 !DXX_USE_OGL/' -e 's/\(\s*#\s*if !\?\)defined(OGL)/\1DXX_USE_OGL/'
2016-09-24 18:06:11 +00:00

80 lines
2 KiB
C++

/*
* Portions of this file are copyright Rebirth contributors and licensed as
* described in COPYING.txt.
* Portions of this file are copyright Parallax Software and licensed
* according to the Parallax license below.
* See COPYING.txt for license details.
THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
SOFTWARE CORPORATION ("PARALLAX"). PARALLAX, IN DISTRIBUTING THE CODE TO
END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
IN USING, DISPLAYING, AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
FREE PURPOSES. IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES. THE END-USER UNDERSTANDS
AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
*/
/*
*
* Graphical routines for setting a pixel.
*
*/
#include "u_mem.h"
#include "gr.h"
#include "grdef.h"
#if DXX_USE_OGL
#include "ogl_init.h"
#endif
namespace dcx {
void gr_upixel(unsigned x, unsigned y, const uint8_t color)
{
switch (TYPE)
{
#if DXX_USE_OGL
case bm_mode::ogl:
ogl_upixelc(*grd_curcanv, x, y, color);
return;
#endif
case bm_mode::linear:
DATA[ROWSIZE * y + x] = color;
return;
}
}
void gr_pixel(unsigned x, unsigned y, const uint8_t color)
{
if (unlikely(x >= GWIDTH || y >= GHEIGHT))
return;
gr_upixel(x, y, color);
}
static inline void gr_bm_upixel(grs_bitmap &bm, uint_fast32_t x, uint_fast32_t y, uint8_t color )
{
switch (bm.get_type())
{
#if DXX_USE_OGL
case bm_mode::ogl:
ogl_upixelc(*grd_curcanv, bm.bm_x+x,bm.bm_y+y,color);
return;
#endif
case bm_mode::linear:
bm.get_bitmap_data()[bm.bm_rowsize*y+x] = color;
return;
}
}
void gr_bm_pixel(grs_bitmap &bm, uint_fast32_t x, uint_fast32_t y, uint8_t color )
{
if (unlikely(x >= bm.bm_w || y >= bm.bm_h))
return;
gr_bm_upixel (bm, x, y, color);
}
}