2012-02-27 21:03:01 +00:00
|
|
|
/*****************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* output.c */
|
|
|
|
/* */
|
|
|
|
/* Output format/file definitions for the sp65 sprite and bitmap utility */
|
|
|
|
/* */
|
|
|
|
/* */
|
|
|
|
/* */
|
|
|
|
/* (C) 2012, Ullrich von Bassewitz */
|
|
|
|
/* Roemerstrasse 52 */
|
|
|
|
/* D-70794 Filderstadt */
|
|
|
|
/* EMail: uz@cc65.org */
|
|
|
|
/* */
|
|
|
|
/* */
|
|
|
|
/* This software is provided 'as-is', without any expressed or implied */
|
|
|
|
/* warranty. In no event will the authors be held liable for any damages */
|
|
|
|
/* arising from the use of this software. */
|
|
|
|
/* */
|
|
|
|
/* Permission is granted to anyone to use this software for any purpose, */
|
|
|
|
/* including commercial applications, and to alter it and redistribute it */
|
|
|
|
/* freely, subject to the following restrictions: */
|
|
|
|
/* */
|
|
|
|
/* 1. The origin of this software must not be misrepresented; you must not */
|
|
|
|
/* claim that you wrote the original software. If you use this software */
|
|
|
|
/* in a product, an acknowledgment in the product documentation would be */
|
|
|
|
/* appreciated but is not required. */
|
|
|
|
/* 2. Altered source versions must be plainly marked as such, and must not */
|
|
|
|
/* be misrepresented as being the original software. */
|
|
|
|
/* 3. This notice may not be removed or altered from any source */
|
|
|
|
/* distribution. */
|
|
|
|
/* */
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-09 11:46:16 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
2012-02-27 21:03:01 +00:00
|
|
|
/* common */
|
|
|
|
#include "fileid.h"
|
|
|
|
|
|
|
|
/* sp65 */
|
|
|
|
#include "asm.h"
|
2012-03-10 14:22:51 +00:00
|
|
|
#include "attr.h"
|
2012-02-27 21:03:01 +00:00
|
|
|
#include "bin.h"
|
2012-03-11 12:38:54 +00:00
|
|
|
#include "c.h"
|
2012-02-27 21:03:01 +00:00
|
|
|
#include "error.h"
|
|
|
|
#include "output.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************************/
|
|
|
|
/* Data */
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-11 12:38:54 +00:00
|
|
|
/* Different types of output formats */
|
|
|
|
enum OutputFormat {
|
|
|
|
ofAsm, /* Output assembler source */
|
|
|
|
ofBin, /* Output raw binary format */
|
|
|
|
ofC, /* Output C code */
|
|
|
|
|
|
|
|
ofCount /* Number of output formats without ofAuto */
|
|
|
|
};
|
|
|
|
|
2012-02-27 21:03:01 +00:00
|
|
|
typedef struct OutputFormatDesc OutputFormatDesc;
|
|
|
|
struct OutputFormatDesc {
|
|
|
|
|
|
|
|
/* Write routine */
|
2012-03-15 17:02:12 +00:00
|
|
|
void (*Write) (const StrBuf*, const Collection*, const Bitmap*);
|
2012-02-27 21:03:01 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Table with Output formats */
|
|
|
|
static OutputFormatDesc OutputFormatTable[ofCount] = {
|
|
|
|
{ WriteAsmFile },
|
|
|
|
{ WriteBinFile },
|
2012-03-11 12:38:54 +00:00
|
|
|
{ WriteCFile },
|
2012-02-27 21:03:01 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Table that maps extensions to Output formats. Must be sorted alphabetically */
|
|
|
|
static const FileId FormatTable[] = {
|
|
|
|
/* Upper case stuff for obsolete operating systems */
|
|
|
|
{ "A", ofAsm },
|
|
|
|
{ "ASM", ofAsm },
|
|
|
|
{ "BIN", ofBin },
|
2012-03-11 12:38:54 +00:00
|
|
|
{ "C", ofC },
|
2012-02-27 21:03:01 +00:00
|
|
|
{ "INC", ofAsm },
|
|
|
|
{ "S", ofAsm },
|
|
|
|
|
|
|
|
{ "a", ofAsm },
|
|
|
|
{ "asm", ofAsm },
|
|
|
|
{ "bin", ofBin },
|
2012-03-11 12:38:54 +00:00
|
|
|
{ "c", ofC },
|
2012-02-27 21:03:01 +00:00
|
|
|
{ "inc", ofAsm },
|
|
|
|
{ "s", ofAsm },
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************************/
|
|
|
|
/* Code */
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-15 17:02:12 +00:00
|
|
|
void WriteOutputFile (const StrBuf* Data, const Collection* A, const Bitmap* B)
|
2012-03-10 14:22:51 +00:00
|
|
|
/* Write the contents of Data to a file. Format, file name etc. must be given
|
2014-06-30 09:10:35 +00:00
|
|
|
** as attributes in A. If no format is given, the function tries to autodetect
|
|
|
|
** it by using the extension of the file name. The bitmap passed to the
|
|
|
|
** function is the bitmap used as source of the conversion. It may be used to
|
|
|
|
** determine the bitmap properties for documentation purposes.
|
|
|
|
*/
|
2012-03-09 11:46:16 +00:00
|
|
|
{
|
2012-03-10 14:22:51 +00:00
|
|
|
const FileId* F;
|
|
|
|
|
|
|
|
/* Get the file format from the command line */
|
|
|
|
const char* Format = GetAttrVal (A, "format");
|
|
|
|
if (Format != 0) {
|
|
|
|
/* Format is given, search for it in the table. */
|
|
|
|
F = bsearch (Format,
|
|
|
|
FormatTable,
|
|
|
|
sizeof (FormatTable) / sizeof (FormatTable[0]),
|
|
|
|
sizeof (FormatTable[0]),
|
|
|
|
CompareFileId);
|
|
|
|
if (F == 0) {
|
2019-01-05 19:57:12 +00:00
|
|
|
Error ("Unknown output format '%s'", Format);
|
2012-03-10 14:22:51 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
/* No format given, use file name extension */
|
|
|
|
const char* Name = NeedAttrVal (A, "name", "write");
|
|
|
|
F = GetFileId (Name, FormatTable,
|
|
|
|
sizeof (FormatTable) / sizeof (FormatTable[0]));
|
2012-02-27 21:03:01 +00:00
|
|
|
/* Found? */
|
|
|
|
if (F == 0) {
|
2019-01-05 19:57:12 +00:00
|
|
|
Error ("Cannot determine file format of output file '%s'", Name);
|
2012-02-27 21:03:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Call the format specific write */
|
2012-03-15 17:02:12 +00:00
|
|
|
OutputFormatTable[F->Id].Write (Data, A, B);
|
2012-02-27 21:03:01 +00:00
|
|
|
}
|