summaryrefslogtreecommitdiff
path: root/util.c
Commit message (Collapse)AuthorAgeFilesLines
* verr: Remove special "usage" caseplanet362022-12-191-3/+0
| | | | | | | | In function verr, remove special case for "usage" string Co-authored-by: drkhsh <me@drkhsh.at> Signed-off-by: drkhsh <me@drkhsh.at>
* radical re-formatting 2/3: Fix blocksdrkhsh2022-10-281-4/+2
| | | | | | Fixes coding style. Formatting commits suck, incoherent coding style sucks more. https://suckless.org/coding_style/
* Follow International System of Units spacing rulesIngo Feinerer2019-02-171-1/+1
|
* Consistency with 80 char limit and breaksAaron Marcher2018-07-081-1/+2
|
* Change uint64_t to uintmax_tAaron Marcher2018-07-071-1/+1
|
* fmt_human: Improve typesAaron Marcher2018-07-061-1/+2
| | | | size_t may not be enough, use 64 bit integers
* Refactor snprintf-usage in util.cLaslo Hunhold2018-05-231-13/+19
|
* Refactor fmt_human() and fix a bugLaslo Hunhold2018-05-211-11/+19
| | | | | | | | | | It is not necessary to copy memory or anything. Just keep a pointer to the active prefix-array and assign the length of the arrays to a variable. Make the code more readable by using a switch, be more strict when an invalid base is passed to it and fix a small oversight in the bottom of the code where the base 1024 was forgotten to generalized.
* Merge fmt_human_2 and fmt_human_10 to one functionAaron Marcher2018-05-211-20/+12
| | | | Now only one function, fmt_human, takes an additional argument "base".
* Remove units from numbersAaron Marcher2018-05-211-4/+4
| | | | | | | | | | This is a first step to decouple formatting from information because of two reasons: 1. The components should only gather and return the values by design 2. Fine grained user control should be a focus Scaling will be implemented in a different way in a later commit.
* Implement fmt_human_2() and fmt_human_10()Laslo Hunhold2018-05-191-8/+24
| | | | | | | | | These functions take the raw number and a unit and automatically print it out "scaled down" to a proper SI-prefix, for powers of 2 and 10 respectively. Apply them to the 2-power cases and keep the 10-power for a later commit.
* Implement esnprintf() and make formatted calls more efficientLaslo Hunhold2018-05-191-0/+21
| | | | | | | 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 fmt_scaled util functionAaron Marcher2018-05-181-0/+16
|
* Add warn() and die()Laslo Hunhold2018-05-181-3/+45
| | | | | | | | | | | 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.
* Properly handle *snprintf() errorsLaslo Hunhold2018-05-171-6/+6
| | | | | | | 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.
* Fix coding styleAaron Marcher2018-05-061-1/+2
| | | | | | | | | - Use block for single statement ifs - Keep lines to reasonable length (current debate as to reasonable) - When functions return -1 for error test against 0 not -1 - Do not indent cases another level - Do not test against NULL and 0 explicitly - Use tabs for indentation, use spaces for alignment
* Format error messages properlyAaron Marcher2018-03-281-1/+2
| | | | | Make use of strerror(errno) and format all errors equally: function ['parameters']: error message
* Get rid of err.h as it is not portableAaron Marcher2018-03-281-3/+1
| | | | | Replace warn() and warnx() with fprintf() and add <stdio.h> where necessary.
* Added LICENSE statements to all source filesAaron Marcher2017-09-171-0/+1
|
* Split into multiple filesAaron Marcher2017-09-171-0/+42
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