support the NO_COLOR environment variable
https://no-color.org/ and more importantly https://youtu.be/biW5UVGkPMA?t=150
This commit is contained in:
		
							parent
							
								
									510302d667
								
							
						
					
					
						commit
						705b58c741
					
				| @ -27,7 +27,11 @@ WINDOWS: Any = ( | ||||
|     else False | ||||
| ) | ||||
| 
 | ||||
| VT100 = not WINDOWS or WINDOWS >= [10, 0, 14393] | ||||
| VT100 = "--ansi" in sys.argv or ( | ||||
|     os.environ.get("NO_COLOR", "").lower() in ("", "0", "false") | ||||
|     and "--no-ansi" not in sys.argv | ||||
|     and (not WINDOWS or WINDOWS >= [10, 0, 14393]) | ||||
| ) | ||||
| # introduced in anniversary update | ||||
| 
 | ||||
| ANYWIN = WINDOWS or sys.platform in ["msys", "cygwin"] | ||||
|  | ||||
| @ -870,6 +870,8 @@ def add_logging(ap): | ||||
|     ap2 = ap.add_argument_group('logging options') | ||||
|     ap2.add_argument("-q", action="store_true", help="quiet") | ||||
|     ap2.add_argument("-lo", metavar="PATH", type=u, help="logfile, example: \033[32mcpp-%%Y-%%m%%d-%%H%%M%%S.txt.xz") | ||||
|     ap2.add_argument("--no-ansi", action="store_true", default=not VT100, help="disable colors; same as environment-variable NO_COLOR") | ||||
|     ap2.add_argument("--ansi", action="store_true", help="force colors; overrides environment-variable NO_COLOR") | ||||
|     ap2.add_argument("--no-voldump", action="store_true", help="do not list volumes and permissions on startup") | ||||
|     ap2.add_argument("--log-conn", action="store_true", help="debug: print tcp-server msgs") | ||||
|     ap2.add_argument("--log-htp", action="store_true", help="debug: print http-server threadpool scaling") | ||||
| @ -1179,6 +1181,11 @@ def main(argv: Optional[list[str]] = None) -> None: | ||||
|     except: | ||||
|         sys.exit(1) | ||||
| 
 | ||||
|     if al.ansi: | ||||
|         al.no_ansi = False | ||||
|     elif not al.no_ansi: | ||||
|         al.ansi = VT100 | ||||
| 
 | ||||
|     if HAVE_SSL: | ||||
|         ensure_cert(al) | ||||
| 
 | ||||
| @ -1188,7 +1195,7 @@ def main(argv: Optional[list[str]] = None) -> None: | ||||
|         except: | ||||
|             lprint("\nfailed to disable quick-edit-mode:\n" + min_ex() + "\n") | ||||
| 
 | ||||
|     if not VT100: | ||||
|     if al.ansi: | ||||
|         al.wintitle = "" | ||||
| 
 | ||||
|     nstrs: list[str] = [] | ||||
|  | ||||
| @ -28,7 +28,7 @@ if True:  # pylint: disable=using-constant-test | ||||
|     import typing | ||||
|     from typing import Any, Optional, Union | ||||
| 
 | ||||
| from .__init__ import ANYWIN, EXE, MACOS, TYPE_CHECKING, VT100, EnvParams, unicode | ||||
| from .__init__ import ANYWIN, EXE, MACOS, TYPE_CHECKING, EnvParams, unicode | ||||
| from .authsrv import AuthSrv | ||||
| from .mtag import HAVE_FFMPEG, HAVE_FFPROBE | ||||
| from .tcpsrv import TcpSrv | ||||
| @ -80,6 +80,7 @@ class SvcHub(object): | ||||
|         self.dargs = dargs | ||||
|         self.argv = argv | ||||
|         self.E: EnvParams = args.E | ||||
|         self.no_ansi = args.no_ansi | ||||
|         self.logf: Optional[typing.TextIO] = None | ||||
|         self.logf_base_fn = "" | ||||
|         self.stop_req = False | ||||
| @ -681,11 +682,15 @@ class SvcHub(object): | ||||
|             now = time.time() | ||||
|             if now >= self.next_day: | ||||
|                 dt = datetime.utcfromtimestamp(now) | ||||
|                 print("\033[36m{}\033[0m\n".format(dt.strftime("%Y-%m-%d")), end="") | ||||
|                 zs = "{}\n" if self.no_ansi else "\033[36m{}\033[0m\n" | ||||
|                 zs = zs.format(dt.strftime("%Y-%m-%d")) | ||||
|                 print(zs, end="") | ||||
|                 self._set_next_day() | ||||
|                 if self.logf: | ||||
|                     self.logf.write(zs) | ||||
| 
 | ||||
|             fmt = "\033[36m%s \033[33m%-21s \033[0m%s\n" | ||||
|             if not VT100: | ||||
|             if self.no_ansi: | ||||
|                 fmt = "%s %-21s %s\n" | ||||
|                 if "\033" in msg: | ||||
|                     msg = ansi_re.sub("", msg) | ||||
|  | ||||
| @ -7,7 +7,7 @@ import socket | ||||
| import sys | ||||
| import time | ||||
| 
 | ||||
| from .__init__ import ANYWIN, PY2, TYPE_CHECKING, VT100, unicode | ||||
| from .__init__ import ANYWIN, PY2, TYPE_CHECKING, unicode | ||||
| from .stolen.qrcodegen import QrCode | ||||
| from .util import ( | ||||
|     E_ACCESS, | ||||
| @ -501,7 +501,7 @@ class TcpSrv(object): | ||||
|                 zoom = 1 | ||||
| 
 | ||||
|         qr = qrc.render(zoom, pad) | ||||
|         if not VT100: | ||||
|         if self.args.no_ansi: | ||||
|             return "{}\n{}".format(txt, qr) | ||||
| 
 | ||||
|         halfc = "\033[40;48;5;{0}m{1}\033[47;48;5;{2}m" | ||||
|  | ||||
| @ -98,7 +98,7 @@ class Cfg(Namespace): | ||||
|     def __init__(self, a=None, v=None, c=None): | ||||
|         ka = {} | ||||
| 
 | ||||
|         ex = "daw dav_auth dav_inf dav_mac dav_rt dotsrch e2d e2ds e2dsa e2t e2ts e2tsr e2v e2vu e2vp ed emp force_js getmod hardlink ih ihead magic never_symlink nid nih no_acode no_athumb no_dav no_dedup no_del no_dupe no_logues no_mv no_readme no_robots no_sb_md no_sb_lg no_scandir no_thumb no_vthumb no_zip nrand nw rand vc xdev xlink xvol" | ||||
|         ex = "daw dav_auth dav_inf dav_mac dav_rt dotsrch e2d e2ds e2dsa e2t e2ts e2tsr e2v e2vu e2vp ed emp force_js getmod grid hardlink ih ihead magic never_symlink nid nih no_acode no_athumb no_dav no_dedup no_del no_dupe no_logues no_mv no_readme no_robots no_sb_md no_sb_lg no_scandir no_thumb no_vthumb no_zip nrand nw rand vc xdev xlink xvol" | ||||
|         ka.update(**{k: False for k in ex.split()}) | ||||
| 
 | ||||
|         ex = "dotpart no_rescan no_sendfile no_voldump plain_ip" | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed