#include <assert.h>
#include <bmusb/bmusb.h>
#include <epoxy/gl.h>
+#include <stdarg.h>
#include <lauxlib.h>
#include <lua.hpp>
#include <movit/deinterlace_effect.h>
return (Theme *)lua_touserdata(L, lua_upvalueindex(1));
}
+void print_warning(lua_State* L, const char *format, ...)
+{
+ char buf[4096];
+ va_list ap;
+ va_start(ap, format);
+ vsnprintf(buf, sizeof(buf), format, ap);
+ va_end(ap);
+
+ lua_Debug ar;
+ lua_getstack(L, 1, &ar);
+ lua_getinfo(L, "nSl", &ar);
+ fprintf(stderr, "WARNING: %s:%d: %s", ar.source, ar.currentline, buf);
+}
+
int ThemeMenu_set(lua_State *L)
{
Theme *theme = get_theme_updata(L);
int signal_num = luaL_checknumber(L, 2);
bool success = (*input)->connect_signal(signal_num);
if (!success) {
- lua_Debug ar;
- lua_getstack(L, 1, &ar);
- lua_getinfo(L, "nSl", &ar);
- fprintf(stderr, "ERROR: %s:%d: Calling connect_signal() on a video or HTML input. Ignoring.\n",
- ar.source, ar.currentline);
+ print_warning(L, "Calling connect_signal() on a video or HTML input. Ignoring.\n");
}
return 0;
}
int pixel_format = luaL_checknumber(L, 2);
if (pixel_format != bmusb::PixelFormat_8BitYCbCrPlanar &&
pixel_format != bmusb::PixelFormat_8BitBGRA) {
- fprintf(stderr, "WARNING: Invalid enum %d used for video format, choosing Y'CbCr.\n",
- pixel_format);
+ print_warning(L, "Invalid enum %d used for video format, choosing Y'CbCr.\n", pixel_format);
pixel_format = bmusb::PixelFormat_8BitYCbCrPlanar;
}
int ret = wrap_lua_object_nonowned<FFmpegCapture>(L, "VideoInput", filename, global_flags.width, global_flags.height);
++card_index;
}
if (signal_num >= int(num_cards - 1)) {
- fprintf(stderr, "WARNING: Theme asked for input %d, but we only have %u input card(s) (card %d is busy with output).\n",
+ print_warning(L, "Theme asked for input %d, but we only have %u input card(s) (card %d is busy with output).\n",
signal_num, num_cards - 1, global_flags.output_card);
fprintf(stderr, "Mapping to card %d instead.\n", card_index);
}
} else {
card_index = signal_num % num_cards;
if (signal_num >= int(num_cards)) {
- fprintf(stderr, "WARNING: Theme asked for input %d, but we only have %u card(s).\n", signal_num, num_cards);
+ print_warning(L, "Theme asked for input %d, but we only have %u card(s).\n", signal_num, num_cards);
fprintf(stderr, "Mapping to card %d instead.\n", card_index);
}
}