X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=common%2Fformatter.hpp;h=75a407f7469ee421f3cde1c9bc8b7e4a68a4772d;hb=HEAD;hp=59f0feac22220f53dc00474edc9f5355694fe330;hpb=33783a898e5450ae5bbe21a2b9c9db159f53d2ab;p=apitrace diff --git a/common/formatter.hpp b/common/formatter.hpp index 59f0fea..75a407f 100644 --- a/common/formatter.hpp +++ b/common/formatter.hpp @@ -33,6 +33,39 @@ #include +#ifdef _WIN32 +#include + +#ifndef COMMON_LVB_LEADING_BYTE +#define COMMON_LVB_LEADING_BYTE 0x0100 +#endif + +#ifndef COMMON_LVB_TRAILING_BYTE +#define COMMON_LVB_TRAILING_BYTE 0x0200 +#endif + +#ifndef COMMON_LVB_GRID_HORIZONTAL +#define COMMON_LVB_GRID_HORIZONTAL 0x0400 +#endif + +#ifndef COMMON_LVB_GRID_LVERTICAL +#define COMMON_LVB_GRID_LVERTICAL 0x0800 +#endif + +#ifndef COMMON_LVB_GRID_RVERTICAL +#define COMMON_LVB_GRID_RVERTICAL 0x1000 +#endif + +#ifndef COMMON_LVB_REVERSE_VIDEO +#define COMMON_LVB_REVERSE_VIDEO 0x4000 +#endif + +#ifndef COMMON_LVB_UNDERSCORE +#define COMMON_LVB_UNDERSCORE 0x8000 +#endif + +#endif /* _WIN32 */ + namespace formatter { @@ -88,7 +121,10 @@ protected: public: virtual Attribute *normal(void) const { return new AnsiAttribute("0m"); } virtual Attribute *bold(void) const { return new AnsiAttribute("1m"); } + /* Italic is not widely supported, or worse, implemented with a reverse */ +#if 0 virtual Attribute *italic(void) const { return new AnsiAttribute("3m"); } +#endif virtual Attribute *strike(void) const { return new AnsiAttribute("9m"); } virtual Attribute *color(Color c) const { static const char *color_escapes[] = { @@ -110,38 +146,6 @@ inline std::ostream& operator<<(std::ostream& os, const Attribute *attr) { #ifdef _WIN32 -#include - - -#ifndef COMMON_LVB_LEADING_BYTE -#define COMMON_LVB_LEADING_BYTE 0x0100 -#endif - -#ifndef COMMON_LVB_TRAILING_BYTE -#define COMMON_LVB_TRAILING_BYTE 0x0200 -#endif - -#ifndef COMMON_LVB_GRID_HORIZONTAL -#define COMMON_LVB_GRID_HORIZONTAL 0x0400 -#endif - -#ifndef COMMON_LVB_GRID_LVERTICAL -#define COMMON_LVB_GRID_LVERTICAL 0x0800 -#endif - -#ifndef COMMON_LVB_GRID_RVERTICAL -#define COMMON_LVB_GRID_RVERTICAL 0x1000 -#endif - -#ifndef COMMON_LVB_REVERSE_VIDEO -#define COMMON_LVB_REVERSE_VIDEO 0x4000 -#endif - -#ifndef COMMON_LVB_UNDERSCORE -#define COMMON_LVB_UNDERSCORE 0x8000 -#endif - - class WindowsAttribute : public Attribute { protected: WORD wAttributes; @@ -186,12 +190,25 @@ public: } }; -#endif + +#endif /* _WIN32 */ inline Formatter *defaultFormatter(bool color = true) { if (color) { #ifdef _WIN32 + // http://wiki.winehq.org/DeveloperFaq#detect-wine + static HMODULE hNtDll = NULL; + static bool bWine = false; + if (!hNtDll) { + hNtDll = LoadLibraryA("ntdll"); + if (hNtDll) { + bWine = GetProcAddress(hNtDll, "wine_get_version") != NULL; + } + } + if (bWine) { + return new AnsiFormatter; + } return new WindowsFormatter; #else return new AnsiFormatter;