aboutsummaryrefslogtreecommitdiff
path: root/mt.c
blob: 373f9042fe50e9e0656c98ee30e4e90344e20b9d (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
#include <gtk/gtk.h>
#include <vte/vte.h>
#include <gdk/gdkkeysyms.h>


static void quit();
gboolean key_press_cb(GtkWidget *widget, GdkEventKey *event);
static void tab_new();
static void tab_close();

/* part of the code is from sakura. :) i just want a more minimal version, sakura is to code bloat for what i want. so snippets will do*/
/* i am very thankful for this part, because it really helped me figure out how to close tabs properly (sounds easy, but i am dumb as a doorknob*/
static GQuark term_data_id = 0;
#define  get_page_term( sakura, page_idx ) \
    (struct term*)g_object_get_qdata(G_OBJECT( gtk_notebook_get_nth_page( (GtkNotebook*)mt.notebook, page_idx ) ), term_data_id);


static struct {
	GtkWidget *win;
	GtkWidget *notebook;
	gchar *title;
} mt;
struct term {
	GtkWidget *vte;     /* Reference to VTE terminal */
	GtkWidget *scrollbar;
	GtkWidget *label;
	gchar *label_text;
};
static void quit() {
	gtk_main_quit();
}
gboolean key_press_cb (GtkWidget *widget, GdkEventKey *event) {	
if (event->state == GDK_CONTROL_MASK) {

	if (gdk_keyval_to_lower(event->keyval) == GDK_T) {
	tab_new();
		return TRUE;
	}
	/*
	if (gdk_keyval_to_lower(event->keyval) == GDK_l) {
		gtk_widget_grab_focus(GTK_WIDGET(sb.bar));
		return TRUE;
	}	
	if (gdk_keyval_to_lower(event->keyval) == GDK_j) {
		go_back_cb(NULL, NULL);

		return TRUE;
	}	
	if (gdk_keyval_to_lower(event->keyval) == GDK_k) {
		go_forward_cb(NULL, NULL);
		return TRUE;
	}	
	if (gdk_keyval_to_lower(event->keyval) == GDK_bracketright) {
		
		webkit_web_view_set_zoom_level(sb.view, (webkit_web_view_get_zoom_level(sb.view) + .05));
		return TRUE;
	}
		if (gdk_keyval_to_lower(event->keyval) == GDK_bracketleft) {
		
		webkit_web_view_set_zoom_level(sb.view, (webkit_web_view_get_zoom_level(sb.view) - .05));
		return TRUE;
	}
	else {
		return FALSE;
	}
}

	if (gtk_widget_has_focus(sb.bar) && gdk_keyval_to_lower(event->keyval) == GDK_Escape) {
		gtk_widget_grab_focus(GTK_WIDGET(sb.view));
		return TRUE;
	}*/}
	return FALSE;
}
static void tab_close() {
	
	
	gint page = gtk_notebook_get_current_page(GTK_NOTEBOOK(mt.notebook));
		
	struct term *t;
	t = get_page_term(NULL, page);
	
	gtk_widget_hide(t->vte);
	gtk_notebook_remove_page(GTK_NOTEBOOK(mt.notebook), page);
	g_free(t);
	if (gtk_notebook_get_n_pages(GTK_NOTEBOOK(mt.notebook)) == 0) { quit(); }


}

static void tab_new() {
	
	struct term *t;
	t = g_new0(struct term, 1);
	t->label = gtk_label_new("terminal");
	t->vte = vte_terminal_new();
	vte_terminal_fork_command(VTE_TERMINAL(t->vte), NULL, NULL, NULL, NULL, FALSE, FALSE, FALSE);
	int index = gtk_notebook_append_page(GTK_NOTEBOOK(mt.notebook), t->vte, t->label);
	printf("%d \n", index);
	//sakura_set_page_term(NULL, index, t);
	
	g_object_set_qdata_full(G_OBJECT(gtk_notebook_get_nth_page((GtkNotebook*)mt.notebook, index)), term_data_id, t, NULL);
	g_signal_connect(t->vte, "child-exited", G_CALLBACK(tab_close), NULL);
	gtk_notebook_set_current_page(GTK_NOTEBOOK(mt.notebook), index);
	gtk_widget_grab_focus(t->vte);
	
}

int main (int argc, char* argv[]) {
    gtk_init (&argc, &argv);
    term_data_id = g_quark_from_static_string("mt");
    mt.notebook = gtk_notebook_new();
    mt.win = gtk_window_new (GTK_WINDOW_TOPLEVEL);
    g_signal_connect (G_OBJECT (mt.win), "destroy", G_CALLBACK (quit), NULL);    
    g_signal_connect(mt.win, "key-press-event", G_CALLBACK(key_press_cb), NULL); 
    tab_new();
    tab_new();
    gtk_container_add (GTK_CONTAINER(mt.win), mt.notebook);
    gtk_window_set_default_size(GTK_WINDOW(mt.win), 800, 800);
    gtk_widget_show_all(mt.win);	
    
  gtk_main();  
};