From 1b29ac6db740488e05f13cfb3f71c20a6c11506a Mon Sep 17 00:00:00 2001 From: helixhorned Date: Wed, 16 Oct 2013 19:43:03 +0000 Subject: [PATCH] build.lua: add read_basepal(). git-svn-id: https://svn.eduke32.com/eduke32@4106 1a8010ca-5511-0410-912e-c29ae57300e0 --- polymer/eduke32/source/lunatic/util/build.lua | 23 +++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/polymer/eduke32/source/lunatic/util/build.lua b/polymer/eduke32/source/lunatic/util/build.lua index fd7849a7c..bf54f9bc6 100644 --- a/polymer/eduke32/source/lunatic/util/build.lua +++ b/polymer/eduke32/source/lunatic/util/build.lua @@ -126,6 +126,26 @@ local function doread(fh, basectype, numelts, dontclose) return cd end +-- Read base palette (i.e. first 768 bytes as R,G,B triplets) from a PALETTE.DAT. +-- Returns: +-- on success: cdata (palette values scaled by 4) +-- on failure: nil, +function read_basepal(filename) + local fh, errmsg = io.open(filename, "rb") + if (fh == nil) then + return nil, errmsg + end + + local palette, errmsg = doread(fh, "uint8_t", 768, true) + fh:close() + + for i=0,768-1 do + palette[i] = 4*palette[i] + end + + return palette, errmsg +end + local function set_secwalspr_mt(structar, maxidx) local mt = { __index = function(tab, idx) @@ -366,12 +386,11 @@ local artfile_mt = { end, dims = function(self, ltile) + self:_check_ltile(ltile) return self.sizx[ltile], self.sizy[ltile] end, getpic = function(self, ltile) - self:_check_ltile(ltile) - local sx, sy = self:dims(ltile) if (sx == 0 or sy == 0) then -- Tile nonexistent/empty in this ART file