나는 내 시스템에 무엇이 있는지, 무엇이 업데이트되고 있는지 추적하는 것을 좋아합니다. 그러나 gedit 3.6.2-1에서 3.6.2-2로의 변경과 같은 사소한 업데이트가 많이 있어서 별로 생각하고 싶지 않습니다.
버전 번호의 첫 번째 또는 두 번째 단락 변경과 같은 팩맨의 주요 업데이트를 강조표시하는 쉬운 방법이 있습니까? (물론 이 휴리스틱이 그다지 유용하지 않다는 것은 알지만 이미 누군가 해결한 문제인 것 같습니다.)
다음은 많은 사소한 업데이트가 포함된 예입니다.
automake 1.12.5-1 1.12.6-1 0.00 MiB
bison 2.6.5-1 2.7-1 0.03 MiB
cdrtools 3.01a09-1 3.01a10-1 0.00 MiB
cifs-utils 5.7-1 5.8-1 0.00 MiB
icu 50.1-2 50.1.1-1 -0.04 MiB
isl 0.11-1 0.11.1-1 0.01 MiB
lib32-libpulse 2.1-1 3.0-1 0.03 MiB
lib32-sqlite 3.7.14.1-1 3.7.15-1 0.00 MiB
libpulse 2.1-1 3.0-2 0.16 MiB
libwbclient 3.6.9-1 3.6.10-1 0.00 MiB
linux 3.6.9-1 3.6.10-1 0.01 MiB
ntp 4.2.6.p5-11 4.2.6.p5-13 -0.05 MiB
pixman 0.28.0-1 0.28.2-1 0.00 MiB
pulseaudio 2.1-1 3.0-2 -0.05 MiB
python2-beaker 1.6.3-2 1.6.4-1 0.03 MiB
python2-distribute 0.6.30-1 0.6.32-1 0.02 MiB
python2-mako 0.7.2-2 0.7.3-1 0.00 MiB
python2-pyparsing 1.5.6-3 1.5.7-1 0.00 MiB
python2-xdg 0.23-2 0.25-1 0.02 MiB
samba 3.6.9-1 3.6.10-1 0.02 MiB
sbc 1.0-1 0.24 MiB
smbclient 3.6.9-1 3.6.10-1 0.00 MiB
sqlite 3.7.14.1-1 3.7.15-1 0.01 MiB
vlc 2.0.4-5 2.0.5-1 -1.42 MiB
wesnoth-data 1.10.5-1 1.10.5-2 98.07 MiB
xorg-server 1.13.0.902-2 1.13.1-1 0.00 MiB
xorg-server-common 1.13.0.902-2 1.13.1-1 0.00 MiB
Pulse Audio 2.1 -> 3.0 및 커널 업데이트가 거기에 숨겨져 있습니다. 더 눈에 띄면 좋겠습니다.
답변1
팩맨은 없지만 제공한 입력 예제를 기반으로 이를 테스트하여 다음과 같이 파일에 저장하고 표준에 전달했습니다.
cat versioninfo.dat | python highlight_major_versions.py
동일한 방식으로 pacman 명령의 출력을 코드에 파이프할 수 있어야 합니다. 내 컴퓨터의 출력은 다음과 같습니다.
파란색은 주요 버전 업데이트(예: 첫 번째 단락)를 나타냅니다. 노란색은 부 버전 업데이트(두 번째 단락)를 나타냅니다. 빨간색은 누락된 버전 정보를 나타냅니다. 이 경우 라이브러리가 이 업데이트의 새로운 것이기 때문입니다. 나는 버전 관리에 대해 영리한 작업을 수행하지 않습니다 -
. -
관련 포인트 분리 세그먼트의 일부로 계산됩니다.
#!/usr/bin/env python
import fileinput
# ANSI escape codes for some colours
BLUE = '\033[94m'
YELLOW = '\033[93m'
RED = '\033[91m'
ENDC = '\033[0m'
def colourise_by_version_change(line, prev_v, new_v):
''' Colourise the input line based on major/minor version change.'''
prev_segments = prev_v.split('.')
new_segments = new_v.split('.')
coloured_line = line
if new_segments[0] > prev_segments[0]:
coloured_line = BLUE + line + ENDC
elif new_segments[1] > prev_segments[1]:
coloured_line = YELLOW + line + ENDC
return coloured_line
if __name__ == '__main__':
for line in fileinput.input():
line = line.strip()
elements = line.split()
if len(elements) == 5:
name, prev_v, new_v, size, size_unit = elements[:5]
line = colourise_by_version_change(line, prev_v, new_v)
# There's something missing, so point it out (e.g. a new version)
else:
line = RED + line + ENDC
print line