summaryrefslogtreecommitdiffstats
path: root/terminal.c
diff options
context:
space:
mode:
authorKristian Høgsberg <krh@redhat.com>2008-12-22 12:14:50 -0500
committerKristian Høgsberg <krh@redhat.com>2008-12-22 12:14:50 -0500
commit0395f30e652bd32234942206bce15e7e6f3a9fb1 (patch)
tree0e6b609b38b3ce520b5be9da8143081a02b4dddb /terminal.c
parentee02ca6fa489a99ddec5d1542d51cce9948d39a9 (diff)
downloadwayland-0395f30e652bd32234942206bce15e7e6f3a9fb1.tar.gz
wayland-0395f30e652bd32234942206bce15e7e6f3a9fb1.tar.xz
wayland-0395f30e652bd32234942206bce15e7e6f3a9fb1.zip
Add a fullscreen mode to the terminal.
Diffstat (limited to 'terminal.c')
-rw-r--r--terminal.c50
1 files changed, 40 insertions, 10 deletions
diff --git a/terminal.c b/terminal.c
index 5855d2a..1010836 100644
--- a/terminal.c
+++ b/terminal.c
@@ -43,6 +43,7 @@
#include "cairo-util.h"
#include "window.h"
+static int option_fullscreen;
static const char gem_device[] = "/dev/dri/card0";
static const char socket_name[] = "\0wayland";
@@ -65,6 +66,7 @@ struct terminal {
int escape_length;
int state;
int margin;
+ int fullscreen;
};
static char *
@@ -129,7 +131,7 @@ terminal_draw_contents(struct terminal *terminal)
cairo_surface_t *surface;
cairo_t *cr;
cairo_font_extents_t extents;
- int i;
+ int i, top_margin, side_margin;
window_get_child_rectangle(terminal->window, &rectangle);
@@ -148,9 +150,12 @@ terminal_draw_contents(struct terminal *terminal)
cairo_set_font_size(cr, 14);
cairo_font_extents(cr, &extents);
+ side_margin = (rectangle.width - terminal->width * extents.max_x_advance) / 2;
+ top_margin = (rectangle.height - terminal->height * extents.height) / 2;
+
for (i = 0; i < terminal->height; i++) {
- cairo_move_to(cr, terminal->margin,
- terminal->margin + extents.ascent + extents.height * i);
+ cairo_move_to(cr, side_margin,
+ top_margin + extents.ascent + extents.height * i);
cairo_show_text(cr, terminal_get_row(terminal, i));
}
cairo_destroy(cr);
@@ -170,7 +175,7 @@ terminal_draw(struct terminal *terminal)
cairo_surface_t *surface;
cairo_font_extents_t extents;
cairo_t *cr;
- int width, height;
+ int32_t width, height;
window_get_child_rectangle(terminal->window, &rectangle);
@@ -188,10 +193,11 @@ terminal_draw(struct terminal *terminal)
height = (rectangle.height - 2 * terminal->margin) / (int32_t) extents.height;
terminal_resize(terminal, width, height);
- rectangle.width = terminal->width * extents.max_x_advance + 2 * terminal->margin;
- rectangle.height = terminal->height * extents.height + 2 * terminal->margin;
-
- window_set_child_size(terminal->window, &rectangle);
+ if (!terminal->fullscreen) {
+ rectangle.width = terminal->width * extents.max_x_advance + 2 * terminal->margin;
+ rectangle.height = terminal->height * extents.height + 2 * terminal->margin;
+ window_set_child_size(terminal->window, &rectangle);
+ }
window_draw(terminal->window);
terminal_draw_contents(terminal);
@@ -495,6 +501,13 @@ key_handler(struct window *window, uint32_t key, uint32_t state, void *data)
case KEY_RIGHTALT:
mod = MOD_ALT;
break;
+ case KEY_F11:
+ if (!state)
+ break;
+ terminal->fullscreen ^= 1;
+ window_set_fullscreen(window, terminal->fullscreen);
+ terminal_schedule_redraw(terminal);
+ break;
default:
if (key < ARRAY_LENGTH(evdev_keymap)) {
if (terminal->modifiers & MOD_CTRL)
@@ -516,7 +529,7 @@ key_handler(struct window *window, uint32_t key, uint32_t state, void *data)
}
static struct terminal *
-terminal_create(struct wl_display *display, int fd)
+terminal_create(struct wl_display *display, int fd, int fullscreen)
{
struct terminal *terminal;
@@ -526,6 +539,7 @@ terminal_create(struct wl_display *display, int fd)
memset(terminal, 0, sizeof *terminal);
terminal->fd = fd;
+ terminal->fullscreen = fullscreen;
terminal->window = window_create(display, fd, "Wayland Terminal",
500, 100, 500, 400);
terminal->display = display;
@@ -533,6 +547,7 @@ terminal_create(struct wl_display *display, int fd)
terminal->margin = 5;
terminal->compositor = wl_display_get_compositor(display);
+ window_set_fullscreen(terminal->window, terminal->fullscreen);
window_set_resize_handler(terminal->window, resize_handler, terminal);
window_set_acknowledge_handler(terminal->window, acknowledge_handler, terminal);
window_set_key_handler(terminal->window, key_handler, terminal);
@@ -588,6 +603,12 @@ terminal_run(struct terminal *terminal, const char *path)
return 0;
}
+static const GOptionEntry option_entries[] = {
+ { "fullscreen", 'f', 0, G_OPTION_ARG_NONE,
+ &option_fullscreen, "Run in fullscreen mode" },
+ { NULL }
+};
+
int main(int argc, char *argv[])
{
struct wl_display *display;
@@ -595,6 +616,15 @@ int main(int argc, char *argv[])
GMainLoop *loop;
GSource *source;
struct terminal *terminal;
+ GOptionContext *context;
+ GError *error;
+
+ context = g_option_context_new(NULL);
+ g_option_context_add_main_entries(context, option_entries, "Wayland Terminal");
+ if (!g_option_context_parse(context, &argc, &argv, &error)) {
+ fprintf(stderr, "option parsing failed: %s\n", error->message);
+ exit(EXIT_FAILURE);
+ }
fd = open(gem_device, O_RDWR);
if (fd < 0) {
@@ -612,7 +642,7 @@ int main(int argc, char *argv[])
source = wl_glib_source_new(display);
g_source_attach(source, NULL);
- terminal = terminal_create(display, fd);
+ terminal = terminal_create(display, fd, option_fullscreen);
if (terminal_run(terminal, "/bin/bash"))
exit(EXIT_FAILURE);