gri3-wm/libi3
Michael Stapelberg fa1b436fca Bugfix: mark IPC fd CLOEXEC (Thanks Layus)
Without this fix, children of i3bar would inherit the file descriptor of
the IPC connection to i3. Therefore, even if i3bar exits with SIGSEGV,
the connection to i3 stays open. Because nobody actually reads any
messages by i3, the buffer will fill up and i3 can’t deliver any more
messages, and thus busy-loops at that point.

fixes 
2013-04-14 10:12:21 +02:00
..
Makefile
README
fake_configure_notify.c
font.c Make i3-nagbar use the same font as configured for i3 2013-01-26 09:55:38 +01:00
get_colorpixel.c
get_mod_mask.c
get_process_filename.c
get_visualtype.c
ipc_connect.c Bugfix: mark IPC fd CLOEXEC (Thanks Layus) 2013-04-14 10:12:21 +02:00
ipc_recv_message.c ipc_recv_message: store message_type, don’t compare. add distinct EOF retval 2013-01-23 18:51:39 +01:00
ipc_send_message.c ipc_send_message: use stack frame with fixed size 2013-01-11 19:09:41 +01:00
is_debug_build.c
libi3.mk
root_atom_contents.c
safewrappers.c
string.c
strndup.c
ucs2_conversion.c

README

Introduction
============

libi3 is an *INTERNAL* library which contains functions that i3 and related
tools (i3-msg, i3-input, i3-nagbar, i3-config-wizard, i3bar) use.

It is NOT to be used by other programs.

Structure
=========

Every function gets its own .c file, which in turn gets compiled into an .o
object file. Afterwards, all .o files are archived into one static library
(libi3.a). This library will be linked into all i3 binaries. The linker is able
to eliminate unused .o files when linking, so only the functions which you
actually use will be included in the corresponding binary.