aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/libintercept.c26
1 files changed, 3 insertions, 23 deletions
diff --git a/lib/libintercept.c b/lib/libintercept.c
index 8503308..9a18d78 100644
--- a/lib/libintercept.c
+++ b/lib/libintercept.c
@@ -27,20 +27,12 @@ static bool sendall(int sock, const char *buffer, size_t length) {
}
static void try_transmit_invocation(const char *pathname, char *const argv[]) {
- fprintf(stderr, "try_transmit_invocation: %s ...\n", pathname);
-
const char *socketpath = getenv(COMM_SOCKET_ENVVAR);
- if (socketpath == NULL) {
- fprintf(stderr, " socket path not given\n");
- return;
- }
+ if (socketpath == NULL) return;
// The SOCK_CLOEXEC option is technically unnecessary, but let's be careful.
int sock = socket(AF_UNIX, SOCK_STREAM | SOCK_CLOEXEC, 0);
- if (sock < 0) {
- fprintf(stderr, " cannot create socket: %s\n", strerror(errno));
- return;
- }
+ if (sock < 0) return;
struct sockaddr_un addr;
memset(&addr, 0, sizeof addr);
@@ -48,33 +40,21 @@ static void try_transmit_invocation(const char *pathname, char *const argv[]) {
strncpy(addr.sun_path, socketpath, sizeof(addr.sun_path) - 1);
int ret = connect(sock, (const struct sockaddr*)&addr, sizeof addr);
- if (ret < 0) {
- fprintf(stderr, " cannot connect to socket\n");
- return;
- }
+ if (ret < 0) return;
size_t nargs = 0;
while (argv[nargs] != NULL) nargs++;
- bool ok = false;
if (!sendall(sock, (const char*)&nargs, 8)) goto cleanup;
if (!sendall(sock, pathname, strlen(pathname) + 1)) goto cleanup;
for (size_t i = 0; i < nargs; i++) {
if (!sendall(sock, argv[i], strlen(argv[i]) + 1)) goto cleanup;
}
- ok = true;
-
cleanup:
- if (!ok) fprintf(stderr, " failed to write to socket\n");
close(sock);
}
-__attribute__((constructor))
-static void constructor(void) {
- fprintf(stderr, "constructor...\n");
-}
-
// Abridged from glibc posix/execl.c, LGPL copyright FSF
int execl(const char *pathname, const char *arg, ...) {
size_t argc;