/* rc.h Header file for external applications to get RC information. Copyright 2007 Gentoo Foundation Released under the GPLv2 */ #ifndef __EINFO_H__ #define __EINFO_H__ #ifdef __GNUC__ # define EINFO_PRINTF(_one, _two) __attribute__ ((__format__ (__printf__, _one, _two))) # define EINFO_XPRINTF(_one, _two) __attribute__ ((__noreturn__, __format__ (__printf__, _one, _two))) #endif #include #include typedef enum { einfo_good, einfo_warn, einfo_bad, einfo_hilite, einfo_bracket, einfo_normal } einfo_color_t; /* Colour codes used by the below functions. */ #define EINFO_GOOD "\033[32;01m" #define EINFO_WARN "\033[33;01m" #define EINFO_BAD "\033[31;01m" #define EINFO_HILITE "\033[36;01m" #define EINFO_BRACKET "\033[34;01m" #define EINFO_NORMAL "\033[0m" /* Handy macros to easily use the above in a custom manner */ #define PEINFO_GOOD if (colour_terminal ()) printf (EINFO_GOOD) #define PEINFO_WARN if (colour_terminal ()) printf (EINFO_WARN) #define PEINFO_BAD if (colour_terminal ()) printf (EINFO_BAD) #define PEINFO_HILITE if (colour_terminal ()) printf (EINFO_HILITE) #define PEINFO_BRACKET if (colour_terminal ()) printf (EINFO_BRACKET) #define PEINFO_NORMAL if (colour_terminal ()) printf (EINFO_NORMAL) /* We work out if the terminal supports colour or not through the use of the TERM env var. We cache the reslt in a static bool, so subsequent calls are very fast. The n suffix means that a newline is NOT appended to the string The v suffix means that we only print it when RC_VERBOSE=yes NOTE We use the v suffix here so we can add veinfo for va_list in the future, but veinfo is used by shell scripts as they don't have the va_list concept */ bool colour_terminal (void); int einfon (const char *fmt, ...) EINFO_PRINTF (1, 2); int ewarnn (const char *fmt, ...) EINFO_PRINTF (1, 2); int eerrorn (const char *fmt, ...) EINFO_PRINTF (1, 2); int einfo (const char *fmt, ...) EINFO_PRINTF(1, 2); int ewarn (const char *fmt, ...) EINFO_PRINTF (1, 2); void ewarnx (const char *fmt, ...) EINFO_XPRINTF (1,2); int eerror (const char *fmt, ...) EINFO_PRINTF (1,2); void eerrorx (const char *fmt, ...) EINFO_XPRINTF (1,2); int ebegin (const char *fmt, ...) EINFO_PRINTF (1, 2); int eend (int retval, const char *fmt, ...) EINFO_PRINTF (2, 3); int ewend (int retval, const char *fmt, ...) EINFO_PRINTF (2, 3); void ebracket (int col, einfo_color_t color, const char *msg); void eindent (void); void eoutdent (void); int einfovn (const char *fmt, ...) EINFO_PRINTF (1, 2); int ewarnvn (const char *fmt, ...) EINFO_PRINTF (1, 2); int ebeginvn (const char *fmt, ...) EINFO_PRINTF (1, 2); int eendvn (int retval, const char *fmt, ...) EINFO_PRINTF (2, 3); int ewendvn (int retval, const char *fmt, ...) EINFO_PRINTF (2, 3); int einfov (const char *fmt, ...) EINFO_PRINTF (1, 2); int ewarnv (const char *fmt, ...) EINFO_PRINTF (1, 2); int ebeginv (const char *fmt, ...) EINFO_PRINTF (1, 2); int eendv (int retval, const char *fmt, ...) EINFO_PRINTF (2, 3); int ewendv (int retval, const char *fmt, ...) EINFO_PRINTF (2, 3); void eindentv (void); void eoutdentv (void); /* If RC_EBUFFER is set, then we buffer all the above commands. As such, we need to flush the buffer when done. */ void eflush(void); #endif