2009-04-11 01:37:45 -08:00
|
|
|
/* ncdu - NCurses Disk Usage
|
|
|
|
|
|
2012-01-18 01:40:50 -09:00
|
|
|
Copyright (c) 2007-2012 Yoran Heling
|
2009-04-11 01:37:45 -08:00
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
|
a copy of this software and associated documentation files (the
|
|
|
|
|
"Software"), to deal in the Software without restriction, including
|
|
|
|
|
without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
|
distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
|
permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
|
the following conditions:
|
|
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included
|
|
|
|
|
in all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
|
|
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
|
|
|
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
|
|
|
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
|
|
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef _util_h
|
|
|
|
|
#define _util_h
|
|
|
|
|
|
2009-04-26 01:08:40 -08:00
|
|
|
#include "global.h"
|
2009-04-11 03:47:55 -08:00
|
|
|
#include <ncurses.h>
|
2009-04-11 01:37:45 -08:00
|
|
|
|
|
|
|
|
/* updated when window is resized */
|
|
|
|
|
extern int winrows, wincols;
|
|
|
|
|
|
|
|
|
|
/* used by the nc* functions and macros */
|
|
|
|
|
extern int subwinr, subwinc;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Instead of using several ncurses windows, we only draw to stdscr.
|
|
|
|
|
* the functions nccreate, ncprint and the macros ncaddstr and ncaddch
|
|
|
|
|
* mimic the behaviour of ncurses windows.
|
|
|
|
|
* This works better than using ncurses windows when all windows are
|
|
|
|
|
* created in the correct order: it paints directly on stdscr, so
|
|
|
|
|
* wrefresh, wnoutrefresh and other window-specific functions are not
|
|
|
|
|
* necessary.
|
|
|
|
|
* Also, this method doesn't require any window objects, as you can
|
|
|
|
|
* only create one window at a time.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/* updates winrows, wincols, and displays a warning when the terminal
|
|
|
|
|
* is smaller than the specified minimum size. */
|
|
|
|
|
int ncresize(int, int);
|
|
|
|
|
|
|
|
|
|
/* creates a new centered window with border */
|
2012-09-05 23:45:52 -08:00
|
|
|
void nccreate(int, int, const char *);
|
2009-04-11 01:37:45 -08:00
|
|
|
|
|
|
|
|
/* printf something somewhere in the last created window */
|
|
|
|
|
void ncprint(int, int, char *, ...);
|
|
|
|
|
|
|
|
|
|
/* same as the w* functions of ncurses */
|
|
|
|
|
#define ncaddstr(r, c, s) mvaddstr(subwinr+(r), subwinc+(c), s)
|
|
|
|
|
#define ncaddch(r, c, s) mvaddch(subwinr+(r), subwinc+(c), s)
|
|
|
|
|
#define ncmove(r, c) move(subwinr+(r), subwinc+(c))
|
|
|
|
|
|
|
|
|
|
/* crops a string into the specified length */
|
|
|
|
|
char *cropstr(const char *, int);
|
|
|
|
|
|
|
|
|
|
/* formats size in the form of xxx.xXB */
|
2012-08-27 07:20:24 -08:00
|
|
|
char *formatsize(int64_t );
|
2009-04-11 01:37:45 -08:00
|
|
|
|
|
|
|
|
/* int2string with thousand separators */
|
2012-08-27 07:20:24 -08:00
|
|
|
char *fullsize(int64_t);
|
2009-04-11 01:37:45 -08:00
|
|
|
|
|
|
|
|
/* recursively free()s a directory tree */
|
2009-04-19 02:47:22 -08:00
|
|
|
void freedir(struct dir *);
|
2009-04-11 01:37:45 -08:00
|
|
|
|
2009-04-23 11:15:11 -08:00
|
|
|
/* generates full path from a dir item,
|
|
|
|
|
returned pointer will be overwritten with a subsequent call */
|
|
|
|
|
char *getpath(struct dir *);
|
2009-04-11 01:37:45 -08:00
|
|
|
|
2012-08-26 04:41:25 -08:00
|
|
|
/* returns the root element of the given dir struct */
|
|
|
|
|
struct dir *getroot(struct dir *);
|
|
|
|
|
|
2012-11-22 03:47:10 -09:00
|
|
|
/* Add two signed 64-bit integers. Returns INT64_MAX if the result would
|
|
|
|
|
* overflow, or 0 if it would be negative. At least one of the integers must be
|
|
|
|
|
* positive.
|
2012-11-22 03:33:32 -09:00
|
|
|
* I use uint64_t's to detect the overflow, as (a + b < 0) relies on undefined
|
|
|
|
|
* behaviour, and (INT64_MAX - b >= a) didn't work for some reason. */
|
2012-11-22 03:47:10 -09:00
|
|
|
#define adds64(a, b) ((a) > 0 && (b) > 0\
|
|
|
|
|
? ((uint64_t)(a) + (uint64_t)(b) > (uint64_t)INT64_MAX ? INT64_MAX : (a)+(b))\
|
|
|
|
|
: (a)+(b) < 0 ? 0 : (a)+(b))
|
2012-11-22 03:33:32 -09:00
|
|
|
|
2012-08-26 04:41:25 -08:00
|
|
|
/* Adds a value to the size, asize and items fields of *d and its parents */
|
2012-08-27 08:32:29 -08:00
|
|
|
void addparentstats(struct dir *, int64_t, int64_t, int);
|
2012-08-26 04:41:25 -08:00
|
|
|
|
2012-08-29 01:43:10 -08:00
|
|
|
|
|
|
|
|
/* A simple stack implemented in macros */
|
|
|
|
|
#define nstack_init(_s) do {\
|
|
|
|
|
(_s)->size = 10;\
|
|
|
|
|
(_s)->top = 0;\
|
|
|
|
|
(_s)->list = malloc(10*sizeof(*(_s)->list));\
|
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
|
|
#define nstack_push(_s, _v) do {\
|
|
|
|
|
if((_s)->size <= (_s)->top) {\
|
|
|
|
|
(_s)->size *= 2;\
|
|
|
|
|
(_s)->list = realloc((_s)->list, (_s)->size*sizeof(*(_s)->list));\
|
|
|
|
|
}\
|
|
|
|
|
(_s)->list[(_s)->top++] = _v;\
|
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
|
|
#define nstack_pop(_s) (_s)->top--
|
|
|
|
|
#define nstack_top(_s, _d) ((_s)->top > 0 ? (_s)->list[(_s)->top-1] : (_d))
|
|
|
|
|
#define nstack_free(_s) free((_s)->list)
|
|
|
|
|
|
|
|
|
|
|
2009-04-11 01:37:45 -08:00
|
|
|
#endif
|
|
|
|
|
|