Size: a a a

2020 July 21

E

Earl Sweetshirt in Linux Чат
Vadim "Oxyd" Priluzkiy
Мне саму команду накладывания диффов.
не patch?
источник

u

user in Linux Чат
источник

k

k4leg in Linux Чат
Earl Sweetshirt
не patch?
Создание патча: diff -Naurp0 a b > changes.patch
Применение патча: patch -Np1 path_to_patch (вроде так)
источник

u

user in Linux Чат
patch patch to patch звучит хайпово
источник

VP

Vadim "Oxyd&quo... in Linux Чат
user
Как понять накладывания? diff -u hello.c hello_new.c > hello.patch
Есть у меня диффы в таком формате:
From 53e56c751b3f2be4154760788850c51dbffc0add Mon Sep 17 00:00:00 2001 
From: Arnas Udovicius <zordsdavini@gmail.com>
Date: Tue, 26 Nov 2019 16:16:15 +0200
Subject: [PATCH] Read colors from Xresources
---
config.def.h | 14 +++++++++--
slock.c      | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++
util.h       |  3 +++
3 files changed, 83 insertions(+), 2 deletions(-)
diff --git a/config.def.h b/config.def.h
index 6288856..bfc1ba0 100644
--- a/config.def.h
+++ b/config.def.h
@@ -3,11 +3,21 @@ static const char *user  = "nobody";
static const char *group = "nogroup";
static const char *colorname[NUMCOLS] = {
-       [INIT] =   "black",     /* after initialization */
-       [INPUT] =  "#005577",   /* during input */
+       [INIT] = "black",       /* after initialization */
+       [INPUT] = "#005577",    /* during input */
       [FAILED] = "#CC3333",   /* wrong password */
       [CAPS] = "red",         /* CapsLock on */
};
+/*
+ * Xresources preferences to load at startup
+ */
+ResourcePref resources[] = {
+               { "color0",       STRING,  &colorname[INIT] },
+               { "color4",       STRING,  &colorname[INPUT] },
+               { "color1",       STRING,  &colorname[FAILED] },
+               { "color3",       STRING,  &colorname[CAPS] },
+};
+
/* treat a cleared input like a wrong password (color) */
static const int failonclear = 1;
diff --git a/slock.c b/slock.c
index 5f4fb7a..2395547 100644
--- a/slock.c
+++ b/slock.c
@@ -6,6 +6,7 @@
#include <ctype.h>
#include <errno.h>
+#include <math.h>
#include <grp.h>
#include <pwd.h>
#include <stdarg.h>
@@ -19,6 +20,7 @@
#include <X11/Xlib.h>
#include <X11/Xutil.h>
#include <X11/XKBlib.h>
+#include <X11/Xresource.h>
#include "arg.h"
#include "util.h"
@@ -46,6 +48,19 @@ struct xrandr {
       int errbase;
};
+/* Xresources preferences */
+enum resource_type {
+       STRING = 0,
+       INTEGER = 1,
+       FLOAT = 2
+};
+
+typedef struct {
+       char *name;
+       enum resource_type type;
+       void *dst;
+} ResourcePref;
+
#include "config.h"
static void
@@ -306,6 +321,57 @@ lockscreen(Display *dpy, struct xrandr *rr, int screen)
       return NULL;
}
+int
+resource_load(XrmDatabase db, char *name, enum resource_type rtype, void *dst)
+{
+       char **sdst = dst;
+       int *idst = dst;
+       float *fdst = dst;
+
+       char fullname[256];
+       char fullclass[256];
+       char *type;
+       XrmValue ret;
+
+       snprintf(fullname, sizeof(fullname), "%s.%s", "slock", name);
+       snprintf(fullclass, sizeof(fullclass), "%s.%s", "Slock", name);
+       fullname[sizeof(fullname) - 1] = fullclass[sizeof(fullclass) - 1] = '\0';
+
+       XrmGetResource(db, fullname, fullclass, &type, &ret);
+       if (ret.addr == NULL || strncmp("String", type, 64))
+               return 1;
+
+       switch (rtype) {
+       case STRING:
+               *sdst = ret.addr;
+               break;
+       case INTEGER:
+               *idst = strtoul(ret.addr, NULL, 10);
+               break;
+       case FLOAT:
+               *fdst = strtof(ret.addr, NULL);
+               break;
+       }
+       return 0;
+}
+
+void
+config_init(Display *dpy)
+{
+       char *resm;
+       XrmDatabase db;
+       ResourcePref *p;
+
+       XrmInitialize();
+       resm = XResourceManagerString(dpy);
+       if (!resm)
+               return;
+
+       db = XrmGetStringDatabase(resm);
+       for (p = resources; p < resources + LEN(resources); p++)
+               resource_load(db, p->name, p->type, p->dst);
+}
+
static void
usage(void)
{
@@ -364,6 +430,8 @@ main(int argc, char **argv) {
       if (setuid(duid) < 0)
               die("slock: setuid: %s\n", strerror(errno));
+       config_init(dpy);
+
       /* check for Xrandr support */
       rr.active = XRRQueryExtension(dpy, &rr.evbase, &rr.errbase);
diff --git a/util.h b/util.h
index 6f748b8..148dbc1 100644
источник

VP

Vadim "Oxyd&quo... in Linux Чат
user
Как понять накладывания? diff -u hello.c hello_new.c > hello.patch

--- a/util.h
+++ b/util.h
@@ -1,2 +1,5 @@
+/* macros */
+#define LEN(a)                 (sizeof(a) / sizeof(a)[0])
+
#undef explicit_bzero
void explicit_bzero(void *, size_t);
--
2.24.0
From ca087d5b0e8cd4ac596c161dbf569640c7754b46 Mon Sep 17 00:00:00 2001
From: Klemens Nanni <kl3@posteo.org>
Date: Sat, 7 Jan 2017 02:18:09 +0100
Subject: [PATCH] Update 'mediakeys' patch to 20170111
---
slock.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/slock.c b/slock.c
index ac26cc8..4d81ca6 100644
--- a/slock.c
+++ b/slock.c
@@ -186,7 +186,7 @@ readpw(Display *dpy, struct xrandr *rr, struct lock **locks, int nscreens,
                       case XF86XK_AudioStop:
                       case XF86XK_AudioPrev:
                       case XF86XK_AudioNext:
-                               XSendEvent(dpy, locks[0]->root, True, KeyPressMask, &ev);
+                               XSendEvent(dpy, DefaultRootWindow(dpy), True, KeyPressMask, &ev);
                               break;
                       case XK_Return:
                               passwd[len] = '\0';
--
2.11.0

Мне их нужно накатить на имеющиеся исходники.
источник

ЯН

Ярослав Нестеров... in Linux Чат
ABRAHAM8080
Скок Стоит примерно
€400
источник

A

ABRAHAM8080 in Linux Чат
Для китайцев дороговато, но это лучше, чем гугл за 1000
источник

k

k4leg in Linux Чат
Vadim "Oxyd" Priluzkiy

--- a/util.h
+++ b/util.h
@@ -1,2 +1,5 @@
+/* macros */
+#define LEN(a)                 (sizeof(a) / sizeof(a)[0])
+
#undef explicit_bzero
void explicit_bzero(void *, size_t);
--
2.24.0
From ca087d5b0e8cd4ac596c161dbf569640c7754b46 Mon Sep 17 00:00:00 2001
From: Klemens Nanni <kl3@posteo.org>
Date: Sat, 7 Jan 2017 02:18:09 +0100
Subject: [PATCH] Update 'mediakeys' patch to 20170111
---
slock.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/slock.c b/slock.c
index ac26cc8..4d81ca6 100644
--- a/slock.c
+++ b/slock.c
@@ -186,7 +186,7 @@ readpw(Display *dpy, struct xrandr *rr, struct lock **locks, int nscreens,
                       case XF86XK_AudioStop:
                       case XF86XK_AudioPrev:
                       case XF86XK_AudioNext:
-                               XSendEvent(dpy, locks[0]->root, True, KeyPressMask, &ev);
+                               XSendEvent(dpy, DefaultRootWindow(dpy), True, KeyPressMask, &ev);
                               break;
                       case XK_Return:
                               passwd[len] = '\0';
--
2.11.0

Мне их нужно накатить на имеющиеся исходники.
В директории, где корневой каталог для патча, указываешь предыдущую команду: patch -Np1 path_to_patch.
источник

ЯН

Ярослав Нестеров... in Linux Чат
ABRAHAM8080
Для китайцев дороговато, но это лучше, чем гугл за 1000
топ китаец, прошу заметить
источник

VP

Vadim "Oxyd&quo... in Linux Чат
k4leg
В директории, где корневой каталог для патча, указываешь предыдущую команду: patch -Np1 path_to_patch.
Ага. Ща добавлю в PKGBUILD и буду пробовать со всем этим безобразием взлететь.
источник

u

user in Linux Чат
Vadim "Oxyd" Priluzkiy
Ага. Ща добавлю в PKGBUILD и буду пробовать со всем этим безобразием взлететь.
о, suckless патчим)
источник

u

user in Linux Чат
я вообще на пофиг все в директории делаю, в обход пакетного менеджера
источник

u

user in Linux Чат
т.к. у меня там много патчей и исходники отличаются и лень ебилд писать
источник

k

k4leg in Linux Чат
Vadim "Oxyd" Priluzkiy

--- a/util.h
+++ b/util.h
@@ -1,2 +1,5 @@
+/* macros */
+#define LEN(a)                 (sizeof(a) / sizeof(a)[0])
+
#undef explicit_bzero
void explicit_bzero(void *, size_t);
--
2.24.0
From ca087d5b0e8cd4ac596c161dbf569640c7754b46 Mon Sep 17 00:00:00 2001
From: Klemens Nanni <kl3@posteo.org>
Date: Sat, 7 Jan 2017 02:18:09 +0100
Subject: [PATCH] Update 'mediakeys' patch to 20170111
---
slock.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/slock.c b/slock.c
index ac26cc8..4d81ca6 100644
--- a/slock.c
+++ b/slock.c
@@ -186,7 +186,7 @@ readpw(Display *dpy, struct xrandr *rr, struct lock **locks, int nscreens,
                       case XF86XK_AudioStop:
                       case XF86XK_AudioPrev:
                       case XF86XK_AudioNext:
-                               XSendEvent(dpy, locks[0]->root, True, KeyPressMask, &ev);
+                               XSendEvent(dpy, DefaultRootWindow(dpy), True, KeyPressMask, &ev);
                               break;
                       case XK_Return:
                               passwd[len] = '\0';
--
2.11.0

Мне их нужно накатить на имеющиеся исходники.
Немного ошибся: нужен ещё флаг i:
patch -Np1 -i path_to_patch
источник

E

Earl Sweetshirt in Linux Чат
источник

E

Earl Sweetshirt in Linux Чат
тем кто еще не видел
источник

AP

Anton Pavlenko in Linux Чат
источник

⛧ ᛡᚢᚾᛁ Connor41 ᚳᚩᛞ ... in Linux Чат
заебибо
источник

E

Earl Sweetshirt in Linux Чат
вот поэтому и не делаю, сел и збс
источник