summaryrefslogtreecommitdiff
path: root/slstatus.c
Commit message (Collapse)AuthorAgeFilesLines
* Add back version flag to prepare for releasedrkhsh2023-05-151-1/+3
|
* radical re-formatting 2/3: Fix blocksdrkhsh2022-10-281-22/+13
| | | | | | Fixes coding style. Formatting commits suck, incoherent coding style sucks more. https://suckless.org/coding_style/
* radical re-formatting 1/3: Fix spacingdrkhsh2022-10-281-8/+8
| | | | | | Fixes coding style. Formatting commits suck, incoherent coding style sucks more. https://suckless.org/coding_style/
* do not rely on obsolete featureNRK2022-10-261-1/+1
| | | | | | | | | | function prototype with unspecified argument is obsolete since c99. additionally some of these function which don't take any argument were being called with a `const char *` arg, which is UB. fix both these issues by declararing ALL the components to accept a `const char *`, and name the arg "unused" if it's meant to be ignored.
* Add a -1 option flagDaniel Moch2020-11-301-3/+6
| | | | | Allow slstatus to be used by programs that can grab status by calling an external program on a periodic basis (e.g. tmux)
* Handle SIGUSR1 for forced refreshesMart Lubbers2020-11-301-4/+5
| | | | | | At some point one might want to force a refresh for example after checking email or changing the volume. Sending a SIGUSR1 achieves this now
* Consistency with 80 char limit and breaksAaron Marcher2018-07-081-1/+2
|
* Flush the output stream instead of arbitrarily disabling bufferingQuentin Rameau2018-05-291-7/+4
| | | | | This is (arguably) more elegant and it matches Xlib output logic. Also use puts instead of printf as we don't do formating there.
* Use E-notation for large powers of 10Laslo Hunhold2018-05-271-2/+2
|
* Remove o-flag as it is redundantLaslo Hunhold2018-05-221-10/+3
| | | | | | | | | | | | | | | | Even if we extend the flag to be an n-flag with a numerical input, we already have other Unix-tools to take care of us much more flexibly, e.g. with head(1) you can easily get the first 10 outputs with slstatus -s | head -n 10, but also e.g. discard the first one and then get the consecutive 10 outputs. For the X11-root-window-name, you can limit the runtime with timeout(1) or a comparable solution. This reverts commit fa8b939990ed0648f99b0cbeba4efed807160db3.
* Check printf() for output errorsLaslo Hunhold2018-05-221-1/+3
| | | | | | | | | This way cases like $ slstatus -s > /dev/full are properly caught and the program terminated with the proper return code.
* Add option to output only once and exitAaron Marcher2018-05-211-3/+10
|
* Implement esnprintf() and make formatted calls more efficientLaslo Hunhold2018-05-191-5/+1
| | | | | | | Within the components, snprintf() was unchecked and had inefficient calls in some places. We implement esnprintf() that does all the dirty laundry for us and use it exclusively now.
* Add warn() and die()Laslo Hunhold2018-05-181-22/+9
| | | | | | | | | | | Given slstatus is a tool that runs in the background, most likely run from .xinitrc, it's important to prepend the name of the tool to error messages so it becomes clear where the error is coming from. To make this much more consistent, this commit adds warn() and die() utility functions consistent with other suckless projects and adapts all calls to fprintf(stderr, *) to the warn() and die() functions, greatly increasing the readability of the code.
* Audit slstatus.cLaslo Hunhold2018-05-181-13/+35
| | | | | | | | | | | | 1) Remove setlocale() (locales are harmful and any 'issues' shall be fixed in different ways that are expected). 2) Disable buffering on stdout with setbuf() rather than flushing it each time. 3) Make error messages more consistent. 4) Add error checks where applicable. 5) Make code a bit more readable where res is assigned. 6) Use XFlush() rather than XSync() (we don't need to wait for the XServer to react, which could lead to long hangs on our side).
* Properly handle *snprintf() errorsLaslo Hunhold2018-05-171-6/+11
| | | | | | | Posix guarantees that the resulting string is null-terminated, even if we have an overflow. Instead of doing what has already been done, properly warn when there has been an error or overflow, so the user can do something about it.
* Change done to int as it is the CPU's natural typeAaron Marcher2018-05-171-1/+1
|
* fflush(stdout) to print line by line if stdout is not a ttyJosuah Demangeon2018-05-081-0/+1
| | | | | | | | | | To reproduce the issue: $ slstatus -s | tee then it would print only when the stdout buffer is full, by block of multiple lines. fflush() makes sure the line is printed at every loop iteration
* Only variable declarations at top of blockAaron Marcher2018-05-071-1/+2
|
* Remove program name from error messagesAaron Marcher2018-03-281-1/+1
|
* Remove unnecessary headersAaron Marcher2018-03-281-2/+0
|
* Print unknown_str in case of errorSiIky2018-02-171-1/+3
| | | | | func can return NULL in case of error, but no checking is done when printing, and unknown_str wasn't being used anywhere.
* Properly declare buf as extern and fix all unused-warningsLaslo Hunhold2017-09-171-1/+4
|
* Rewrite Makefile to accomodate file splitLaslo Hunhold2017-09-171-37/+1
|
* Split into multiple filesAaron Marcher2017-09-171-740/+1
| | | | | | | | For multiple reasons the program is now split: - Make future porting to OpenBSD easier - Assign header includes to individiual functions - Make future program extensions easier - Recompile only changed parts
* Add blank line after setlocaleAaron Marcher2017-09-161-0/+1
| | | | setlocale() has to be separated from the signal handling.
* slstatus: set localeKurt Van Dijck2017-09-161-0/+2
| | | | | | | I want my date & time printed according my locale settings. This commit enables that Signed-off-by: Kurt Van Dijck <dev.kurt@vandijck-laurijssen.be>
* slstatus: add cpu_iowaitKurt Van Dijck2017-09-161-11/+33
| | | | | | | | | | This commit introduces the cpu_iowait item, this is the percentage of cpu time spent waiting on disks. High numbers typically indicate that your system is not responsive due to disk IO. This commit also avoid sleeping inside the cpu_perc and cpu_iowait functions: waiting in either one implies lost info for the other. Signed-off-by: Kurt Van Dijck <dev.kurt@vandijck-laurijssen.be>
* slstatus load_avg format stringKamil CholewiƄski2017-09-101-3/+3
|
* Added IPv6 address functionAaron Marcher2017-08-141-4/+36
| | | | | | - Renamed "ip" function to "ipv4" - Added "ipv6" function - Adjusted README and config.def.h accordingly
* Fix a little logic errorLaslo Hunhold2017-08-141-1/+1
|
* Add pscanf()Laslo Hunhold2017-08-141-157/+66
| | | | This reduces a lot of equivalent code to one function call.
* Refactor main()Laslo Hunhold2017-08-131-34/+39
| | | | | | | | | | | | | | | | | We remove the hack with the sleep and global "delay"-variable and use a monotonic clock to derive the desired monotonic properties of the tool. Inside each function that demands a personal delay we can then just do a nanosleep() and be done with it. It's a shame that timespec is so ugly to work with, but there's really no way to make it more beautiful. However, at this cost though we finally can set the interval times in milliseconds and not only just seconds. We remove setlocale(), because nothing good ever came out of this function. Besides that we have some more code refactoring, especially in the argument loop which saves us a bit of complexity.
* Simplify signal handling a bitLaslo Hunhold2017-08-131-7/+5
|
* Remove unnecessary prototypesLaslo Hunhold2017-08-131-3/+0
|
* Remove unnecessary blank lines after license-noticeLaslo Hunhold2017-08-131-1/+0
|
* Removed #define for unknown_strAaron Marcher2017-08-121-69/+69
| | | | | Debugging #define is very difficult. The performance overhead of static const char is negligible.
* Removed #define for update intervalAaron Marcher2017-08-121-2/+2
| | | | | Debugging #define, especially in mathematical constructs is very difficult. The performance overhead of static const int is negligible.
* keyboard_indicators: fix segfault when -s is specifiedAli H. Fardan2017-08-121-0/+6
|
* Fixed possible NULL-deref and removed unnecessary XOpenDisplay()Aaron Marcher2017-08-111-2/+5
| | | | | | | - Added a check for the return value of XOpenDisplay() in main(). This fixes a possible NULL-deref. - Removed unnsecessary XOpenDisplay and XCloseDisplay from keyboard_indicators(). The ones in main() are sufficent.
* Add and use LEN() macroLaslo Hunhold2017-08-111-5/+6
|
* Refactor battery_state()Laslo Hunhold2017-08-111-12/+17
|
* Print usage() when we are left with argumentsLaslo Hunhold2017-08-101-0/+4
|
* Reduce -o | -n to -sLaslo Hunhold2017-08-101-21/+10
| | | | | What we really want is to either output to WM_NAME or stdout. If we want just one single line, we do slstatus | head -n 1.
* Remove d- and v-flagsLaslo Hunhold2017-08-101-12/+3
| | | | | | | d-flag: There's no need for that, use the &-operator or fork+exec in a non-shell-context. In the latter case you get the PID for free. v-flag: If you want to find out which version of a package is installed, consult your package manager. That's his job.
* Convert slstatus.1 to mandoc, simplify it and remove -hLaslo Hunhold2017-08-101-8/+6
| | | | | | We also change the semantics of -v to only return the version information. There is now no need for usage() to exit with anything other than 1.
* add num_files() function for maildirs ;)aaron marcher2017-08-061-0/+25
|
* check for fgets/fscanf return valuesAaron Marcher2017-06-131-35/+75
|
* use a static buffer instead of dynamic memoryAaron Marcher2017-06-131-241/+200
|
* remove format characters from stat functionsAaron Marcher2017-06-121-8/+8
|