aboutsummaryrefslogtreecommitdiff
path: root/engines/sci/scicore/sciconsole.cpp
blob: 0c0124aaf5a501399e78de33766941e8aec090c5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/* ScummVM - Graphic Adventure Engine
 *
 * ScummVM is the legal property of its developers, whose names
 * are too numerous to list here. Please refer to the COPYRIGHT
 * file distributed with this source distribution.
 *
 * This program 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; either version 2
 * of the License, or (at your option) any later version.

 * This program 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, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 *
 * $URL$
 * $Id$
 *
 */

/* First part of the console implmentation: VM independent stuff */
/* Remember, it doesn't have to be fast. */

#include "sci/sci_memory.h"
#include "sci/engine/state.h"

namespace Sci {

#ifdef SCI_CONSOLE

int con_passthrough = 0;
FILE *con_file = NULL;

static void(*_con_string_callback)(char*) = NULL;
static void (*_con_pixmap_callback)(gfx_pixmap_t *) = NULL;

int sciprintf(const char *fmt, ...) {
	va_list argp;
	int bufsize = 256;
	int i;
	char *buf = (char *)sci_malloc(bufsize);

	if (NULL == fmt) {
		fprintf(stderr, "console.c: sciprintf(): NULL passed for parameter fmt\n");
		return -1;
	}

	if (NULL == buf) {
		fprintf(stderr, "console.c: sciprintf(): malloc failed for buf\n");
		return -1;
	}

	va_start(argp, fmt);
	while ((i = vsnprintf(buf, bufsize - 1, fmt, argp)) == -1 || (i >= bufsize - 2)) {
		// while we're out of space...
		va_end(argp);
		va_start(argp, fmt); // reset argp

		free(buf);
		buf = (char *)sci_malloc(bufsize <<= 1);
	}
	va_end(argp);

	if (con_passthrough)
		printf("%s", buf);
	if (con_file)
		fprintf(con_file, "%s", buf);

	if (_con_string_callback)
		_con_string_callback(buf);
	else
		free(buf);

	return 1;
}

void con_set_string_callback(void(*callback)(char *)) {
	_con_string_callback = callback;
}

void con_set_pixmap_callback(void(*callback)(gfx_pixmap_t *)) {
	_con_pixmap_callback = callback;
}

int con_can_handle_pixmaps() {
	return _con_pixmap_callback != NULL;
}

int con_insert_pixmap(gfx_pixmap_t *pixmap) {
	if (_con_pixmap_callback)
		_con_pixmap_callback(pixmap);
	else
		return 1;
	return 0;
}

void open_console_file(char *filename) {
	if (con_file != NULL)
		fclose(con_file);

	if (NULL == filename) {
		fprintf(stderr, "console.c: open_console_file(): NULL passed for parameter filename\r\n");
	}
#ifdef WIN32
	con_file = fopen(filename, "wt");
#else
	con_file = fopen(filename, "w");
#endif

	if (NULL == con_file)
		fprintf(stderr, "console.c: open_console_file(): Could not open output file %s\n", filename);
}

void close_console_file() {
	if (con_file != NULL) {
		fclose(con_file);
		con_file = NULL;
	}
}

#endif // SCI_CONSOLE

} // End of namespace Sci