13 #include <sys/types.h> 16 #include <sys/socket.h> 34 strncmp((
const char *)stringval,
"human_readable", strlen(
"human_readable")) == 0);
36 strncmp((
const char *)stringval,
"loaded_config_file_name", strlen(
"loaded_config_file_name")) == 0);
59 if (pid_from_atom == NULL) {
61 printf(
"\nRunning version: < 4.2-200\n");
67 printf(
"(Getting version from running i3, press ctrl-c to abort…)");
73 err(EXIT_FAILURE,
"IPC: write()");
75 uint32_t reply_length;
79 if ((ret =
ipc_recv_message(sockfd, &reply_type, &reply_length, &reply)) != 0) {
81 err(EXIT_FAILURE,
"IPC: read()");
85 if (reply_type != I3_IPC_MESSAGE_TYPE_GET_VERSION)
86 errx(EXIT_FAILURE,
"Got reply type %d, but expected %d (GET_VERSION)", reply_type, I3_IPC_MESSAGE_TYPE_GET_VERSION);
90 yajl_status
state = yajl_parse(handle, (
const unsigned char *)reply, (
int)reply_length);
91 if (state != yajl_status_ok)
92 errx(EXIT_FAILURE,
"Could not parse my own reply. That's weird. reply is %.*s", (
int)reply_length, reply);
105 strftime(mtime,
sizeof(mtime),
"%c", localtime(&(sb.st_mtime)));
107 printf(
" (Last modified: %s, %.f seconds ago)\n", mtime, difftime(now, sb.st_mtime));
112 size_t destpath_size = 1024;
115 char *destpath =
smalloc(destpath_size);
117 sasprintf(&exepath,
"/proc/%d/exe", getpid());
119 while ((linksize = readlink(exepath, destpath, destpath_size)) == (ssize_t)destpath_size) {
120 destpath_size = destpath_size * 2;
121 destpath =
srealloc(destpath, destpath_size);
124 err(EXIT_FAILURE,
"readlink(%s)", exepath);
127 destpath[linksize] =
'\0';
130 printf(
"The i3 binary you just called: %s\n", destpath);
133 sasprintf(&exepath,
"/proc/%s/exe", pid_from_atom);
135 while ((linksize = readlink(exepath, destpath, destpath_size)) == (ssize_t)destpath_size) {
136 destpath_size = destpath_size * 2;
137 destpath =
srealloc(destpath, destpath_size);
140 err(EXIT_FAILURE,
"readlink(%s)", exepath);
143 destpath[linksize] =
'\0';
147 if (strstr(destpath,
"(deleted)") != NULL)
148 printf(
"RUNNING BINARY DIFFERENT FROM BINARY ON DISK!\n");
154 sasprintf(&exepath,
"/proc/%s/cmdline", pid_from_atom);
157 if ((fd = open(exepath, O_RDONLY)) == -1)
158 err(EXIT_FAILURE,
"open(%s)", exepath);
159 if (read(fd, destpath,
sizeof(destpath)) == -1)
160 err(EXIT_FAILURE,
"read(%s)", exepath);
163 printf(
"The i3 binary you are running: %s\n", destpath);
int sasprintf(char **strp, const char *fmt,...)
Safe-wrapper around asprintf which exits if it returns -1 (meaning that there is no more memory avail...
static yajl_callbacks version_callbacks
xcb_connection_t * conn
XCB connection and root screen.
int ipc_connect(const char *socket_path)
Connects to the i3 IPC socket and returns the file descriptor for the socket.
int ipc_send_message(int sockfd, const uint32_t message_size, const uint32_t message_type, const uint8_t *payload)
Formats a message (payload) of the given size and type and sends it to i3 via the given socket file d...
static bool human_readable_key
char * root_atom_contents(const char *atomname, xcb_connection_t *provided_conn, int screen)
Try to get the contents of the given atom (for example I3_SOCKET_PATH) from the X11 root window and r...
static char * loaded_config_file_name
static bool loaded_config_file_name_key
void display_running_version(void)
Connects to i3 to find out the currently running version.
void * smalloc(size_t size)
Safe-wrapper around malloc which exits if malloc returns NULL (meaning that there is no more memory a...
static int version_map_key(void *ctx, const unsigned char *stringval, size_t stringlen)
void * srealloc(void *ptr, size_t size)
Safe-wrapper around realloc which exits if realloc returns NULL (meaning that there is no more memory...
int ipc_recv_message(int sockfd, uint32_t *message_type, uint32_t *reply_length, uint8_t **reply)
Reads a message from the given socket file descriptor and stores its length (reply_length) as well as...
static int version_string(void *ctx, const unsigned char *val, size_t len)
static char * human_readable_version
static xcb_cursor_context_t * ctx