1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-03 04:48:52 -05:00

tools: make color output work on windows

This commit is contained in:
Bert Belder 2018-09-02 23:37:14 +02:00
parent be8f49b332
commit 2e3a8b495d
No known key found for this signature in database
GPG key ID: 7A77887B2E2ED461
6 changed files with 115 additions and 4 deletions

View file

@ -4,7 +4,9 @@ from __future__ import print_function
import os import os
import sys import sys
import third_party import third_party
from util import build_path, run from util import build_path, enable_ansi_colors, run
enable_ansi_colors()
third_party.fix_symlinks() third_party.fix_symlinks()

View file

@ -2,7 +2,9 @@
# Does google-lint on c++ files and ts-lint on typescript files # Does google-lint on c++ files and ts-lint on typescript files
import os import os
from util import run from util import enable_ansi_colors, run
enable_ansi_colors()
root_path = os.path.dirname(os.path.dirname(os.path.realpath(__file__))) root_path = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
third_party_path = os.path.join(root_path, "third_party") third_party_path = os.path.join(root_path, "third_party")

View file

@ -1,6 +1,6 @@
#!/usr/bin/env python #!/usr/bin/env python
import third_party import third_party
from util import run, root_path, build_path, build_mode from util import build_mode, build_path, enable_ansi_colors, root_path, run
import os import os
import re import re
import sys import sys
@ -8,6 +8,8 @@ from distutils.spawn import find_executable
def main(): def main():
enable_ansi_colors()
os.chdir(root_path) os.chdir(root_path)
third_party.fix_symlinks() third_party.fix_symlinks()

View file

@ -5,6 +5,9 @@
# find . -type f | grep -v "\.git" | xargs -I% git add -f --no-warn-embedded-repo "%" # find . -type f | grep -v "\.git" | xargs -I% git add -f --no-warn-embedded-repo "%"
import third_party import third_party
import util
util.enable_ansi_colors()
third_party.fix_symlinks() third_party.fix_symlinks()

View file

@ -5,7 +5,7 @@ import os
import sys import sys
from check_output_test import check_output_test from check_output_test import check_output_test
from setup_test import setup_test from setup_test import setup_test
from util import executable_suffix, run, build_path from util import build_path, enable_ansi_colors, executable_suffix, run
from unit_tests import unit_tests from unit_tests import unit_tests
from util_test import util_test from util_test import util_test
import subprocess import subprocess
@ -28,6 +28,8 @@ def main(argv):
print "Usage: tools/test.py [build_dir]" print "Usage: tools/test.py [build_dir]"
sys.exit(1) sys.exit(1)
enable_ansi_colors()
http_server.spawn() http_server.spawn()
# Internal tools testing # Internal tools testing

View file

@ -173,3 +173,103 @@ def parse_exit_code(s):
return codes[0] return codes[0]
else: else:
return 0 return 0
# Attempts to enable ANSI escape code support.
# Returns True if successful, False if not supported.
def enable_ansi_colors():
if os.name != 'nt':
return True # On non-windows platforms this just works.
elif "CI" in os.environ:
return True # Ansi escape codes work out of the box on Appveyor.
return enable_ansi_colors_win10()
# The windows 10 implementation of enable_ansi_colors.
def enable_ansi_colors_win10():
import ctypes
# Function factory for errcheck callbacks that raise WinError on failure.
def raise_if(error_result):
def check(result, func, args):
if result == error_result:
raise ctypes.WinError(ctypes.get_last_error())
return args
return check
# Windows API types.
from ctypes.wintypes import BOOL, DWORD, HANDLE, LPCWSTR, LPVOID
LPDWORD = ctypes.POINTER(DWORD)
# Generic constants.
NULL = ctypes.c_void_p(0).value
INVALID_HANDLE_VALUE = ctypes.c_void_p(-1).value
# CreateFile flags.
# yapf: disable
GENERIC_READ = 0x80000000
GENERIC_WRITE = 0x40000000
FILE_SHARE_READ = 0x01
FILE_SHARE_WRITE = 0x02
OPEN_EXISTING = 3
# yapf: enable
# Get/SetConsoleMode flags.
ENABLE_VIRTUAL_TERMINAL_PROCESSING = 0x04
kernel32 = ctypes.WinDLL('kernel32', use_last_error=True)
# HANDLE CreateFileW(...)
CreateFileW = kernel32.CreateFileW
CreateFileW.restype = HANDLE
CreateFileW.errcheck = raise_if(INVALID_HANDLE_VALUE)
# yapf: disable
CreateFileW.argtypes = (LPCWSTR, # lpFileName
DWORD, # dwDesiredAccess
DWORD, # dwShareMode
LPVOID, # lpSecurityAttributes
DWORD, # dwCreationDisposition
DWORD, # dwFlagsAndAttributes
HANDLE) # hTemplateFile
# yapf: enable
# BOOL CloseHandle(HANDLE hObject)
CloseHandle = kernel32.CloseHandle
CloseHandle.restype = BOOL
CloseHandle.errcheck = raise_if(False)
CloseHandle.argtypes = (HANDLE, )
# BOOL GetConsoleMode(HANDLE hConsoleHandle, LPDWORD lpMode)
GetConsoleMode = kernel32.GetConsoleMode
GetConsoleMode.restype = BOOL
GetConsoleMode.errcheck = raise_if(False)
GetConsoleMode.argtypes = (HANDLE, LPDWORD)
# BOOL SetConsoleMode(HANDLE hConsoleHandle, DWORD dwMode)
SetConsoleMode = kernel32.SetConsoleMode
SetConsoleMode.restype = BOOL
SetConsoleMode.errcheck = raise_if(False)
SetConsoleMode.argtypes = (HANDLE, DWORD)
# Open the console output device.
conout = CreateFileW("CONOUT$", GENERIC_READ | GENERIC_WRITE,
FILE_SHARE_READ | FILE_SHARE_WRITE, NULL,
OPEN_EXISTING, 0, 0)
# Get the current mode.
mode = DWORD()
GetConsoleMode(conout, ctypes.byref(mode))
# Try to set the flag that controls ANSI escape code support.
try:
SetConsoleMode(conout, mode.value | ENABLE_VIRTUAL_TERMINAL_PROCESSING)
except WindowsError as e:
if e.winerror == ERROR_INVALID_PARAMETER:
return False # Not supported, likely an older version of Windows.
raise
finally:
CloseHandle(conout)
return True