mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-18 16:49:18 +03:00
Don't use P96 on gfx.lib v54+ systems
This commit is contained in:
parent
e0198789ae
commit
fdb9a42eff
@ -27,6 +27,8 @@
|
|||||||
#include <proto/intuition.h>
|
#include <proto/intuition.h>
|
||||||
#include <proto/utility.h>
|
#include <proto/utility.h>
|
||||||
|
|
||||||
|
#include <graphics/gfxbase.h> /* Needed for v54 version check */
|
||||||
|
|
||||||
#ifndef __amigaos4__
|
#ifndef __amigaos4__
|
||||||
/* OS3 needs these for the XXXX_GetClass() functions */
|
/* OS3 needs these for the XXXX_GetClass() functions */
|
||||||
#include <proto/arexx.h>
|
#include <proto/arexx.h>
|
||||||
@ -216,6 +218,7 @@ bool ami_libs_open(void)
|
|||||||
/*\todo This is down here as we need to check the graphics.library version
|
/*\todo This is down here as we need to check the graphics.library version
|
||||||
* before opening. If it is sufficiently new enough we can avoid using P96
|
* before opening. If it is sufficiently new enough we can avoid using P96
|
||||||
*/
|
*/
|
||||||
|
if(GfxBase->LibNode.lib_Version >= 54)
|
||||||
AMINS_LIB_OPEN("Picasso96API.library", 0, P96, "main", 1, false)
|
AMINS_LIB_OPEN("Picasso96API.library", 0, P96, "main", 1, false)
|
||||||
|
|
||||||
/* NB: timer.device is opened in schedule.c (ultimately by the scheduler process).
|
/* NB: timer.device is opened in schedule.c (ultimately by the scheduler process).
|
||||||
@ -235,7 +238,6 @@ bool ami_libs_open(void)
|
|||||||
* NB: the last argument should be "true" only if the class also has
|
* NB: the last argument should be "true" only if the class also has
|
||||||
* library functions we use.
|
* library functions we use.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
AMINS_CLASS_OPEN("arexx.class", 44, ARexx, AREXX, false)
|
AMINS_CLASS_OPEN("arexx.class", 44, ARexx, AREXX, false)
|
||||||
AMINS_CLASS_OPEN("images/bevel.image", 44, Bevel, BEVEL, false)
|
AMINS_CLASS_OPEN("images/bevel.image", 44, Bevel, BEVEL, false)
|
||||||
AMINS_CLASS_OPEN("images/bitmap.image", 44, BitMap, BITMAP, false)
|
AMINS_CLASS_OPEN("images/bitmap.image", 44, BitMap, BITMAP, false)
|
||||||
|
19
amiga/rtg.c
19
amiga/rtg.c
@ -47,19 +47,26 @@ void ami_rtg_freebitmap(struct BitMap *bm)
|
|||||||
void ami_rtg_writepixelarray(UBYTE *pixdata, struct BitMap *bm,
|
void ami_rtg_writepixelarray(UBYTE *pixdata, struct BitMap *bm,
|
||||||
ULONG width, ULONG height, ULONG bpr, ULONG format)
|
ULONG width, ULONG height, ULONG bpr, ULONG format)
|
||||||
{
|
{
|
||||||
struct RenderInfo ri;
|
|
||||||
struct RastPort trp;
|
struct RastPort trp;
|
||||||
|
|
||||||
/* This requires P96 currently */
|
InitRastPort(&trp);
|
||||||
if(P96Base == NULL) return;
|
trp.BitMap = bm;
|
||||||
|
|
||||||
|
/* This requires P96 or gfx.lib v54 currently */
|
||||||
|
if(P96Base == NULL) {
|
||||||
|
#ifdef __amigaos4__
|
||||||
|
if(GfxBase->LibNode.lib_Version >= 54) {
|
||||||
|
WritePixelArray(pixdata, 0, 0, bpr, format, &trp, 0, 0, width, height);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
} else {
|
||||||
|
struct RenderInfo ri;
|
||||||
|
|
||||||
ri.Memory = pixdata;
|
ri.Memory = pixdata;
|
||||||
ri.BytesPerRow = bpr;
|
ri.BytesPerRow = bpr;
|
||||||
ri.RGBFormat = format;
|
ri.RGBFormat = format;
|
||||||
|
|
||||||
InitRastPort(&trp);
|
|
||||||
trp.BitMap = bm;
|
|
||||||
|
|
||||||
p96WritePixelArray((struct RenderInfo *)&ri, 0, 0, &trp, 0, 0, width, height);
|
p96WritePixelArray((struct RenderInfo *)&ri, 0, 0, &trp, 0, 0, width, height);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user