mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-11 21:39:56 +03:00
[project @ 2003-08-26 22:37:32 by bursa]
Break out dialog related code from gui.c. svn path=/import/netsurf/; revision=251
This commit is contained in:
parent
1e6e665e35
commit
fd5b6d0c80
Binary file not shown.
2
makefile
2
makefile
@ -12,7 +12,7 @@ OBJECTS_COMMON = cache.o content.o fetch.o fetchcache.o other.o \
|
|||||||
messages.o utils.o
|
messages.o utils.o
|
||||||
OBJECTS = $(OBJECTS_COMMON) \
|
OBJECTS = $(OBJECTS_COMMON) \
|
||||||
browser.o netsurf.o \
|
browser.o netsurf.o \
|
||||||
gif.o gui.o jpeg.o menus.o png.o theme.o plugin.o \
|
dialog.o gif.o gui.o jpeg.o menus.o png.o theme.o plugin.o \
|
||||||
options.o filetype.o font.o uri.o
|
options.o filetype.o font.o uri.o
|
||||||
OBJECTS_DEBUG = $(OBJECTS_COMMON) \
|
OBJECTS_DEBUG = $(OBJECTS_COMMON) \
|
||||||
netsurfd.o \
|
netsurfd.o \
|
||||||
|
256
riscos/dialog.c
Normal file
256
riscos/dialog.c
Normal file
@ -0,0 +1,256 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of NetSurf, http://netsurf.sourceforge.net/
|
||||||
|
* Licensed under the GNU General Public License,
|
||||||
|
* http://www.opensource.org/licenses/gpl-license
|
||||||
|
* Copyright 2003 Phil Mellor <monkeyson@users.sourceforge.net>
|
||||||
|
* Copyright 2003 James Bursa <bursa@users.sourceforge.net>
|
||||||
|
* Copyright 2003 John M Bell <jmb202@ecs.soton.ac.uk>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "oslib/wimp.h"
|
||||||
|
#include "netsurf/riscos/gui.h"
|
||||||
|
#include "netsurf/riscos/options.h"
|
||||||
|
#include "netsurf/utils/utils.h"
|
||||||
|
|
||||||
|
|
||||||
|
#define GESTURES_URL "file:///%3CNetSurf$Dir%3E/Resources/gestures"
|
||||||
|
#define THEMES_URL "http://netsurf.sourceforge.net/themes/"
|
||||||
|
|
||||||
|
|
||||||
|
wimp_w dialog_info, dialog_saveas, dialog_config, dialog_config_br,
|
||||||
|
dialog_config_prox, dialog_config_th;
|
||||||
|
|
||||||
|
|
||||||
|
static wimp_w ro_gui_dialog_create(const char *template_name);
|
||||||
|
static void ro_gui_dialog_click_config(wimp_pointer *pointer);
|
||||||
|
static void ro_gui_dialog_click_config_br(wimp_pointer *pointer);
|
||||||
|
static void ro_gui_dialog_click_config_prox(wimp_pointer *pointer);
|
||||||
|
static void ro_gui_dialog_click_config_th(wimp_pointer *pointer);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load and create dialogs from template file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_init(void)
|
||||||
|
{
|
||||||
|
wimp_open_template("<NetSurf$Dir>.Resources.Templates");
|
||||||
|
dialog_info = ro_gui_dialog_create("info");
|
||||||
|
dialog_saveas = ro_gui_dialog_create("saveas");
|
||||||
|
dialog_config = ro_gui_dialog_create("config");
|
||||||
|
dialog_config_br = ro_gui_dialog_create("config_br");
|
||||||
|
dialog_config_prox = ro_gui_dialog_create("config_prox");
|
||||||
|
dialog_config_th = ro_gui_dialog_create("config_th");
|
||||||
|
wimp_close_template();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a window from a template.
|
||||||
|
*/
|
||||||
|
|
||||||
|
wimp_w ro_gui_dialog_create(const char *template_name)
|
||||||
|
{
|
||||||
|
char name[20];
|
||||||
|
int context, window_size, data_size;
|
||||||
|
char *data;
|
||||||
|
wimp_window *window;
|
||||||
|
wimp_w w;
|
||||||
|
|
||||||
|
/* wimp_load_template won't accept a const char * */
|
||||||
|
strncpy(name, template_name, 20);
|
||||||
|
|
||||||
|
/* find required buffer sizes */
|
||||||
|
context = wimp_load_template(wimp_GET_SIZE, 0, 0, wimp_NO_FONTS,
|
||||||
|
name, 0, &window_size, &data_size);
|
||||||
|
assert(context != 0);
|
||||||
|
|
||||||
|
window = xcalloc((unsigned int) window_size, 1);
|
||||||
|
data = xcalloc((unsigned int) data_size, 1);
|
||||||
|
|
||||||
|
/* load and create */
|
||||||
|
wimp_load_template(window, data, data + data_size, wimp_NO_FONTS,
|
||||||
|
name, 0, 0, 0);
|
||||||
|
w = wimp_create_window(window);
|
||||||
|
|
||||||
|
/* the window definition is copied by the wimp and may be freed */
|
||||||
|
xfree(window);
|
||||||
|
|
||||||
|
return w;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle clicks in one of the dialog boxes.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_click(wimp_pointer *pointer)
|
||||||
|
{
|
||||||
|
if (pointer->buttons == wimp_CLICK_MENU)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (pointer->w == dialog_config)
|
||||||
|
ro_gui_dialog_click_config(pointer);
|
||||||
|
else if (pointer->w == dialog_config_br)
|
||||||
|
ro_gui_dialog_click_config_br(pointer);
|
||||||
|
else if (pointer->w == dialog_config_prox)
|
||||||
|
ro_gui_dialog_click_config_prox(pointer);
|
||||||
|
else if (pointer->w == dialog_config_th)
|
||||||
|
ro_gui_dialog_click_config_th(pointer);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle clicks in the main Choices dialog.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_click_config(wimp_pointer *pointer)
|
||||||
|
{
|
||||||
|
switch (pointer->i) {
|
||||||
|
case ICON_CONFIG_SAVE:
|
||||||
|
ro_to_options(&choices, &OPTIONS);
|
||||||
|
options_write(&OPTIONS, NULL);
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT) {
|
||||||
|
ro_gui_dialog_close(dialog_config_br);
|
||||||
|
ro_gui_dialog_close(dialog_config_prox);
|
||||||
|
ro_gui_dialog_close(dialog_config_th);
|
||||||
|
ro_gui_dialog_close(dialog_config);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_CANCEL:
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT) {
|
||||||
|
ro_gui_dialog_close(dialog_config_br);
|
||||||
|
ro_gui_dialog_close(dialog_config_prox);
|
||||||
|
ro_gui_dialog_close(dialog_config_th);
|
||||||
|
ro_gui_dialog_close(dialog_config);
|
||||||
|
} else {
|
||||||
|
options_to_ro(&OPTIONS, &choices);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_BROWSER:
|
||||||
|
ro_gui_show_browser_choices();
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_PROXY:
|
||||||
|
ro_gui_show_proxy_choices();
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_THEME:
|
||||||
|
ro_gui_show_theme_choices();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle clicks in the Browser Choices dialog.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_click_config_br(wimp_pointer *pointer)
|
||||||
|
{
|
||||||
|
struct browser_window* bw;
|
||||||
|
|
||||||
|
switch (pointer->i) {
|
||||||
|
case ICON_CONFIG_BR_OK:
|
||||||
|
get_browser_choices(&choices.browser);
|
||||||
|
get_browser_choices(&browser_choices);
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT)
|
||||||
|
ro_gui_dialog_close(dialog_config_br);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_BR_CANCEL:
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT)
|
||||||
|
ro_gui_dialog_close(dialog_config_br);
|
||||||
|
else
|
||||||
|
set_browser_choices(&choices.browser);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_BR_EXPLAIN:
|
||||||
|
bw = create_browser_window(browser_TITLE | browser_TOOLBAR |
|
||||||
|
browser_SCROLL_X_ALWAYS | browser_SCROLL_Y_ALWAYS, 320, 256);
|
||||||
|
gui_window_show(bw->window);
|
||||||
|
browser_window_open_location(bw, GESTURES_URL);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle clicks in the Proxy Choices dialog.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_click_config_prox(wimp_pointer *pointer)
|
||||||
|
{
|
||||||
|
switch (pointer->i) {
|
||||||
|
case ICON_CONFIG_PROX_OK:
|
||||||
|
get_proxy_choices(&choices.proxy);
|
||||||
|
get_proxy_choices(&proxy_choices);
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT)
|
||||||
|
ro_gui_dialog_close(dialog_config_prox);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_PROX_CANCEL:
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT)
|
||||||
|
ro_gui_dialog_close(dialog_config_prox);
|
||||||
|
else
|
||||||
|
set_proxy_choices(&choices.proxy);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle clicks in the Theme Choices dialog.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_click_config_th(wimp_pointer *pointer)
|
||||||
|
{
|
||||||
|
struct browser_window* bw;
|
||||||
|
|
||||||
|
switch (pointer->i) {
|
||||||
|
case ICON_CONFIG_TH_OK:
|
||||||
|
get_theme_choices(&choices.theme);
|
||||||
|
get_theme_choices(&theme_choices);
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT)
|
||||||
|
ro_gui_dialog_close(dialog_config_th);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_TH_CANCEL:
|
||||||
|
if (pointer->buttons == wimp_CLICK_SELECT)
|
||||||
|
ro_gui_dialog_close(dialog_config_th);
|
||||||
|
else
|
||||||
|
set_theme_choices(&choices.theme);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_TH_PICK:
|
||||||
|
ro_gui_build_theme_menu();
|
||||||
|
ro_gui_create_menu(theme_menu, pointer->pos.x - 64,
|
||||||
|
pointer->pos.y, NULL);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_TH_MANAGE:
|
||||||
|
os_cli("Filer_OpenDir " THEMES_DIR);
|
||||||
|
break;
|
||||||
|
case ICON_CONFIG_TH_GET:
|
||||||
|
bw = create_browser_window(browser_TITLE | browser_TOOLBAR |
|
||||||
|
browser_SCROLL_X_ALWAYS | browser_SCROLL_Y_ALWAYS, 480, 320);
|
||||||
|
gui_window_show(bw->window);
|
||||||
|
browser_window_open_location(bw, THEMES_URL);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Close a dialog box.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void ro_gui_dialog_close(wimp_w close)
|
||||||
|
{
|
||||||
|
if (close == dialog_config)
|
||||||
|
config_open = 0;
|
||||||
|
else if (close == dialog_config_br)
|
||||||
|
config_br_open = 0;
|
||||||
|
else if (close == dialog_config_prox)
|
||||||
|
config_prox_open = 0;
|
||||||
|
else if (close == dialog_config_th) {
|
||||||
|
config_th_open = 0;
|
||||||
|
ro_gui_destroy_theme_menu();
|
||||||
|
}
|
||||||
|
wimp_close_window(close);
|
||||||
|
}
|
||||||
|
|
325
riscos/gui.c
325
riscos/gui.c
@ -10,6 +10,7 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
#include <stddef.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
@ -41,27 +42,9 @@ static gui_window *window_list = 0;
|
|||||||
int gadget_subtract_x;
|
int gadget_subtract_x;
|
||||||
int gadget_subtract_y;
|
int gadget_subtract_y;
|
||||||
const char* HOME_URL = "file:///%3CNetSurf$Dir%3E/Resources/intro";
|
const char* HOME_URL = "file:///%3CNetSurf$Dir%3E/Resources/intro";
|
||||||
const char* GESTURES_URL = "file:///%3CNetSurf$Dir%3E/Resources/gestures";
|
|
||||||
const char* THEMES_URL = "http://netsurf.sourceforge.net/themes/";
|
|
||||||
|
|
||||||
wimp_menu* theme_menu = NULL;
|
wimp_menu* theme_menu = NULL;
|
||||||
|
|
||||||
const char* THEME_DIR = "<NetSurf$Dir>.Themes";
|
|
||||||
|
|
||||||
const char* netsurf_messages_filename = "<NetSurf$Dir>.Resources.Messages";
|
|
||||||
messagetrans_control_block netsurf_messages_cb;
|
|
||||||
char* netsurf_messages_data;
|
|
||||||
|
|
||||||
const char* templates_messages_filename = "<NetSurf$Dir>.Resources.IconNames";
|
|
||||||
messagetrans_control_block templates_messages_cb;
|
|
||||||
char* templates_messages_data;
|
|
||||||
|
|
||||||
wimp_w netsurf_info;
|
|
||||||
wimp_w netsurf_saveas;
|
|
||||||
wimp_w config;
|
|
||||||
wimp_w config_br;
|
|
||||||
wimp_w config_prox;
|
|
||||||
wimp_w config_th;
|
|
||||||
|
|
||||||
struct ro_choices choices;
|
struct ro_choices choices;
|
||||||
struct browser_choices browser_choices;
|
struct browser_choices browser_choices;
|
||||||
@ -97,10 +80,6 @@ void gui_remove_gadget(struct gui_gadget* g);
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void ro_gui_load_messages(void);
|
|
||||||
static wimp_w ro_gui_load_template(const char* template_name);
|
|
||||||
static void ro_gui_load_templates(void);
|
|
||||||
static wimp_i ro_gui_icon(char* token);
|
|
||||||
static int window_x_units(int scr_units, wimp_window_state* win);
|
static int window_x_units(int scr_units, wimp_window_state* win);
|
||||||
static int window_y_units(int scr_units, wimp_window_state* win);
|
static int window_y_units(int scr_units, wimp_window_state* win);
|
||||||
static void ro_gui_window_redraw_box(struct content *content, struct box * box,
|
static void ro_gui_window_redraw_box(struct content *content, struct box * box,
|
||||||
@ -119,7 +98,6 @@ static void ro_gui_drag_box(wimp_drag* drag, struct ro_gui_drag_info* drag_info)
|
|||||||
static void ro_gui_drag_end(wimp_dragged* drag);
|
static void ro_gui_drag_end(wimp_dragged* drag);
|
||||||
static void ro_gui_window_mouse_at(wimp_pointer* pointer);
|
static void ro_gui_window_mouse_at(wimp_pointer* pointer);
|
||||||
static void ro_gui_toolbar_click(gui_window* g, wimp_pointer* pointer);
|
static void ro_gui_toolbar_click(gui_window* g, wimp_pointer* pointer);
|
||||||
static void ro_gui_w_click(wimp_pointer* pointer);
|
|
||||||
static double calculate_angle(double x, double y);
|
static double calculate_angle(double x, double y);
|
||||||
static int anglesDifferent(double a, double b);
|
static int anglesDifferent(double a, double b);
|
||||||
static mouseaction ro_gui_try_mouse_action(void);
|
static mouseaction ro_gui_try_mouse_action(void);
|
||||||
@ -128,88 +106,9 @@ static void ro_gui_keypress(wimp_key* key);
|
|||||||
static void ro_msg_datasave(wimp_message* block);
|
static void ro_msg_datasave(wimp_message* block);
|
||||||
static void ro_msg_dataload(wimp_message* block);
|
static void ro_msg_dataload(wimp_message* block);
|
||||||
static void gui_set_gadget_extent(struct box* box, int x, int y, os_box* extent, struct gui_gadget* g);
|
static void gui_set_gadget_extent(struct box* box, int x, int y, os_box* extent, struct gui_gadget* g);
|
||||||
static void ro_gui_close_dialog(wimp_w close);
|
|
||||||
|
|
||||||
|
|
||||||
void ro_gui_close_dialog(wimp_w close)
|
|
||||||
{
|
|
||||||
if (close == config)
|
|
||||||
config_open = 0;
|
|
||||||
else if (close == config_br)
|
|
||||||
config_br_open = 0;
|
|
||||||
else if (close == config_prox)
|
|
||||||
config_prox_open = 0;
|
|
||||||
else if (close == config_th)
|
|
||||||
{
|
|
||||||
config_th_open = 0;
|
|
||||||
ro_gui_destroy_theme_menu();
|
|
||||||
}
|
|
||||||
wimp_close_window(close);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ro_gui_load_messages(void)
|
|
||||||
{
|
|
||||||
int size;
|
|
||||||
messagetrans_file_flags flags;
|
|
||||||
|
|
||||||
fprintf(stderr, "opening messages:\n");
|
|
||||||
messagetrans_file_info(netsurf_messages_filename, &flags, &size);
|
|
||||||
fprintf(stderr, "allocating %d bytes\n", size);
|
|
||||||
netsurf_messages_data = xcalloc((unsigned int) size, sizeof(char));
|
|
||||||
messagetrans_open_file(&netsurf_messages_cb, netsurf_messages_filename,
|
|
||||||
netsurf_messages_data);
|
|
||||||
fprintf(stderr, "messages opened\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
wimp_w ro_gui_load_template(const char* template_name)
|
|
||||||
{
|
|
||||||
int winicon;
|
|
||||||
int indirected;
|
|
||||||
wimp_window *window;
|
|
||||||
char* data;
|
|
||||||
int temp;
|
|
||||||
char name[20];
|
|
||||||
|
|
||||||
strcpy(name, template_name); /* wimp_load_template won't accept a const char * */
|
|
||||||
|
|
||||||
wimp_load_template(wimp_GET_SIZE, 0, 0, wimp_NO_FONTS, name, 0, &winicon, &indirected);
|
|
||||||
data = (char *) window = xcalloc((unsigned int) (winicon + indirected + 16), 1);
|
|
||||||
wimp_load_template(window, data+winicon, data+winicon+indirected,
|
|
||||||
wimp_NO_FONTS, name, 0, &temp, &temp);
|
|
||||||
return wimp_create_window(window);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ro_gui_load_templates(void)
|
|
||||||
{
|
|
||||||
int size;
|
|
||||||
messagetrans_file_flags flags;
|
|
||||||
|
|
||||||
messagetrans_file_info(templates_messages_filename, &flags, &size);
|
|
||||||
templates_messages_data = xcalloc((unsigned int) size, sizeof(char));
|
|
||||||
messagetrans_open_file(&templates_messages_cb, templates_messages_filename,
|
|
||||||
templates_messages_data);
|
|
||||||
|
|
||||||
wimp_open_template("<NetSurf$Dir>.Resources.Templates");
|
|
||||||
netsurf_info = ro_gui_load_template("info");
|
|
||||||
netsurf_saveas = ro_gui_load_template("saveas");
|
|
||||||
config = ro_gui_load_template("config");
|
|
||||||
config_br = ro_gui_load_template("config_br");
|
|
||||||
config_prox = ro_gui_load_template("config_prox");
|
|
||||||
config_th = ro_gui_load_template("config_th");
|
|
||||||
wimp_close_template();
|
|
||||||
}
|
|
||||||
|
|
||||||
wimp_i ro_gui_icon(char* token)
|
|
||||||
{
|
|
||||||
int used;
|
|
||||||
char buffer[32];
|
|
||||||
|
|
||||||
messagetrans_lookup(&templates_messages_cb, token, buffer, 32, 0,0,0,0, &used);
|
|
||||||
if (used > 0)
|
|
||||||
return atoi(buffer);
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
wimp_menu* combo_menu;
|
wimp_menu* combo_menu;
|
||||||
@ -1103,8 +1002,7 @@ void gui_init(int argc, char** argv)
|
|||||||
LOG(("Using theme '%s' - from '%s'",theme_fname, OPTIONS.theme));
|
LOG(("Using theme '%s' - from '%s'",theme_fname, OPTIONS.theme));
|
||||||
current_theme = ro_theme_create(theme_fname);
|
current_theme = ro_theme_create(theme_fname);
|
||||||
|
|
||||||
ro_gui_load_templates();
|
ro_gui_dialog_init();
|
||||||
ro_gui_load_messages();
|
|
||||||
ro_gui_menus_init();
|
ro_gui_menus_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1311,142 +1209,7 @@ void ro_gui_toolbar_click(gui_window* g, wimp_pointer* pointer)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ro_gui_w_click(wimp_pointer* pointer)
|
|
||||||
{
|
|
||||||
if (pointer->w == netsurf_info)
|
|
||||||
{
|
|
||||||
if (pointer->i == ro_gui_icon("INFO_URL"))
|
|
||||||
{
|
|
||||||
struct browser_window* bw;
|
|
||||||
bw = create_browser_window(browser_TITLE | browser_TOOLBAR
|
|
||||||
| browser_SCROLL_X_ALWAYS | browser_SCROLL_Y_ALWAYS, 640, 480);
|
|
||||||
gui_window_show(bw->window);
|
|
||||||
browser_window_open_location(bw, "http://sourceforge.net/projects/netsurf/");
|
|
||||||
wimp_set_caret_position(bw->window->data.browser.toolbar, ro_theme_icon(current_theme, THEME_TOOLBAR, "TOOLBAR_URL"),
|
|
||||||
0,0,-1, strlen(bw->window->url) - 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (pointer->w == config && (pointer->buttons == 4 || pointer->buttons == 1))
|
|
||||||
{
|
|
||||||
if (pointer->i == ro_gui_icon("CONFIG_BROWSER"))
|
|
||||||
ro_gui_show_browser_choices();
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_PROXY"))
|
|
||||||
ro_gui_show_proxy_choices();
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_THEME"))
|
|
||||||
ro_gui_show_theme_choices();
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_OK") || pointer->i == ro_gui_icon("CONFIG_SAVE"))
|
|
||||||
{
|
|
||||||
LOG(("converting optons"));
|
|
||||||
ro_to_options(&choices, &OPTIONS);
|
|
||||||
LOG(("testing save"));
|
|
||||||
if (pointer->i == ro_gui_icon("CONFIG_SAVE"))
|
|
||||||
options_write(&OPTIONS, NULL);
|
|
||||||
LOG(("closing windows"));
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
{
|
|
||||||
ro_gui_close_dialog(config_br);
|
|
||||||
ro_gui_close_dialog(config_prox);
|
|
||||||
ro_gui_close_dialog(config_th);
|
|
||||||
ro_gui_close_dialog(config);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_CANCEL"))
|
|
||||||
{
|
|
||||||
ro_gui_close_dialog(config_br);
|
|
||||||
ro_gui_close_dialog(config_prox);
|
|
||||||
ro_gui_close_dialog(config_th);
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config);
|
|
||||||
else
|
|
||||||
options_to_ro(&OPTIONS, &choices);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (pointer->w == config_br && (pointer->buttons == 4 || pointer->buttons == 1))
|
|
||||||
{
|
|
||||||
if (pointer->i == ro_gui_icon("CONFIG_BR_OK"))
|
|
||||||
{
|
|
||||||
get_browser_choices(&choices.browser);
|
|
||||||
get_browser_choices(&browser_choices);
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config_br);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_BR_CANCEL"))
|
|
||||||
{
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config_br);
|
|
||||||
else
|
|
||||||
set_browser_choices(&choices.browser);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_BR_DEFAULT"))
|
|
||||||
{
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_BR_EXPLAIN"))
|
|
||||||
{
|
|
||||||
struct browser_window* bw;
|
|
||||||
bw = create_browser_window(browser_TITLE | browser_TOOLBAR | browser_SCROLL_X_ALWAYS | browser_SCROLL_Y_ALWAYS, 320, 256);
|
|
||||||
gui_window_show(bw->window);
|
|
||||||
browser_window_open_location(bw, GESTURES_URL);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (pointer->w == config_prox && (pointer->buttons == 4 || pointer->buttons == 1))
|
|
||||||
{
|
|
||||||
if (pointer->i == ro_gui_icon("CONFIG_PROX_OK"))
|
|
||||||
{
|
|
||||||
get_proxy_choices(&choices.proxy);
|
|
||||||
get_proxy_choices(&proxy_choices);
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config_prox);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_PROX_CANCEL"))
|
|
||||||
{
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config_prox);
|
|
||||||
else
|
|
||||||
set_proxy_choices(&choices.proxy);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_PROX_DEFAULT"))
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (pointer->w == config_th && (pointer->buttons == 4 || pointer->buttons == 1))
|
|
||||||
{
|
|
||||||
if (pointer->i == ro_gui_icon("CONFIG_TH_OK"))
|
|
||||||
{
|
|
||||||
get_theme_choices(&choices.theme);
|
|
||||||
get_theme_choices(&theme_choices);
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config_th);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_TH_CANCEL"))
|
|
||||||
{
|
|
||||||
if (pointer->buttons != 1)
|
|
||||||
ro_gui_close_dialog(config_th);
|
|
||||||
else
|
|
||||||
set_theme_choices(&choices.theme);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_TH_DEFAULT"))
|
|
||||||
{
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_TH_PICK"))
|
|
||||||
{
|
|
||||||
ro_gui_build_theme_menu();
|
|
||||||
ro_gui_create_menu(theme_menu, pointer->pos.x - 64, pointer->pos.y, NULL);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_TH_MANAGE"))
|
|
||||||
{
|
|
||||||
char buffer[256];
|
|
||||||
sprintf(buffer, "*filer_opendir %s", THEME_DIR);
|
|
||||||
os_cli(buffer);
|
|
||||||
}
|
|
||||||
else if (pointer->i == ro_gui_icon("CONFIG_TH_GET"))
|
|
||||||
{
|
|
||||||
struct browser_window* bw;
|
|
||||||
bw = create_browser_window(browser_TITLE | browser_TOOLBAR | browser_SCROLL_X_ALWAYS | browser_SCROLL_Y_ALWAYS, 480, 320);
|
|
||||||
gui_window_show(bw->window);
|
|
||||||
browser_window_open_location(bw, THEMES_URL);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
double calculate_angle(double x, double y)
|
double calculate_angle(double x, double y)
|
||||||
{
|
{
|
||||||
@ -1822,7 +1585,7 @@ void gui_multitask(void)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case wimp_REDRAW_WINDOW_REQUEST :
|
case wimp_REDRAW_WINDOW_REQUEST :
|
||||||
if (block.redraw.w == config_th)
|
if (block.redraw.w == dialog_config_th)
|
||||||
ro_gui_redraw_config_th(&block.redraw);
|
ro_gui_redraw_config_th(&block.redraw);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -2067,7 +1830,7 @@ void gui_poll(void)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case wimp_REDRAW_WINDOW_REQUEST :
|
case wimp_REDRAW_WINDOW_REQUEST :
|
||||||
if (block.redraw.w == config_th)
|
if (block.redraw.w == dialog_config_th)
|
||||||
ro_gui_redraw_config_th(&block.redraw);
|
ro_gui_redraw_config_th(&block.redraw);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -2098,7 +1861,7 @@ void gui_poll(void)
|
|||||||
if (g != NULL)
|
if (g != NULL)
|
||||||
browser_window_destroy(g->data.browser.bw);
|
browser_window_destroy(g->data.browser.bw);
|
||||||
else
|
else
|
||||||
ro_gui_close_dialog(block.close.w);
|
ro_gui_dialog_close(&(block.close.w));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case wimp_POINTER_LEAVING_WINDOW :
|
case wimp_POINTER_LEAVING_WINDOW :
|
||||||
@ -2131,7 +1894,7 @@ void gui_poll(void)
|
|||||||
ro_gui_toolbar_click(g, &(block.pointer));
|
ro_gui_toolbar_click(g, &(block.pointer));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
ro_gui_w_click(&(block.pointer));
|
ro_gui_dialog_click(&(block.pointer));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -2281,7 +2044,7 @@ void gui_gadget_combo(struct browser_window* bw, struct gui_gadget* g, unsigned
|
|||||||
o = o->next;
|
o = o->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
combo_menu = xcalloc(1, sizeof(wimp_menu_entry) * count + offsetof(wimp_menu, entries));
|
combo_menu = xcalloc(1, wimp_SIZEOF_MENU(count));
|
||||||
|
|
||||||
combo_menu->title_data.indirected_text.text = "Select";
|
combo_menu->title_data.indirected_text.text = "Select";
|
||||||
combo_menu->title_fg = wimp_COLOUR_BLACK;
|
combo_menu->title_fg = wimp_COLOUR_BLACK;
|
||||||
@ -2539,7 +2302,7 @@ void gui_show_choices()
|
|||||||
if (!config_open)
|
if (!config_open)
|
||||||
options_to_ro(&OPTIONS, &choices);
|
options_to_ro(&OPTIONS, &choices);
|
||||||
|
|
||||||
open.w = config;
|
open.w = dialog_config;
|
||||||
wimp_get_window_state(&open);
|
wimp_get_window_state(&open);
|
||||||
open.next = wimp_TOP;
|
open.next = wimp_TOP;
|
||||||
wimp_open_window(&open);
|
wimp_open_window(&open);
|
||||||
@ -2592,35 +2355,35 @@ void set_icon_string_i(wimp_w w, wimp_i i, int num)
|
|||||||
void set_browser_choices(struct browser_choices* newchoices)
|
void set_browser_choices(struct browser_choices* newchoices)
|
||||||
{
|
{
|
||||||
memcpy(&browser_choices, newchoices, sizeof(struct browser_choices));
|
memcpy(&browser_choices, newchoices, sizeof(struct browser_choices));
|
||||||
set_icon_state(config_br, ro_gui_icon("CONFIG_BR_GESTURES"), browser_choices.use_mouse_gestures);
|
set_icon_state(dialog_config_br, ICON_CONFIG_BR_GESTURES, browser_choices.use_mouse_gestures);
|
||||||
set_icon_state(config_br, ro_gui_icon("CONFIG_BR_FORM"), browser_choices.use_riscos_elements);
|
set_icon_state(dialog_config_br, ICON_CONFIG_BR_FORM, browser_choices.use_riscos_elements);
|
||||||
set_icon_state(config_br, ro_gui_icon("CONFIG_BR_TEXT"), browser_choices.allow_text_selection);
|
set_icon_state(dialog_config_br, ICON_CONFIG_BR_TEXT, browser_choices.allow_text_selection);
|
||||||
set_icon_state(config_br, ro_gui_icon("CONFIG_BR_TOOLBAR"), browser_choices.show_toolbar);
|
set_icon_state(dialog_config_br, ICON_CONFIG_BR_TOOLBAR, browser_choices.show_toolbar);
|
||||||
set_icon_state(config_br, ro_gui_icon("CONFIG_BR_PREVIEW"), browser_choices.show_print_preview);
|
set_icon_state(dialog_config_br, ICON_CONFIG_BR_PREVIEW, browser_choices.show_print_preview);
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_browser_choices(struct browser_choices* newchoices)
|
void get_browser_choices(struct browser_choices* newchoices)
|
||||||
{
|
{
|
||||||
newchoices->use_mouse_gestures = get_icon_state(config_br, ro_gui_icon("CONFIG_BR_GESTURES"));
|
newchoices->use_mouse_gestures = get_icon_state(dialog_config_br, ICON_CONFIG_BR_GESTURES);
|
||||||
newchoices->use_riscos_elements = get_icon_state(config_br, ro_gui_icon("CONFIG_BR_FORM"));
|
newchoices->use_riscos_elements = get_icon_state(dialog_config_br, ICON_CONFIG_BR_FORM);
|
||||||
newchoices->allow_text_selection = get_icon_state(config_br, ro_gui_icon("CONFIG_BR_TEXT"));
|
newchoices->allow_text_selection = get_icon_state(dialog_config_br, ICON_CONFIG_BR_TEXT);
|
||||||
newchoices->show_toolbar = get_icon_state(config_br, ro_gui_icon("CONFIG_BR_TOOLBAR"));
|
newchoices->show_toolbar = get_icon_state(dialog_config_br, ICON_CONFIG_BR_TOOLBAR);
|
||||||
newchoices->show_print_preview = get_icon_state(config_br, ro_gui_icon("CONFIG_BR_PREVIEW"));
|
newchoices->show_print_preview = get_icon_state(dialog_config_br, ICON_CONFIG_BR_PREVIEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_proxy_choices(struct proxy_choices* newchoices)
|
void set_proxy_choices(struct proxy_choices* newchoices)
|
||||||
{
|
{
|
||||||
memcpy(&proxy_choices, newchoices, sizeof(struct proxy_choices));
|
memcpy(&proxy_choices, newchoices, sizeof(struct proxy_choices));
|
||||||
set_icon_state(config_prox, ro_gui_icon("CONFIG_PROX_HTTP"), proxy_choices.http);
|
set_icon_state(dialog_config_prox, ICON_CONFIG_PROX_HTTP, proxy_choices.http);
|
||||||
set_icon_string(config_prox, ro_gui_icon("CONFIG_PROX_HTTPHOST"), proxy_choices.http_proxy);
|
set_icon_string(dialog_config_prox, ICON_CONFIG_PROX_HTTPHOST, proxy_choices.http_proxy);
|
||||||
set_icon_string_i(config_prox, ro_gui_icon("CONFIG_PROX_HTTPPORT"), proxy_choices.http_port);
|
set_icon_string_i(dialog_config_prox, ICON_CONFIG_PROX_HTTPPORT, proxy_choices.http_port);
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_proxy_choices(struct proxy_choices* newchoices)
|
void get_proxy_choices(struct proxy_choices* newchoices)
|
||||||
{
|
{
|
||||||
newchoices->http = get_icon_state(config_prox, ro_gui_icon("CONFIG_PROX_HTTP"));
|
newchoices->http = get_icon_state(dialog_config_prox, ICON_CONFIG_PROX_HTTP);
|
||||||
strncpy(newchoices->http_proxy, get_icon_string(config_prox, ro_gui_icon("CONFIG_PROX_HTTPHOST")), 255);
|
strncpy(newchoices->http_proxy, get_icon_string(dialog_config_prox, ICON_CONFIG_PROX_HTTPHOST), 255);
|
||||||
newchoices->http_port = atoi(get_icon_string(config_prox, ro_gui_icon("CONFIG_PROX_HTTPPORT")));
|
newchoices->http_port = atoi(get_icon_string(dialog_config_prox, ICON_CONFIG_PROX_HTTPPORT));
|
||||||
}
|
}
|
||||||
|
|
||||||
osspriteop_area* theme_preview = NULL;
|
osspriteop_area* theme_preview = NULL;
|
||||||
@ -2632,14 +2395,14 @@ if (theme_preview != NULL)
|
|||||||
|
|
||||||
theme_preview = NULL;
|
theme_preview = NULL;
|
||||||
|
|
||||||
if (file_exists(THEME_DIR, thname, "Preview", 0xff9))
|
if (file_exists(THEMES_DIR, thname, "Preview", 0xff9))
|
||||||
{
|
{
|
||||||
char filename[256];
|
char filename[256];
|
||||||
FILE* fp;
|
FILE* fp;
|
||||||
int size;
|
int size;
|
||||||
|
|
||||||
|
|
||||||
sprintf(filename, "%s.%s.Preview", THEME_DIR, thname);
|
sprintf(filename, "%s.%s.Preview", THEMES_DIR, thname);
|
||||||
fp = fopen(filename, "rb");
|
fp = fopen(filename, "rb");
|
||||||
if (fp == 0) return;
|
if (fp == 0) return;
|
||||||
if (fseek(fp, 0, SEEK_END) != 0) die("fseek() failed");
|
if (fseek(fp, 0, SEEK_END) != 0) die("fseek() failed");
|
||||||
@ -2664,13 +2427,13 @@ int size;
|
|||||||
void set_theme_choices(struct theme_choices* newchoices)
|
void set_theme_choices(struct theme_choices* newchoices)
|
||||||
{
|
{
|
||||||
memcpy(&theme_choices, newchoices, sizeof(struct theme_choices));
|
memcpy(&theme_choices, newchoices, sizeof(struct theme_choices));
|
||||||
set_icon_string(config_th, ro_gui_icon("CONFIG_TH_NAME"), theme_choices.name);
|
set_icon_string(dialog_config_th, ICON_CONFIG_TH_NAME, theme_choices.name);
|
||||||
load_theme_preview(theme_choices.name);
|
load_theme_preview(theme_choices.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_theme_choices(struct theme_choices* newchoices)
|
void get_theme_choices(struct theme_choices* newchoices)
|
||||||
{
|
{
|
||||||
strncpy(newchoices->name, get_icon_string(config_th, ro_gui_icon("CONFIG_TH_NAME")), 255);
|
strncpy(newchoices->name, get_icon_string(dialog_config_th, ICON_CONFIG_TH_NAME), 255);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ro_gui_show_browser_choices()
|
void ro_gui_show_browser_choices()
|
||||||
@ -2680,7 +2443,7 @@ void ro_gui_show_browser_choices()
|
|||||||
if (!config_br_open)
|
if (!config_br_open)
|
||||||
set_browser_choices(&choices.browser);
|
set_browser_choices(&choices.browser);
|
||||||
|
|
||||||
open.w = config_br;
|
open.w = dialog_config_br;
|
||||||
wimp_get_window_state(&open);
|
wimp_get_window_state(&open);
|
||||||
open.next = wimp_TOP;
|
open.next = wimp_TOP;
|
||||||
wimp_open_window(&open);
|
wimp_open_window(&open);
|
||||||
@ -2694,7 +2457,7 @@ void ro_gui_show_proxy_choices()
|
|||||||
if (!config_prox_open)
|
if (!config_prox_open)
|
||||||
set_proxy_choices(&choices.proxy);
|
set_proxy_choices(&choices.proxy);
|
||||||
|
|
||||||
open.w = config_prox;
|
open.w = dialog_config_prox;
|
||||||
wimp_get_window_state(&open);
|
wimp_get_window_state(&open);
|
||||||
open.next = wimp_TOP;
|
open.next = wimp_TOP;
|
||||||
wimp_open_window(&open);
|
wimp_open_window(&open);
|
||||||
@ -2710,7 +2473,7 @@ void ro_gui_show_theme_choices()
|
|||||||
set_theme_choices(&choices.theme);
|
set_theme_choices(&choices.theme);
|
||||||
}
|
}
|
||||||
|
|
||||||
open.w = config_th;
|
open.w = dialog_config_th;
|
||||||
wimp_get_window_state(&open);
|
wimp_get_window_state(&open);
|
||||||
open.next = wimp_TOP;
|
open.next = wimp_TOP;
|
||||||
wimp_open_window(&open);
|
wimp_open_window(&open);
|
||||||
@ -2774,17 +2537,17 @@ void ro_gui_build_theme_menu()
|
|||||||
ro_gui_destroy_theme_menu();
|
ro_gui_destroy_theme_menu();
|
||||||
|
|
||||||
LOG(("enumerate themes"));
|
LOG(("enumerate themes"));
|
||||||
context = osgbpb_dir_entries_system_info(THEME_DIR, buffer, 1, context, 256, 0, &count);
|
context = osgbpb_dir_entries_system_info(THEMES_DIR, buffer, 1, context, 256, 0, &count);
|
||||||
while (context != -1)
|
while (context != -1)
|
||||||
{
|
{
|
||||||
LOG(("called"));
|
LOG(("called"));
|
||||||
info = (osgbpb_system_info*) buffer;
|
info = (osgbpb_system_info*) buffer;
|
||||||
if (info->obj_type == 2 /* directory */)
|
if (info->obj_type == 2 /* directory */)
|
||||||
{
|
{
|
||||||
if (file_exists(THEME_DIR, info->name, "Templates", 0xfec) &&
|
if (file_exists(THEMES_DIR, info->name, "Templates", 0xfec) &&
|
||||||
file_exists(THEME_DIR, info->name, "Sprites", 0xff9) &&
|
file_exists(THEMES_DIR, info->name, "Sprites", 0xff9) &&
|
||||||
file_exists(THEME_DIR, info->name, "IconNames", 0xfff) &&
|
file_exists(THEMES_DIR, info->name, "IconNames", 0xfff) &&
|
||||||
file_exists(THEME_DIR, info->name, "IconSizes", 0xfff))
|
file_exists(THEMES_DIR, info->name, "IconSizes", 0xfff))
|
||||||
{
|
{
|
||||||
LOG(("found"));
|
LOG(("found"));
|
||||||
name[num] = malloc(strlen(info->name) + 2);
|
name[num] = malloc(strlen(info->name) + 2);
|
||||||
@ -2792,7 +2555,7 @@ void ro_gui_build_theme_menu()
|
|||||||
num++;
|
num++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
context = osgbpb_dir_entries_system_info(THEME_DIR, buffer, 1, context, 256, 0, &count);
|
context = osgbpb_dir_entries_system_info(THEMES_DIR, buffer, 1, context, 256, 0, &count);
|
||||||
}
|
}
|
||||||
LOG(("mallocing"));
|
LOG(("mallocing"));
|
||||||
|
|
||||||
@ -2841,11 +2604,11 @@ void ro_gui_redraw_config_th(wimp_draw* redraw)
|
|||||||
wimp_window_state win;
|
wimp_window_state win;
|
||||||
osspriteop_trans_tab* trans_tab;
|
osspriteop_trans_tab* trans_tab;
|
||||||
|
|
||||||
win.w = config_th;
|
win.w = dialog_config_th;
|
||||||
wimp_get_window_state(&win);
|
wimp_get_window_state(&win);
|
||||||
|
|
||||||
preview.w = config_th;
|
preview.w = dialog_config_th;
|
||||||
preview.i = ro_gui_icon("CONFIG_TH_PREVIEW");
|
preview.i = ICON_CONFIG_TH_PREVIEW;
|
||||||
wimp_get_icon_state(&preview);
|
wimp_get_icon_state(&preview);
|
||||||
|
|
||||||
if (theme_preview != NULL)
|
if (theme_preview != NULL)
|
||||||
@ -2887,10 +2650,10 @@ void ro_gui_redraw_config_th(wimp_draw* redraw)
|
|||||||
void ro_gui_theme_menu_selection(char *theme)
|
void ro_gui_theme_menu_selection(char *theme)
|
||||||
{
|
{
|
||||||
strcpy(theme_choices.name, theme);
|
strcpy(theme_choices.name, theme);
|
||||||
set_icon_string(config_th, ro_gui_icon("CONFIG_TH_NAME"), theme_choices.name);
|
set_icon_string(dialog_config_th, ICON_CONFIG_TH_NAME, theme_choices.name);
|
||||||
load_theme_preview(theme_choices.name);
|
load_theme_preview(theme_choices.name);
|
||||||
wimp_set_icon_state(config_th, ro_gui_icon("CONFIG_TH_NAME"), 0, 0);
|
wimp_set_icon_state(dialog_config_th, ICON_CONFIG_TH_NAME, 0, 0);
|
||||||
wimp_set_icon_state(config_th, ro_gui_icon("CONFIG_TH_PREVIEW"), 0, 0);
|
wimp_set_icon_state(dialog_config_th, ICON_CONFIG_TH_PREVIEW, 0, 0);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
51
riscos/gui.h
51
riscos/gui.h
@ -12,14 +12,25 @@
|
|||||||
#include "netsurf/desktop/browser.h"
|
#include "netsurf/desktop/browser.h"
|
||||||
#include "netsurf/desktop/netsurf.h"
|
#include "netsurf/desktop/netsurf.h"
|
||||||
#include "netsurf/desktop/gui.h"
|
#include "netsurf/desktop/gui.h"
|
||||||
|
#include "netsurf/desktop/options.h"
|
||||||
|
|
||||||
extern wimp_w netsurf_info, netsurf_saveas;
|
#define THEMES_DIR "<NetSurf$Dir>.Themes"
|
||||||
|
|
||||||
|
extern wimp_w dialog_info, dialog_saveas, dialog_config, dialog_config_br,
|
||||||
|
dialog_config_prox, dialog_config_th;
|
||||||
extern wimp_menu *current_menu, *iconbar_menu, *browser_menu,
|
extern wimp_menu *current_menu, *iconbar_menu, *browser_menu,
|
||||||
*combo_menu, *theme_menu;
|
*combo_menu, *theme_menu;
|
||||||
extern int current_menu_x, current_menu_y, iconbar_menu_height;
|
extern int current_menu_x, current_menu_y, iconbar_menu_height;
|
||||||
extern struct gui_gadget *current_gadget;
|
extern struct gui_gadget *current_gadget;
|
||||||
extern const char *HOME_URL;
|
extern const char *HOME_URL;
|
||||||
|
|
||||||
|
extern struct ro_choices choices;
|
||||||
|
extern struct browser_choices browser_choices;
|
||||||
|
extern struct proxy_choices proxy_choices;
|
||||||
|
extern struct theme_choices theme_choices;
|
||||||
|
extern int config_open, config_br_open, config_prox_open, config_th_open;
|
||||||
|
|
||||||
|
|
||||||
struct ro_gui_window
|
struct ro_gui_window
|
||||||
{
|
{
|
||||||
gui_window_type type;
|
gui_window_type type;
|
||||||
@ -55,4 +66,42 @@ void ro_gui_menus_init(void);
|
|||||||
void ro_gui_create_menu(wimp_menu* menu, int x, int y, gui_window* g);
|
void ro_gui_create_menu(wimp_menu* menu, int x, int y, gui_window* g);
|
||||||
void ro_gui_menu_selection(wimp_selection* selection);
|
void ro_gui_menu_selection(wimp_selection* selection);
|
||||||
|
|
||||||
|
/* in dialog.c */
|
||||||
|
void ro_gui_dialog_init(void);
|
||||||
|
void ro_gui_dialog_click(wimp_pointer *pointer);
|
||||||
|
void ro_gui_dialog_close(wimp_w close);
|
||||||
|
|
||||||
|
/* icon numbers */
|
||||||
|
#define ICON_CONFIG_SAVE 0
|
||||||
|
#define ICON_CONFIG_CANCEL 1
|
||||||
|
#define ICON_CONFIG_BROWSER 2
|
||||||
|
#define ICON_CONFIG_PROXY 3
|
||||||
|
#define ICON_CONFIG_THEME 4
|
||||||
|
|
||||||
|
#define ICON_CONFIG_BR_OK 0
|
||||||
|
#define ICON_CONFIG_BR_CANCEL 1
|
||||||
|
#define ICON_CONFIG_BR_EXPLAIN 2
|
||||||
|
#define ICON_CONFIG_BR_DEFAULT 3
|
||||||
|
#define ICON_CONFIG_BR_FORM 4
|
||||||
|
#define ICON_CONFIG_BR_GESTURES 5
|
||||||
|
#define ICON_CONFIG_BR_TEXT 6
|
||||||
|
#define ICON_CONFIG_BR_TOOLBAR 7
|
||||||
|
#define ICON_CONFIG_BR_PREVIEW 8
|
||||||
|
|
||||||
|
#define ICON_CONFIG_PROX_OK 0
|
||||||
|
#define ICON_CONFIG_PROX_CANCEL 1
|
||||||
|
#define ICON_CONFIG_PROX_DEFAULT 2
|
||||||
|
#define ICON_CONFIG_PROX_HTTP 3
|
||||||
|
#define ICON_CONFIG_PROX_HTTPHOST 4
|
||||||
|
#define ICON_CONFIG_PROX_HTTPPORT 5
|
||||||
|
|
||||||
|
#define ICON_CONFIG_TH_OK 0
|
||||||
|
#define ICON_CONFIG_TH_CANCEL 1
|
||||||
|
#define ICON_CONFIG_TH_DEFAULT 2
|
||||||
|
#define ICON_CONFIG_TH_NAME 4
|
||||||
|
#define ICON_CONFIG_TH_PICK 5
|
||||||
|
#define ICON_CONFIG_TH_PREVIEW 7
|
||||||
|
#define ICON_CONFIG_TH_GET 8
|
||||||
|
#define ICON_CONFIG_TH_MANAGE 9
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -98,8 +98,8 @@ void ro_gui_menus_init(void)
|
|||||||
translate_menu(browser_selection_menu);
|
translate_menu(browser_selection_menu);
|
||||||
translate_menu(browser_navigate_menu);
|
translate_menu(browser_navigate_menu);
|
||||||
|
|
||||||
iconbar_menu->entries[0].sub_menu = (wimp_menu *) netsurf_info;
|
iconbar_menu->entries[0].sub_menu = (wimp_menu *) dialog_info;
|
||||||
browser_page_menu->entries[1].sub_menu = (wimp_menu *) netsurf_saveas;
|
browser_page_menu->entries[1].sub_menu = (wimp_menu *) dialog_saveas;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -162,7 +162,7 @@ void ro_gui_menu_selection(wimp_selection *selection)
|
|||||||
} else if (current_menu == iconbar_menu) {
|
} else if (current_menu == iconbar_menu) {
|
||||||
switch (selection->items[0]) {
|
switch (selection->items[0]) {
|
||||||
case 0: /* Info */
|
case 0: /* Info */
|
||||||
ro_gui_create_menu((wimp_menu *) netsurf_info,
|
ro_gui_create_menu((wimp_menu *) dialog_info,
|
||||||
pointer.pos.x, pointer.pos.y, 0);
|
pointer.pos.x, pointer.pos.y, 0);
|
||||||
break;
|
break;
|
||||||
case 1: /* Choices */
|
case 1: /* Choices */
|
||||||
|
Loading…
Reference in New Issue
Block a user