2020-06-26 03:31:51 +00:00
|
|
|
|
|
|
|
#if defined(REC98_PROJECT)
|
|
|
|
# include "platform.h" /* see also [https://github.com/nmlgc/ReC98/issues/8] */
|
2020-07-09 07:37:00 +00:00
|
|
|
#elif defined(_MSC_VER)/*Microsoft C++*/ || defined(__BORLANDC__) || defined(__TURBOC__)
|
2020-06-28 00:39:45 +00:00
|
|
|
typedef unsigned char uint8_t;
|
|
|
|
typedef unsigned short uint16_t;
|
|
|
|
typedef unsigned long uint32_t;
|
2020-06-26 03:31:51 +00:00
|
|
|
#else
|
|
|
|
# include <stdint.h>
|
|
|
|
#endif
|
2020-07-09 07:37:00 +00:00
|
|
|
#if defined(_MSC_VER)/*Microsoft C++*/ || defined(__BORLANDC__) || defined(__TURBOC__)
|
2020-06-28 00:36:46 +00:00
|
|
|
# include <io.h>
|
|
|
|
#else
|
|
|
|
# include <sys/types.h>
|
|
|
|
# include <sys/stat.h>
|
2020-06-28 00:39:45 +00:00
|
|
|
# include <unistd.h>
|
2020-06-28 00:36:46 +00:00
|
|
|
#endif
|
2020-06-26 03:31:51 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <malloc.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
#if defined(__GNUC__)
|
|
|
|
# include <endian.h>
|
|
|
|
#else
|
|
|
|
# define le16toh(x) (x)
|
|
|
|
# define le32toh(x) (x)
|
2020-06-26 06:36:26 +00:00
|
|
|
# define htole16(x) (x)
|
|
|
|
# define htole32(x) (x)
|
2020-06-26 03:31:51 +00:00
|
|
|
#endif
|
|
|
|
|
2020-07-06 22:09:42 +00:00
|
|
|
#include "bmp2arrl.h"
|
|
|
|
|
2020-06-26 03:31:51 +00:00
|
|
|
/* O_BINARY is needed for MS-DOS, Windows, etc.
|
|
|
|
* Linux, Mac OS X, etc. do not have O_BINARY */
|
|
|
|
#ifndef O_BINARY
|
|
|
|
#define O_BINARY (0)
|
|
|
|
#endif
|
|
|
|
|
2020-09-04 20:29:54 +00:00
|
|
|
static enum bmp2arr_error parse_argv(struct rec98_bmp2arr_task *tsk,int argc,char **argv) {
|
2020-06-26 03:31:51 +00:00
|
|
|
char *a;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i=1;i < argc;) {
|
|
|
|
a = argv[i++];
|
|
|
|
|
|
|
|
if (*a == '-') {
|
|
|
|
do { a++; } while (*a == '-');
|
|
|
|
|
|
|
|
if (!strcmp(a,"i")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "i");
|
2020-06-26 03:31:51 +00:00
|
|
|
cstr_set(&tsk->input_bmp,a);
|
|
|
|
}
|
|
|
|
else if (!strcmp(a,"o")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "o");
|
2020-06-26 03:31:51 +00:00
|
|
|
cstr_set(&tsk->output_file,a);
|
|
|
|
}
|
2020-06-26 22:41:45 +00:00
|
|
|
else if (!strcmp(a,"sym")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "sym");
|
2020-06-26 22:41:45 +00:00
|
|
|
cstr_set(&tsk->output_symname,a);
|
|
|
|
}
|
2020-06-26 03:31:51 +00:00
|
|
|
else if (!strcmp(a,"of")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "of");
|
2020-06-26 03:31:51 +00:00
|
|
|
|
2020-06-28 00:17:52 +00:00
|
|
|
if (!strcmp(a,"asm"))
|
2020-06-26 03:31:51 +00:00
|
|
|
tsk->output_type = REC98_OUT_ASM;
|
2020-06-26 22:44:57 +00:00
|
|
|
else if (!strcmp(a,"bin"))
|
|
|
|
tsk->output_type = REC98_OUT_BIN;
|
2020-06-27 00:27:27 +00:00
|
|
|
else if (!strcmp(a,"bmp"))
|
|
|
|
tsk->output_type = REC98_OUT_BMP;
|
2020-06-26 03:31:51 +00:00
|
|
|
else if (!strcmp(a,"c"))
|
|
|
|
tsk->output_type = REC98_OUT_C;
|
|
|
|
else
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_set(tsk, INVALID_OUTPUT_TYPE);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
else if (!strcmp(a,"sw")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "sw");
|
|
|
|
|
2020-06-26 03:31:51 +00:00
|
|
|
tsk->sprite_width = atoi(a);
|
2020-09-04 20:29:54 +00:00
|
|
|
if (!(tsk->sprite_width == 8 || tsk->sprite_width == 16))
|
|
|
|
return bmp2arr_error_set(tsk, INVALID_SPRITE_WIDTH);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
else if (!strcmp(a,"sh")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "sh");
|
|
|
|
|
2020-06-26 03:31:51 +00:00
|
|
|
tsk->sprite_height = atoi(a);
|
2020-09-04 20:29:54 +00:00
|
|
|
if (tsk->sprite_height < 1 || tsk->sprite_height > 32)
|
|
|
|
return bmp2arr_error_set(tsk, INVALID_SPRITE_HEIGHT);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
else if (!strcmp(a,"u")) {
|
2020-09-04 14:48:32 +00:00
|
|
|
tsk->flags |= UPSIDEDOWN;
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
2020-06-26 06:33:06 +00:00
|
|
|
else if (!strcmp(a,"dbg-bmp")) {
|
2020-09-04 14:48:32 +00:00
|
|
|
tsk->flags |= DEBUG_BMP_OUT;
|
2020-06-26 06:33:06 +00:00
|
|
|
}
|
2020-09-04 20:50:16 +00:00
|
|
|
else if (!strcmp(a,"q")) {
|
|
|
|
tsk->flags |= QUIET;
|
|
|
|
}
|
2020-06-26 03:31:51 +00:00
|
|
|
else if (!strcmp(a,"pshf")) {
|
|
|
|
a = argv[i++];
|
2020-09-04 20:29:54 +00:00
|
|
|
if (a == NULL)
|
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_ARGUMENT, "pshf");
|
2020-06-26 03:31:51 +00:00
|
|
|
|
|
|
|
if (!strcmp(a,"inner"))
|
2020-09-04 14:48:32 +00:00
|
|
|
tsk->flags |= PRESHIFT_INNER;
|
2020-06-26 03:31:51 +00:00
|
|
|
else if (!strcmp(a,"outer"))
|
2020-09-04 14:48:32 +00:00
|
|
|
tsk->flags |= PRESHIFT_OUTER;
|
2020-06-26 03:31:51 +00:00
|
|
|
else
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_set(tsk, INVALID_PRESHIFT);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
else {
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_set_str(tsk, INVALID_SWITCH, a);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_set_str(tsk, EXPECTED_SWITCH, a);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-04 20:29:54 +00:00
|
|
|
/* required fields */
|
|
|
|
if (tsk->input_bmp == NULL)
|
|
|
|
return bmp2arr_error_set(tsk, MISSING_INPUT_BMP);
|
2020-06-26 03:31:51 +00:00
|
|
|
|
2020-09-04 20:29:54 +00:00
|
|
|
if (tsk->output_file == NULL)
|
|
|
|
return bmp2arr_error_set(tsk, MISSING_OUTPUT_FILE);
|
2020-06-26 03:31:51 +00:00
|
|
|
|
2020-09-04 20:42:33 +00:00
|
|
|
if (tsk->output_type == REC98_OUT_NONE)
|
|
|
|
return bmp2arr_error_set(tsk, MISSING_OUTPUT_TYPE);
|
|
|
|
|
2020-09-04 20:29:54 +00:00
|
|
|
if (tsk->sprite_width == 0)
|
|
|
|
return bmp2arr_error_set(tsk, MISSING_SPRITE_WIDTH);
|
|
|
|
|
|
|
|
if (tsk->sprite_height == 0)
|
|
|
|
return bmp2arr_error_set(tsk, MISSING_SPRITE_HEIGHT);
|
2020-06-26 07:09:59 +00:00
|
|
|
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_set(tsk, SUCCESS);
|
2020-06-26 03:31:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc,char **argv) {
|
|
|
|
struct rec98_bmp2arr_task tsk;
|
|
|
|
|
|
|
|
if (rec98_bmp2arr_task_init(&tsk))
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
if (parse_argv(&tsk,argc,argv))
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_report(&tsk.err);
|
2020-06-26 03:31:51 +00:00
|
|
|
|
|
|
|
if (rec98_bmp2arr_load_bitmap(&tsk))
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_report(&tsk.err);
|
2020-06-26 03:31:51 +00:00
|
|
|
|
2020-09-04 14:48:32 +00:00
|
|
|
if (tsk.flags & DEBUG_BMP_OUT) {
|
2020-06-26 06:33:06 +00:00
|
|
|
if (rec98_bmp2arr_save_debug_bmp_out(&tsk))
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_report(&tsk.err);
|
2020-06-26 06:33:06 +00:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-06-26 23:16:56 +00:00
|
|
|
if (rec98_bmp2arr_save_output(&tsk))
|
2020-09-04 20:29:54 +00:00
|
|
|
return bmp2arr_error_report(&tsk.err);
|
2020-06-26 23:16:56 +00:00
|
|
|
|
2020-06-26 03:31:51 +00:00
|
|
|
rec98_bmp2arr_task_free(&tsk);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|