mirror of
https://git.pwmt.org/pwmt/zathura.git
synced 2025-01-01 10:36:00 +01:00
Add synctex-editor-command setting
Also, turn on SyncTeX backward synchronization per default and remove -s option. Signed-off-by: Sebastian Ramacher <sebastian+dev@ramacher.at>
This commit is contained in:
parent
0db370274a
commit
eabd883e62
9 changed files with 36 additions and 66 deletions
4
config.c
4
config.c
|
@ -221,8 +221,10 @@ config_load_default(zathura_t* zathura)
|
||||||
girara_setting_add(gsession, "window-title-page", &bool_value, BOOLEAN, false, _("Display the page number in the window title"), NULL, NULL);
|
girara_setting_add(gsession, "window-title-page", &bool_value, BOOLEAN, false, _("Display the page number in the window title"), NULL, NULL);
|
||||||
bool_value = false;
|
bool_value = false;
|
||||||
girara_setting_add(gsession, "statusbar-basename", &bool_value, BOOLEAN, false, _("Use basename of the file in the statusbar"), NULL, NULL);
|
girara_setting_add(gsession, "statusbar-basename", &bool_value, BOOLEAN, false, _("Use basename of the file in the statusbar"), NULL, NULL);
|
||||||
bool_value = false;
|
bool_value = true;
|
||||||
girara_setting_add(gsession, "synctex", &bool_value, BOOLEAN, false, _("Enable synctex support"), NULL, NULL);
|
girara_setting_add(gsession, "synctex", &bool_value, BOOLEAN, false, _("Enable synctex support"), NULL, NULL);
|
||||||
|
string_value = "";
|
||||||
|
girara_setting_add(gsession, "synctex-editor-command", string_value, STRING, false, _("Synctex editor command"), NULL, NULL);
|
||||||
bool_value = true;
|
bool_value = true;
|
||||||
girara_setting_add(gsession, "dbus-service", &bool_value, BOOLEAN, false, _("Enable D-Bus service"), NULL, NULL);
|
girara_setting_add(gsession, "dbus-service", &bool_value, BOOLEAN, false, _("Enable D-Bus service"), NULL, NULL);
|
||||||
string_value = "primary";
|
string_value = "primary";
|
||||||
|
|
|
@ -23,11 +23,8 @@
|
||||||
-l, --debug=level
|
-l, --debug=level
|
||||||
Set log debug level (debug, info, warning, error)
|
Set log debug level (debug, info, warning, error)
|
||||||
|
|
||||||
-s, --synctex
|
|
||||||
Enables synctex support
|
|
||||||
|
|
||||||
-x, --synctex-editor-command=command
|
-x, --synctex-editor-command=command
|
||||||
Set the synctex editor command
|
Set the synctex editor command. Overrides the synctex-editor-command setting.
|
||||||
|
|
||||||
--synctex-forward=input
|
--synctex-forward=input
|
||||||
Jump to the given position. The switch expects the same format as specified for synctex's view -i.
|
Jump to the given position. The switch expects the same format as specified for synctex's view -i.
|
||||||
|
|
|
@ -880,9 +880,23 @@ middle mouse button, or the Shift-Insert key combination.
|
||||||
* Value type: String
|
* Value type: String
|
||||||
* Default value: primary
|
* Default value: primary
|
||||||
|
|
||||||
|
synctex
|
||||||
|
^^^^^^^
|
||||||
|
En/Disables SyncTeX backward synchronization support.
|
||||||
|
|
||||||
|
* Value type: Boolean
|
||||||
|
* Default value: true
|
||||||
|
|
||||||
|
synctex-editor-command
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
Defines the command executed for SyncTeX backward synchronization.
|
||||||
|
|
||||||
|
* Value type: String
|
||||||
|
* Default value:
|
||||||
|
|
||||||
syntex-dbus-service
|
syntex-dbus-service
|
||||||
^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^
|
||||||
En/Disables the D-Bus service required for synctex forward synchronization.
|
En/Disables the D-Bus service required for SyncTeX forward synchronization.
|
||||||
|
|
||||||
* Value type: Boolean
|
* Value type: Boolean
|
||||||
* Default value: true
|
* Default value: true
|
||||||
|
|
9
main.c
9
main.c
|
@ -5,6 +5,7 @@
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <girara/utils.h>
|
#include <girara/utils.h>
|
||||||
|
#include <girara/settings.h>
|
||||||
#include <glib/gi18n.h>
|
#include <glib/gi18n.h>
|
||||||
#include <glib/gstdio.h>
|
#include <glib/gstdio.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
@ -48,7 +49,6 @@ main(int argc, char* argv[])
|
||||||
gchar* mode = NULL;
|
gchar* mode = NULL;
|
||||||
bool forkback = false;
|
bool forkback = false;
|
||||||
bool print_version = false;
|
bool print_version = false;
|
||||||
bool synctex = false;
|
|
||||||
int page_number = ZATHURA_PAGE_NUMBER_UNSPECIFIED;
|
int page_number = ZATHURA_PAGE_NUMBER_UNSPECIFIED;
|
||||||
int synctex_pid = -1;
|
int synctex_pid = -1;
|
||||||
Window embed = 0;
|
Window embed = 0;
|
||||||
|
@ -63,7 +63,6 @@ main(int argc, char* argv[])
|
||||||
{ "page", 'P', 0, G_OPTION_ARG_INT, &page_number, _("Page number to go to"), "number" },
|
{ "page", 'P', 0, G_OPTION_ARG_INT, &page_number, _("Page number to go to"), "number" },
|
||||||
{ "debug", 'l', 0, G_OPTION_ARG_STRING, &loglevel, _("Log level (debug, info, warning, error)"), "level" },
|
{ "debug", 'l', 0, G_OPTION_ARG_STRING, &loglevel, _("Log level (debug, info, warning, error)"), "level" },
|
||||||
{ "version", 'v', 0, G_OPTION_ARG_NONE, &print_version, _("Print version information"), NULL },
|
{ "version", 'v', 0, G_OPTION_ARG_NONE, &print_version, _("Print version information"), NULL },
|
||||||
{ "synctex", 's', 0, G_OPTION_ARG_NONE, &synctex, _("Enable synctex support"), NULL },
|
|
||||||
{ "synctex-editor-command", 'x', 0, G_OPTION_ARG_STRING, &synctex_editor, _("Synctex editor (forwarded to the synctex command)"), "cmd" },
|
{ "synctex-editor-command", 'x', 0, G_OPTION_ARG_STRING, &synctex_editor, _("Synctex editor (forwarded to the synctex command)"), "cmd" },
|
||||||
{ "synctex-forward", '\0', 0, G_OPTION_ARG_STRING, &synctex_fwd, _("Move to given synctex position"), "position" },
|
{ "synctex-forward", '\0', 0, G_OPTION_ARG_STRING, &synctex_fwd, _("Move to given synctex position"), "position" },
|
||||||
{ "synctex-pid", '\0', 0, G_OPTION_ARG_INT, &synctex_pid, _("Highlight given position in the given process"), "pid" },
|
{ "synctex-pid", '\0', 0, G_OPTION_ARG_INT, &synctex_pid, _("Highlight given position in the given process"), "pid" },
|
||||||
|
@ -158,7 +157,6 @@ main(int argc, char* argv[])
|
||||||
zathura_set_config_dir(zathura, config_dir);
|
zathura_set_config_dir(zathura, config_dir);
|
||||||
zathura_set_data_dir(zathura, data_dir);
|
zathura_set_data_dir(zathura, data_dir);
|
||||||
zathura_set_plugin_dir(zathura, plugin_path);
|
zathura_set_plugin_dir(zathura, plugin_path);
|
||||||
zathura_set_synctex_editor_command(zathura, synctex_editor);
|
|
||||||
zathura_set_argv(zathura, argv);
|
zathura_set_argv(zathura, argv);
|
||||||
|
|
||||||
/* Init zathura */
|
/* Init zathura */
|
||||||
|
@ -168,8 +166,9 @@ main(int argc, char* argv[])
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Enable/Disable synctex support */
|
if (synctex_editor != NULL) {
|
||||||
zathura_set_synctex(zathura, synctex);
|
girara_setting_set(zathura->ui.session, "synctex-editor-command", synctex_editor);
|
||||||
|
}
|
||||||
|
|
||||||
/* Print version */
|
/* Print version */
|
||||||
if (print_version == true) {
|
if (print_version == true) {
|
||||||
|
|
|
@ -721,10 +721,15 @@ cb_zathura_page_widget_button_release_event(GtkWidget* widget, GdkEventButton* b
|
||||||
|
|
||||||
if (synctex == true && button->state & GDK_CONTROL_MASK) {
|
if (synctex == true && button->state & GDK_CONTROL_MASK) {
|
||||||
/* synctex backwards sync */
|
/* synctex backwards sync */
|
||||||
|
char* editor = NULL;
|
||||||
|
girara_setting_get(priv->zathura->ui.session, "synctex-editor-command", &editor);
|
||||||
|
if (editor != NULL && *editor != '\0') {
|
||||||
double scale = zathura_document_get_scale(document);
|
double scale = zathura_document_get_scale(document);
|
||||||
int x = button->x / scale, y = button->y / scale;
|
int x = button->x / scale, y = button->y / scale;
|
||||||
|
|
||||||
synctex_edit(priv->zathura, priv->page, x, y);
|
synctex_edit(editor, priv->page, x, y);
|
||||||
|
}
|
||||||
|
g_free(editor);
|
||||||
} else {
|
} else {
|
||||||
zathura_rectangle_t tmp = priv->mouse.selection;
|
zathura_rectangle_t tmp = priv->mouse.selection;
|
||||||
|
|
||||||
|
|
|
@ -2,18 +2,18 @@
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
#include <girara/utils.h>
|
#include <girara/utils.h>
|
||||||
|
#include <synctex/synctex_parser.h>
|
||||||
|
|
||||||
#include "synctex.h"
|
#include "synctex.h"
|
||||||
#include "zathura.h"
|
#include "zathura.h"
|
||||||
#include "page.h"
|
#include "page.h"
|
||||||
#include "document.h"
|
#include "document.h"
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include "synctex/synctex_parser.h"
|
|
||||||
|
|
||||||
void
|
void
|
||||||
synctex_edit(zathura_t* zathura, zathura_page_t* page, int x, int y)
|
synctex_edit(const char* editor, zathura_page_t* page, int x, int y)
|
||||||
{
|
{
|
||||||
if (zathura == NULL || page == NULL || zathura->synctex.editor == NULL) {
|
if (editor == NULL || page == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ synctex_edit(zathura_t* zathura, zathura_page_t* page, int x, int y)
|
||||||
|
|
||||||
gchar** argv = NULL;
|
gchar** argv = NULL;
|
||||||
gint argc = 0;
|
gint argc = 0;
|
||||||
if (g_shell_parse_argv(zathura->synctex.editor, &argc, &argv, NULL) == TRUE) {
|
if (g_shell_parse_argv(editor, &argc, &argv, NULL) == TRUE) {
|
||||||
for (gint i = 0; i != argc; ++i) {
|
for (gint i = 0; i != argc; ++i) {
|
||||||
char* temp = girara_replace_substring(argv[i], "%{line}", linestr);
|
char* temp = girara_replace_substring(argv[i], "%{line}", linestr);
|
||||||
g_free(argv[i]);
|
g_free(argv[i]);
|
||||||
|
|
|
@ -10,7 +10,7 @@ typedef struct synctex_page_rect_s {
|
||||||
zathura_rectangle_t rect;
|
zathura_rectangle_t rect;
|
||||||
} synctex_page_rect_t;
|
} synctex_page_rect_t;
|
||||||
|
|
||||||
void synctex_edit(zathura_t* zathura, zathura_page_t* page, int x, int y);
|
void synctex_edit(const char* editor, zathura_page_t* page, int x, int y);
|
||||||
girara_list_t* synctex_rectangles_from_position(const char* filename,
|
girara_list_t* synctex_rectangles_from_position(const char* filename,
|
||||||
const char* input_file, int line, int column, unsigned int* page,
|
const char* input_file, int line, int column, unsigned int* page,
|
||||||
girara_list_t** secondary_rects);
|
girara_list_t** secondary_rects);
|
||||||
|
|
25
zathura.c
25
zathura.c
|
@ -421,31 +421,6 @@ zathura_set_plugin_dir(zathura_t* zathura, const char* dir)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
zathura_set_synctex_editor_command(zathura_t* zathura, const char* command)
|
|
||||||
{
|
|
||||||
g_return_if_fail(zathura != NULL);
|
|
||||||
|
|
||||||
if (zathura->synctex.editor != NULL) {
|
|
||||||
g_free(zathura->synctex.editor);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (command != NULL) {
|
|
||||||
zathura->synctex.editor = g_strdup(command);
|
|
||||||
} else {
|
|
||||||
zathura->synctex.editor = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
zathura_set_synctex(zathura_t* zathura, bool value)
|
|
||||||
{
|
|
||||||
g_return_if_fail(zathura != NULL);
|
|
||||||
g_return_if_fail(zathura->ui.session != NULL);
|
|
||||||
|
|
||||||
girara_setting_set(zathura->ui.session, "synctex", &value);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
zathura_set_argv(zathura_t* zathura, char** argv)
|
zathura_set_argv(zathura_t* zathura, char** argv)
|
||||||
{
|
{
|
||||||
|
|
22
zathura.h
22
zathura.h
|
@ -129,12 +129,6 @@ struct zathura_s
|
||||||
gchar* data_dir; /**< Path to the data directory */
|
gchar* data_dir; /**< Path to the data directory */
|
||||||
} config;
|
} config;
|
||||||
|
|
||||||
struct
|
|
||||||
{
|
|
||||||
bool enabled;
|
|
||||||
gchar* editor;
|
|
||||||
} synctex;
|
|
||||||
|
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
GtkPrintSettings* settings; /**< Print settings */
|
GtkPrintSettings* settings; /**< Print settings */
|
||||||
|
@ -263,22 +257,6 @@ void zathura_set_data_dir(zathura_t* zathura, const char* dir);
|
||||||
*/
|
*/
|
||||||
void zathura_set_plugin_dir(zathura_t* zathura, const char* dir);
|
void zathura_set_plugin_dir(zathura_t* zathura, const char* dir);
|
||||||
|
|
||||||
/**
|
|
||||||
* Enables synctex support and sets the synctex editor command
|
|
||||||
*
|
|
||||||
* @param zathura The zathura session
|
|
||||||
* @param command Synctex editor command
|
|
||||||
*/
|
|
||||||
void zathura_set_synctex_editor_command(zathura_t* zathura, const char* command);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* En/Disable zathuras synctex support
|
|
||||||
*
|
|
||||||
* @param zathura The zathura session
|
|
||||||
* @param value The value
|
|
||||||
*/
|
|
||||||
void zathura_set_synctex(zathura_t* zathura, bool value);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the program parameters
|
* Sets the program parameters
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue