/* 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. * */ #ifndef GLK_GLK_API_H #define GLK_GLK_API_H #include "glk/glk.h" #include "glk/glk_types.h" #include "glk/blorb.h" #include "glk/sound.h" #include "glk/time.h" #include "glk/windows.h" namespace Glk { class GlkAPI; typedef void (GlkAPI::*GlkFunction)(); struct gidispatch_function_struct { uint32 id; const char *name; GlkFunction fnptr; }; typedef gidispatch_function_struct gidispatch_function_t; /** * Implements the GLK interface */ class GlkAPI : public GlkEngine { private: bool _gliFirstEvent; unsigned char _charTolowerTable[256]; unsigned char _charToupperTable[256]; public: /** * Constructor */ GlkAPI(OSystem *syst, const GlkGameDescription &gameDesc); ~GlkAPI() override {} void glk_exit(void); void glk_set_interrupt_handler(void(*func)(void)); void glk_tick(void); uint glk_gestalt(uint id, uint val); uint glk_gestalt_ext(uint id, uint val, uint *arr, uint arrlen); unsigned char glk_char_to_lower(unsigned char ch); unsigned char glk_char_to_upper(unsigned char ch); /** * Get the root window of the window hierarchy */ winid_t glk_window_get_root(void) const; /** * Open a new window */ winid_t glk_window_open(winid_t split, uint method, uint size, uint wintype, uint rock = 0) const; void glk_window_close(winid_t win, stream_result_t *result = nullptr); void glk_window_get_size(winid_t win, uint *width, uint *height); void glk_window_set_arrangement(winid_t win, uint method, uint size, winid_t keyWin); void glk_window_get_arrangement(winid_t win, uint *method, uint *size, winid_t *keyWin); winid_t glk_window_iterate(winid_t win, uint *rock = 0); uint glk_window_get_rock(winid_t win); uint glk_window_get_type(winid_t win); winid_t glk_window_get_parent(winid_t win); winid_t glk_window_get_sibling(winid_t win); void glk_window_clear(winid_t win); void glk_window_move_cursor(winid_t win, uint xpos, uint ypos); strid_t glk_window_get_stream(winid_t win); void glk_window_set_echo_stream(winid_t win, strid_t str); strid_t glk_window_get_echo_stream(winid_t win); void glk_set_window(winid_t win); strid_t glk_stream_open_file(frefid_t fileref, FileMode fmode, uint rock = 0); strid_t glk_stream_open_memory(char *buf, uint buflen, FileMode fmode, uint rock = 0); void glk_stream_close(strid_t str, stream_result_t *result = nullptr); strid_t glk_stream_iterate(strid_t str, uint *rockptr) const; uint glk_stream_get_rock(strid_t str) const; void glk_stream_set_position(strid_t str, int pos, uint seekMode); uint glk_stream_get_position(strid_t str) const; void glk_stream_set_current(strid_t str); strid_t glk_stream_get_current(void); void glk_put_char(unsigned char ch); void glk_put_char_stream(strid_t str, unsigned char ch); void glk_put_string(const char *s); void glk_put_string_stream(strid_t str, const char *s); void glk_put_buffer(const char *buf, uint len); void glk_put_buffer_stream(strid_t str, const char *buf, uint len); void glk_set_style(uint styl); void glk_set_style_stream(strid_t str, uint styl); int glk_get_char_stream(strid_t str); uint glk_get_line_stream(strid_t str, char *buf, uint len); uint glk_get_buffer_stream(strid_t str, char *buf, uint len); void glk_stylehint_set(uint wintype, uint styl, uint hint, int val); void glk_stylehint_clear(uint wintype, uint style, uint hint); uint glk_style_distinguish(winid_t win, uint style1, uint style2); bool glk_style_measure(winid_t win, uint style, uint hint, uint *result); frefid_t glk_fileref_create_temp(uint usage, uint rock = 0); frefid_t glk_fileref_create_by_name(uint usage, const char *name, uint rock = 0); frefid_t glk_fileref_create_by_prompt(uint usage, FileMode fmode, uint rock = 0); frefid_t glk_fileref_create_from_fileref(uint usage, frefid_t fref, uint rock = 0); void glk_fileref_destroy(frefid_t fref); frefid_t glk_fileref_iterate(frefid_t fref, uint *rockptr); uint glk_fileref_get_rock(frefid_t fref); void glk_fileref_delete_file(frefid_t fref); uint glk_fileref_does_file_exist(frefid_t fref); void glk_select(event_t *event); void glk_select_poll(event_t *event); void glk_request_timer_events(uint millisecs); void glk_request_line_event(winid_t win, char *buf, uint maxlen, uint initlen); void glk_request_char_event(winid_t win); void glk_request_mouse_event(winid_t win); void glk_cancel_line_event(winid_t win, event_t *event); void glk_cancel_char_event(winid_t win); void glk_cancel_mouse_event(winid_t win); #ifdef GLK_MODULE_LINE_ECHO void glk_set_echo_line_event(winid_t win, uint val); #endif /* GLK_MODULE_LINE_ECHO */ #ifdef GLK_MODULE_LINE_TERMINATORS void glk_set_terminators_line_event(winid_t win, const uint32 *keycodes, uint count); #endif /* GLK_MODULE_LINE_TERMINATORS */ /** \addtogroup Unicode * @{ */ uint glk_buffer_to_lower_case_uni(uint32 *buf, uint len, uint numchars); uint glk_buffer_to_upper_case_uni(uint32 *buf, uint len, uint numchars); uint glk_buffer_to_title_case_uni(uint32 *buf, uint len, uint numchars, uint lowerrest); void glk_put_char_uni(uint32 ch); void glk_put_string_uni(const uint32 *s); void glk_put_buffer_uni(const uint32 *buf, uint len); void glk_put_char_stream_uni(strid_t str, uint32 ch); void glk_put_string_stream_uni(strid_t str, const uint32 *s); void glk_put_buffer_stream_uni(strid_t str, const uint32 *buf, uint len); int glk_get_char_stream_uni(strid_t str); uint glk_get_buffer_stream_uni(strid_t str, uint32 *buf, uint len); uint glk_get_line_stream_uni(strid_t str, uint32 *buf, uint len); strid_t glk_stream_open_file_uni(frefid_t fileref, FileMode fmode, uint rock = 0); strid_t glk_stream_open_memory_uni(uint32 *buf, uint buflen, FileMode fmode, uint rock = 0); void glk_request_char_event_uni(winid_t win); void glk_request_line_event_uni(winid_t win, uint32 *buf, uint maxlen, uint initlen); /** @}*/ #ifdef GLK_MODULE_UNICODE_NORM uint glk_buffer_canon_decompose_uni(uint32 *buf, uint len, uint numchars); uint glk_buffer_canon_normalize_uni(uint32 *buf, uint len, uint numchars); #endif /* GLK_MODULE_UNICODE_NORM */ #ifdef GLK_MODULE_IMAGE bool glk_image_draw(winid_t win, uint image, int val1, int val2); bool glk_image_draw_scaled(winid_t win, uint image, int val1, int val2, uint width, uint height); bool glk_image_draw(winid_t win, const Graphics::Surface &image, uint transColor = (uint)-1, int xp = 0, int yp = 0); bool glk_image_draw_scaled(winid_t win, const Graphics::Surface &image, uint transColor, int xp, int yp, uint width, uint height); bool glk_image_get_info(uint image, uint *width, uint *height); void glk_window_flow_break(winid_t win); void glk_window_erase_rect(winid_t win, int left, int top, uint width, uint height); void glk_window_fill_rect(winid_t win, uint color, int left, int top, uint width, uint height); void glk_window_set_background_color(winid_t win, uint color); #endif /* GLK_MODULE_IMAGE */ #ifdef GLK_MODULE_SOUND schanid_t glk_schannel_create(uint rock = 0); void glk_schannel_destroy(schanid_t chan); schanid_t glk_schannel_iterate(schanid_t chan, uint *rockptr); uint glk_schannel_get_rock(schanid_t chan); uint glk_schannel_play(schanid_t chan, uint snd); uint glk_schannel_play_ext(schanid_t chan, uint snd, uint repeats, uint notify); void glk_schannel_stop(schanid_t chan); void glk_schannel_set_volume(schanid_t chan, uint vol); void glk_sound_load_hint(uint snd, uint flag); #ifdef GLK_MODULE_SOUND2 /* Note that this section is nested inside the #ifdef GLK_MODULE_SOUND. GLK_MODULE_SOUND must be defined if GLK_MODULE_SOUND2 is. */ schanid_t glk_schannel_create_ext(uint rock, uint volume); uint glk_schannel_play_multi(schanid_t *chanarray, uint chancount, uint *sndarray, uint soundcount, uint notify); void glk_schannel_pause(schanid_t chan); void glk_schannel_unpause(schanid_t chan); void glk_schannel_set_volume_ext(schanid_t chan, uint vol, uint duration, uint notify); #endif /* GLK_MODULE_SOUND2 */ #endif /* GLK_MODULE_SOUND */ #ifdef GLK_MODULE_HYPERLINKS void glk_set_hyperlink(uint linkval); void glk_set_hyperlink_stream(strid_t str, uint linkval); void glk_request_hyperlink_event(winid_t win); void glk_cancel_hyperlink_event(winid_t win); #endif /* GLK_MODULE_HYPERLINKS */ #ifdef GLK_MODULE_DATETIME void glk_current_time(glktimeval_t *time); int glk_current_simple_time(uint factor); void glk_time_to_date_utc(const glktimeval_t *time, glkdate_t *date); void glk_time_to_date_local(const glktimeval_t *time, glkdate_t *date); void glk_simple_time_to_date_utc(int time, uint factor, glkdate_t *date); void glk_simple_time_to_date_local(int time, uint factor, glkdate_t *date); void glk_date_to_time_utc(const glkdate_t *date, glktimeval_t *time); void glk_date_to_time_local(const glkdate_t *date, glktimeval_t *time); int glk_date_to_simple_time_utc(const glkdate_t *date, uint factor); int glk_date_to_simple_time_local(const glkdate_t *date, uint factor); #endif /* GLK_MODULE_DATETIME */ /* XXX non-official Glk functions that may or may not exist */ #define GARGLK 1 const char *garglk_fileref_get_name(frefid_t fref) const; void garglk_set_program_name(const char *name); void garglk_set_program_info(const char *info); void garglk_set_story_name(const char *name); void garglk_set_story_title(const char *title); void garglk_set_config(const char *name); /** * Removes the specified string from the end of the output buffer, if * indeed it is there. */ void garglk_unput_string(const char *str); /** * Removes the specified string from the end of the output buffer, if * indeed it is there. */ void garglk_unput_string_uni(const uint32 *str); void garglk_set_zcolors(uint fg, uint bg); void garglk_set_zcolors_stream(strid_t str, uint fg, uint bg); void garglk_set_reversevideo(uint reverse); void garglk_set_reversevideo_stream(strid_t str, uint reverse); void garglk_window_get_cursor(winid_t win, uint *xpos, uint *ypos); void garglk_window_get_cursor_current(uint *xpos, uint *ypos); /* dispa methods */ void gidispatch_set_object_registry(gidispatch_rock_t(*regi)(void *obj, uint objclass), void(*unregi)(void *obj, uint objclass, gidispatch_rock_t objrock)); void gidispatch_set_retained_registry(gidispatch_rock_t(*regi)(void *array, uint len, const char *typecode), void(*unregi)(void *array, uint len, const char *typecode, gidispatch_rock_t objrock)); uint32 gidispatch_count_classes() const; const gidispatch_intconst_t *gidispatch_get_class(uint32 index) const; uint32 gidispatch_count_intconst() const; const gidispatch_intconst_t *gidispatch_get_intconst(uint32 index) const; const char *gidispatch_prototype(uint32 funcnum) const; void gidispatch_call(uint32 funcnum, uint32 numargs, gluniversal_t *arglist); gidispatch_rock_t gidispatch_get_objrock(void *obj, uint objclass); }; } // End of namespace Glk #endif