Compare commits
No commits in common. "90fef3b4682a6e31b1cf9e980b033bb5725ef7fe" and "2896ff4e52241c7cb3ee24f91527c42ef0bfbecb" have entirely different histories.
90fef3b468
...
2896ff4e52
47
config.h
47
config.h
|
@ -1,42 +1,32 @@
|
||||||
#include <gdk/gdkkeysyms.h>
|
#include <gdk/gdkkeysyms.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
// Key user config
|
/* See more:
|
||||||
|
* https://webkitgtk.org/reference/webkit2gtk/stable/class.Settings.html
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#define WEBKIT_DEFAULT_SETTINGS \
|
||||||
|
"enable-back-forward-navigation-gestures", true, "enable-developer-extras", true, \
|
||||||
|
"enable-smooth-scrolling", false, \
|
||||||
|
"default-charset", "utf-8"
|
||||||
|
|
||||||
|
#define GTK "gtk-application-prefer-dark-theme", false, "gtk-enable-animations", false
|
||||||
|
#define ROSE_HOMEPAGE false
|
||||||
|
#define SEARCH "https://lite.duckduckgo.com/html/?q=%s" // "https://search.nunosempere.com/search?q=%s"
|
||||||
|
#define HOME ROSE_HOMEPAGE ? "file:///home/loki/Documents/core/software/fresh/C/rose-browser/rosenrot/user-scripts/ubuntu-20.04/rose-images/rose-homepage.png" : "https://search.nunosempere.com/"
|
||||||
|
// #define HOME ROSE_HOMEPAGE ? "file:///home/loki/Documents/core/software/fresh/C/rose-browser/rosenrot/user-scripts/ubuntu-20.04/rose-images/rose-homepage.png" : "https://search.nunosempere.com/"
|
||||||
|
#define CACHE_DIR "/home/loki/.cache/rose"
|
||||||
|
|
||||||
#define WIDTH 1920 // 960 for half-width, 1920 for full width
|
#define WIDTH 1920 // 960 for half-width, 1920 for full width
|
||||||
#define HEIGHT 1080
|
#define HEIGHT 1080
|
||||||
#define BAR_SIZE 1000
|
#define SEARCH_BAR_SIZE 1000
|
||||||
|
#define KEY(x) GDK_KEY_##x
|
||||||
// More user config
|
|
||||||
#define ZOOM 1.6 /* Starting zoom level.*/
|
#define ZOOM 1.6 /* Starting zoom level.*/
|
||||||
#define ZOOM_VAL .1 /* Zooming value in zoomin/zoomout functions */
|
#define ZOOM_VAL .1 /* Zooming value in zoomin/zoomout functions */
|
||||||
#define BG_COLOR "#FEFEFE" /* "FEFEFE", "#1E1E2E" */
|
#define BG_COLOR "#FEFEFE" /* "FEFEFE", "#1E1E2E" */
|
||||||
#define DEBUG false
|
#define DEBUG false
|
||||||
#define MAX_NUM_TABS 8 // set to 0 or false if you want unlimited tabs, or look at the relevant rose.c code.
|
#define MAX_NUM_TABS 8 // set to 0 or false if you want unlimited tabs, or look at the relevant rose.c code.
|
||||||
#define ROSE_HOMEPAGE false
|
|
||||||
#define SEARCH "https://lite.duckduckgo.com/html/?q=%s" // "https://search.nunosempere.com/search?q=%s"
|
|
||||||
#define HOME ROSE_HOMEPAGE ? "file:///home/loki/Documents/core/software/fresh/C/rose-browser/rosenrot/user-scripts/ubuntu-20.04/rose-images/rose-homepage.png" : "https://search.nunosempere.com/"
|
|
||||||
|
|
||||||
// Webkit settings
|
|
||||||
// See: https://webkitgtk.org/reference/webkit2gtk/stable/class.Settings.html
|
|
||||||
#define WEBKIT_DEFAULT_SETTINGS \
|
|
||||||
"enable-back-forward-navigation-gestures", true, "enable-developer-extras", true, \
|
|
||||||
"enable-smooth-scrolling", false, \
|
|
||||||
"default-charset", "utf-8"
|
|
||||||
/* CACHE */
|
|
||||||
#define CACHE_DIR "/home/loki/.cache/rose"
|
|
||||||
#define CACHE \
|
|
||||||
"base-cache-directory", CACHE_DIR, "base-data-directory", CACHE_DIR, \
|
|
||||||
"disk-cache-directory", CACHE_DIR, "dom-cache-directory", CACHE_DIR, \
|
|
||||||
"hsts-cache-directory", CACHE_DIR, "indexeddb-directory", CACHE_DIR, \
|
|
||||||
"itp-directory", CACHE_DIR, "local-storage-directory", CACHE_DIR, \
|
|
||||||
"offline-application-cache-directory", CACHE_DIR, \
|
|
||||||
"service-worker-registrations-directory", CACHE_DIR
|
|
||||||
|
|
||||||
// GTK
|
|
||||||
#define GTK "gtk-application-prefer-dark-theme", false, "gtk-enable-animations", false
|
|
||||||
#define KEY(x) GDK_KEY_##x
|
|
||||||
|
|
||||||
// Shortcuts
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
goback,
|
goback,
|
||||||
goforward,
|
goforward,
|
||||||
|
@ -113,4 +103,3 @@ static struct {
|
||||||
{ CTRL, KEY(p), prettify }
|
{ CTRL, KEY(p), prettify }
|
||||||
};
|
};
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#define READABILITY_N 88067 + 1000
|
#define READABILITY_N 88023 + 1000
|
||||||
|
|
||||||
void read_readability_js(char* string)
|
void read_readability_js(char* string)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#ifndef READABILITY
|
#ifndef READABILITY
|
||||||
#define READABILITY
|
#define READABILITY
|
||||||
|
|
||||||
#define READABILITY_N 88067 + 1000
|
#define READABILITY_N 88023 + 1000
|
||||||
|
|
||||||
void read_readability_js(char* string);
|
void read_readability_js(char* string);
|
||||||
|
|
||||||
|
|
|
@ -2615,13 +2615,12 @@ var style_sheet_simple = `
|
||||||
<style type="text/css">
|
<style type="text/css">
|
||||||
|
|
||||||
body {
|
body {
|
||||||
padding: 40px 200px 40px 200px !important;
|
padding: 40px 200px 40px 200px;
|
||||||
font-size: 18px;
|
font-size: 18px;
|
||||||
font: 18px/1.5 Roboto;
|
font: 18px/1.5 Roboto;
|
||||||
line-height: 1.6;
|
line-height: 1.6;
|
||||||
background-color: #FEFEFE !important;
|
background-color: #FEFEFE !important;
|
||||||
color: #444 !important;
|
color: #444 !important;
|
||||||
max-width: 99% !important;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#readOverlay {
|
#readOverlay {
|
||||||
|
|
98
rose.c
98
rose.c
|
@ -1,30 +1,23 @@
|
||||||
#include <stdlib.h>
|
#include <stdbool.h>
|
||||||
|
#include <stdlib.h> // necessary for free, malloc.
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <webkit2/webkit2.h>
|
#include <webkit2/webkit2.h>
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include "plugins/libre_redirect/libre_redirect.h"
|
#include "plugins/libre_redirect/libre_redirect.h"
|
||||||
#include "plugins/readability/readability.h"
|
#include "plugins/readability/readability.h"
|
||||||
#include "plugins/shortcuts/shortcuts.h"
|
#include "plugins/shortcuts/shortcuts.h"
|
||||||
#include "plugins/style/style.h"
|
#include "plugins/style/style.h"
|
||||||
|
|
||||||
/* Global declarations */
|
|
||||||
static GtkNotebook* notebook;
|
|
||||||
static GtkWindow* window;
|
|
||||||
|
|
||||||
// Search, find and url bar
|
|
||||||
static GtkHeaderBar* bar;
|
|
||||||
static GtkEntry* bar_line; // widget
|
|
||||||
static GtkEntryBuffer* bar_line_text;
|
|
||||||
static int bar_entry_mode;
|
|
||||||
enum { _SEARCH, _FIND, _HIDDEN };
|
|
||||||
|
|
||||||
/* Plugins */
|
|
||||||
// #include "plugins/stand_in/stand_in.h"
|
// #include "plugins/stand_in/stand_in.h"
|
||||||
|
|
||||||
int LIBRE_REDIRECT_ENABLED = true;
|
int LIBRE_REDIRECT_ENABLED = true;
|
||||||
int READABILITY_ENABLED = true;
|
int READABILITY_ENABLED = true;
|
||||||
int CUSTOM_STYLE_ENABLED = true;
|
int CUSTOM_STYLE_ENABLED = true;
|
||||||
int CUSTOM_USER_AGENT = false;
|
int CUSTOM_USER_AGENT = false;
|
||||||
int NUM_TABS = 0;
|
int NUM_TABS = 0;
|
||||||
|
|
||||||
// to enable plugins,
|
// to enable plugins,
|
||||||
// 1. Enable them:
|
// 1. Enable them:
|
||||||
// - uncomment their #include statement
|
// - uncomment their #include statement
|
||||||
|
@ -36,6 +29,24 @@ int NUM_TABS = 0;
|
||||||
// - In the make file, include the stand_in.c file and exclude the
|
// - In the make file, include the stand_in.c file and exclude the
|
||||||
// relevant plugin
|
// relevant plugin
|
||||||
|
|
||||||
|
#define CACHE \
|
||||||
|
"base-cache-directory", CACHE_DIR, "base-data-directory", CACHE_DIR, \
|
||||||
|
"disk-cache-directory", CACHE_DIR, "dom-cache-directory", CACHE_DIR, \
|
||||||
|
"hsts-cache-directory", CACHE_DIR, "indexeddb-directory", CACHE_DIR, \
|
||||||
|
"itp-directory", CACHE_DIR, "local-storage-directory", CACHE_DIR, \
|
||||||
|
"offline-application-cache-directory", CACHE_DIR, \
|
||||||
|
"service-worker-registrations-directory", CACHE_DIR
|
||||||
|
|
||||||
|
enum { _SEARCH,
|
||||||
|
_FIND,
|
||||||
|
_HIDDEN };
|
||||||
|
|
||||||
|
static int entry_mode;
|
||||||
|
static GtkWindow* window;
|
||||||
|
static GtkHeaderBar* bar;
|
||||||
|
static GtkEntryBuffer* search_buf;
|
||||||
|
static GtkEntry* search;
|
||||||
|
|
||||||
WebKitWebView* webview_new()
|
WebKitWebView* webview_new()
|
||||||
{
|
{
|
||||||
char* style;
|
char* style;
|
||||||
|
@ -245,24 +256,24 @@ void notebook_append(GtkNotebook* notebook, const char* uri)
|
||||||
|
|
||||||
void show_bar(GtkNotebook* notebook)
|
void show_bar(GtkNotebook* notebook)
|
||||||
{
|
{
|
||||||
if (bar_entry_mode == _SEARCH) {
|
if (entry_mode == _SEARCH) {
|
||||||
const char* url = webkit_web_view_get_uri(notebook_get_webview(notebook));
|
const char* url = webkit_web_view_get_uri(notebook_get_webview(notebook));
|
||||||
gtk_entry_set_placeholder_text(bar_line, "Search");
|
gtk_entry_set_placeholder_text(search, "Search");
|
||||||
gtk_entry_buffer_set_text(bar_line_text, url, strlen(url));
|
gtk_entry_buffer_set_text(search_buf, url, strlen(url));
|
||||||
gtk_widget_show(GTK_WIDGET(bar));
|
gtk_widget_show(GTK_WIDGET(bar));
|
||||||
gtk_window_set_focus(window, GTK_WIDGET(bar_line));
|
gtk_window_set_focus(window, GTK_WIDGET(search));
|
||||||
} else if (bar_entry_mode == _HIDDEN) {
|
} else if (entry_mode == _HIDDEN) {
|
||||||
gtk_widget_hide(GTK_WIDGET(bar));
|
gtk_widget_hide(GTK_WIDGET(bar));
|
||||||
} else {
|
} else {
|
||||||
const char* search_text = webkit_find_controller_get_search_text(
|
const char* search_text = webkit_find_controller_get_search_text(
|
||||||
webkit_web_view_get_find_controller(notebook_get_webview(notebook)));
|
webkit_web_view_get_find_controller(notebook_get_webview(notebook)));
|
||||||
|
|
||||||
if (search_text != NULL)
|
if (search_text != NULL)
|
||||||
gtk_entry_buffer_set_text(bar_line_text, search_text, strlen(search_text));
|
gtk_entry_buffer_set_text(search_buf, search_text, strlen(search_text));
|
||||||
|
|
||||||
gtk_entry_set_placeholder_text(bar_line, "Find");
|
gtk_entry_set_placeholder_text(search, "Find");
|
||||||
gtk_widget_show(GTK_WIDGET(bar));
|
gtk_widget_show(GTK_WIDGET(bar));
|
||||||
gtk_window_set_focus(window, GTK_WIDGET(bar_line));
|
gtk_window_set_focus(window, GTK_WIDGET(search));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -345,12 +356,12 @@ int handle_key(func id, GtkNotebook* notebook)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case show_searchbar:
|
case show_searchbar:
|
||||||
bar_entry_mode = _SEARCH;
|
entry_mode = _SEARCH;
|
||||||
show_bar(notebook);
|
show_bar(notebook);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case show_finder:
|
case show_finder:
|
||||||
bar_entry_mode = _FIND;
|
entry_mode = _FIND;
|
||||||
show_bar(notebook);
|
show_bar(notebook);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -367,12 +378,12 @@ int handle_key(func id, GtkNotebook* notebook)
|
||||||
case new_tab:
|
case new_tab:
|
||||||
notebook_append(notebook, NULL);
|
notebook_append(notebook, NULL);
|
||||||
gtk_notebook_set_show_tabs(notebook, true);
|
gtk_notebook_set_show_tabs(notebook, true);
|
||||||
bar_entry_mode = _SEARCH;
|
entry_mode = _SEARCH;
|
||||||
show_bar(notebook);
|
show_bar(notebook);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case hide_bar:
|
case hide_bar:
|
||||||
bar_entry_mode = _HIDDEN;
|
entry_mode = _HIDDEN;
|
||||||
show_bar(notebook);
|
show_bar(notebook);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -412,13 +423,13 @@ int keypress(void* self, GdkEvent* e, GtkNotebook* notebook)
|
||||||
|
|
||||||
void search_activate(GtkEntry* self, GtkNotebook* notebook)
|
void search_activate(GtkEntry* self, GtkNotebook* notebook)
|
||||||
{
|
{
|
||||||
if (bar_entry_mode == _SEARCH)
|
if (entry_mode == _SEARCH)
|
||||||
load_uri(notebook_get_webview(notebook),
|
load_uri(notebook_get_webview(notebook),
|
||||||
gtk_entry_buffer_get_text(bar_line_text));
|
gtk_entry_buffer_get_text(search_buf));
|
||||||
else if (bar_entry_mode == _FIND)
|
else if (entry_mode == _FIND)
|
||||||
webkit_find_controller_search(
|
webkit_find_controller_search(
|
||||||
webkit_web_view_get_find_controller(notebook_get_webview(notebook)),
|
webkit_web_view_get_find_controller(notebook_get_webview(notebook)),
|
||||||
gtk_entry_buffer_get_text(bar_line_text),
|
gtk_entry_buffer_get_text(search_buf),
|
||||||
WEBKIT_FIND_OPTIONS_CASE_INSENSITIVE | WEBKIT_FIND_OPTIONS_WRAP_AROUND,
|
WEBKIT_FIND_OPTIONS_CASE_INSENSITIVE | WEBKIT_FIND_OPTIONS_WRAP_AROUND,
|
||||||
G_MAXUINT);
|
G_MAXUINT);
|
||||||
|
|
||||||
|
@ -433,11 +444,11 @@ void window_init(GtkNotebook* notebook)
|
||||||
gtk_style_context_add_provider_for_screen(gdk_screen_get_default(),
|
gtk_style_context_add_provider_for_screen(gdk_screen_get_default(),
|
||||||
GTK_STYLE_PROVIDER(css), 800);
|
GTK_STYLE_PROVIDER(css), 800);
|
||||||
gtk_entry_buffer_new("", 0);
|
gtk_entry_buffer_new("", 0);
|
||||||
gtk_entry_set_alignment(bar_line, 0.48);
|
gtk_entry_set_alignment(search, 0.48);
|
||||||
gtk_widget_set_size_request(GTK_WIDGET(bar_line), BAR_SIZE, -1);
|
gtk_widget_set_size_request(GTK_WIDGET(search), SEARCH_BAR_SIZE, -1);
|
||||||
gtk_header_bar_set_custom_title(bar, GTK_WIDGET(bar_line));
|
gtk_header_bar_set_custom_title(bar, GTK_WIDGET(search));
|
||||||
gtk_window_set_titlebar(window, GTK_WIDGET(bar));
|
gtk_window_set_titlebar(window, GTK_WIDGET(bar));
|
||||||
g_signal_connect(bar_line, "activate", G_CALLBACK(search_activate), notebook);
|
g_signal_connect(search, "activate", G_CALLBACK(search_activate), notebook);
|
||||||
g_signal_connect(window, "key-press-event", G_CALLBACK(keypress), notebook);
|
g_signal_connect(window, "key-press-event", G_CALLBACK(keypress), notebook);
|
||||||
g_signal_connect(window, "destroy", G_CALLBACK(exit), notebook);
|
g_signal_connect(window, "destroy", G_CALLBACK(exit), notebook);
|
||||||
}
|
}
|
||||||
|
@ -449,18 +460,15 @@ void notebook_init(GtkNotebook* notebook, const char* uri)
|
||||||
notebook_append(notebook, uri);
|
notebook_append(notebook, uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char** argv)
|
void setup(GtkNotebook* notebook, int argc, char** argv)
|
||||||
{
|
{
|
||||||
// <https://docs.gtk.org/gtk3/func.init.html>
|
// Define GTK entities
|
||||||
gtk_init(NULL, NULL);
|
|
||||||
|
|
||||||
// Define GTK entities. These are declared globally
|
|
||||||
window = GTK_WINDOW(gtk_window_new(0));
|
window = GTK_WINDOW(gtk_window_new(0));
|
||||||
bar = GTK_HEADER_BAR(gtk_header_bar_new());
|
|
||||||
bar_line_text = GTK_ENTRY_BUFFER(gtk_entry_buffer_new("", 0));
|
|
||||||
bar_line = GTK_ENTRY(gtk_entry_new_with_buffer(bar_line_text));
|
|
||||||
gtk_window_set_default_size(window, WIDTH, HEIGHT);
|
|
||||||
notebook = GTK_NOTEBOOK(gtk_notebook_new());
|
notebook = GTK_NOTEBOOK(gtk_notebook_new());
|
||||||
|
bar = GTK_HEADER_BAR(gtk_header_bar_new());
|
||||||
|
search_buf = GTK_ENTRY_BUFFER(gtk_entry_buffer_new("", 0));
|
||||||
|
search = GTK_ENTRY(gtk_entry_new_with_buffer(search_buf));
|
||||||
|
gtk_window_set_default_size(window, WIDTH, HEIGHT);
|
||||||
window_init(notebook);
|
window_init(notebook);
|
||||||
|
|
||||||
// Initialize with first uri
|
// Initialize with first uri
|
||||||
|
@ -480,7 +488,13 @@ int main(int argc, char** argv)
|
||||||
notebook_append(notebook, argv[i]);
|
notebook_append(notebook, argv[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char** argv)
|
||||||
|
{
|
||||||
|
GtkNotebook* notebook = NULL;
|
||||||
|
gtk_init(NULL, NULL);
|
||||||
|
setup(notebook, argc, argv);
|
||||||
gtk_main();
|
gtk_main();
|
||||||
// this point is never reached, since gtk_main(); never exits.
|
// this point is never reached, since gtk_main(); never exits.
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user