/*
 * Copyright 2005 Richard Wilson <info@tinct.net>
 *
 * This file is part of NetSurf, http://www.netsurf-browser.org/
 *
 * NetSurf is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; version 2 of the License.
 *
 * NetSurf is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

/*
 * Complete details on using Tinct are available from http://www.tinct.net.
 */

/** \file
 * Tinct SWI numbers and flags for version 0.11
 */

#ifndef _NETSURF_RISCOS_TINCT_H_
#define _NETSURF_RISCOS_TINCT_H_


/**
 * Plots an alpha-blended sprite at the specified coordinates.
 *
 * ->	R2	Sprite pointer
 *	R3	X coordinate
 *	R4	Y coordinate
 *	R7	Flag word
*/
#define Tinct_PlotAlpha 0x57240


/**
 * Plots a scaled alpha-blended sprite at the specified coordinates.
 *
 * ->	R2	Sprite pointer
 *	R3	X coordinate
 *	R4	Y coordinate
 *	R5	Scaled sprite width
 *	R6	Scaled sprite height
 *	R7	Flag word
 */
#define Tinct_PlotScaledAlpha 0x57241


/**
 * Plots a sprite at the specified coordinates with a constant 0xff value for
 * the alpha channel, ie without a mask.
 *
 * ->	R2	Sprite pointer
 *	R3	X coordinate
 *	R4	Y coordinate
 *	R7	Flag word
 */
#define Tinct_Plot 0x57242

/**
 * Plots a scaled sprite at the specified coordinates with a constant 0xff value
 * for the alpha channel, ie without a mask.
 *
 * ->	R2	Sprite pointer
 *	R3	X coordinate
 *	R4	Y coordinate
 *	R5	Scaled sprite width
 *	R6	Scaled sprite height
 *	R7	Flag word
 */
#define Tinct_PlotScaled 0x57243


/**
 * Converts a paletted sprite into its 32bpp equivalent. Sufficient memory must
 * have previously been allocated for the sprite (44 + width * height * 4).
 * As sprites with 16bpp or 32bpp do not have palettes, conversion cannot be
 * performed on these variants. All sprites must be supplied with a full palette,
 * eg 8bpp must have 256 palette entries.
 *
 * ->	R2	Source sprite pointer
 *	R3	Destination sprite pointer
 */
#define Tinct_ConvertSprite 0x57244


/**
 * Returns the features available to the caller by specifying bits in the flag
 * word. The features available are unique for each mode, although the current
 * version of Tinct supports the same subset of features for all modes.
 *
 * ->	R0	Feature to test for, or 0 for all features
 * <-	R0	Features available
 */
#define Tinct_AvailableFeatures 0x57245


/**
 * Compresses an image using a fast algorithm. Sufficient memory must have been
 * previously allocated for the maximum possible compressed size. This value is
 * equal to 28 + (width * height * 4) * 33 / 32.
 *
 * ->	R0	Source sprite pointer
 *	R2	Output data buffer
 *	R3	Output bytes available
 *	R7	Flag word (currently 0)
 * <-	R0	Size of compressed data
 */
#define Tinct_Compress 0x57246


/**
 * Decompresses an image previously compressed. Sufficient memory must have been
 * previously allocated for the decompressed data (44 + width * height * 4) where
 * width and height are available at +0 and +4 of the compressed data respectively.
 *
 * ->	R0	Input data buffer
 *	R2	Output data buffer
 *	R7	Flag word (currently 0)
 * <-	R0	Size of decompressed data
 */
#define Tinct_Decompress 0x57247


/*	Plotting flags
*/
#define tinct_READ_SCREEN_BASE	  0x01	/** <-- Use when hardware scrolling */
#define tinct_BILINEAR_FILTER	  0x02	/** <-- Perform bi-linear filtering */
#define tinct_DITHER		  0x04	/** <-- Perform dithering */
#define tinct_ERROR_DIFFUSE	  0x08	/** <-- Perform error diffusion */
#define tinct_DITHER_INVERTED	  0x0C	/** <-- Perform dithering with inverted pattern */
#define tinct_FILL_HORIZONTALLY	  0x10	/** <-- Horizontally fill clipping region with image */
#define tinct_FILL_VERTICALLY	  0x20	/** <-- Vertically fill clipping region with image */
#define tinct_FORCE_PALETTE_READ  0x40	/** <-- Use after a palette change when out of the desktop */
#define tinct_USE_OS_SPRITE_OP	  0x80	/** <-- Use when printing */

/*	Compression flags
*/
#define tinct_OPAQUE_IMAGE	  0x01	/** <-- Image is opaque, compress further */

/*	Shifts
*/
#define tinct_BACKGROUND_SHIFT	  0x08

/*	Sprite mode
*/
#define tinct_SPRITE_MODE	  (os_mode)0x301680b5
#endif