revamping markdown libraries

This commit is contained in:
q
2016-06-06 23:45:23 +03:00
parent 543820b04b
commit 0ced78d059
6 changed files with 426 additions and 265 deletions

212
reporting/srcframes2ans Executable file
View File

@@ -0,0 +1,212 @@
#!/usr/bin/env python
# coding=utf-8
#
# Copyright 2016 Ville Rantanen
#
# This program is free software: you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
'''Color by notation.'''
__author__ = "Ville Rantanen <ville.q.rantanen@gmail.com>"
__version__ = "0.2"
NEWCHAR="====CHAR"
NEWCOLOR="====COLOR"
NEWIMAGE="====EOI"
ENDOFFILE="====EOF"
PAUSE="====PAUSE"
import sys,os,argparse,re,time
from argparse import ArgumentParser
class bc:
K="\033[1;30m"
R="\033[1;31m"
G="\033[1;32m"
Y="\033[1;33m"
B="\033[1;34m"
M="\033[1;35m"
C="\033[1;36m"
W="\033[1;37m"
k="\033[0;30m"
r="\033[0;31m"
g="\033[0;32m"
y="\033[0;33m"
b="\033[0;34m"
m="\033[0;35m"
c="\033[0;36m"
w="\033[0;37m"
nk="\033[30m"
nr="\033[31m"
ng="\033[32m"
ny="\033[33m"
nb="\033[34m"
nm="\033[35m"
nc="\033[36m"
nw="\033[37m"
bk="\033[40m"
br="\033[41m"
bg="\033[42m"
by="\033[43m"
bb="\033[44m"
bm="\033[45m"
bc="\033[46m"
bw="\033[47m"
S = '\033[1m'
U = '\033[4m'
Z = '\033[0m'
CLR = '\033[2J'
CLREND = '\033[K'
CLRSCR = CLR+"\033[0;0H"
color_keys="PQWERTYU01234567XCZV;asdfghj)!@#$%^&"
color_list=[K, R, G, Y, B, M, C, W, k, r, g, y, b, m, c, w,
S,CLRSCR,Z,U,bk,br,bg,by,bb,bm,bc,bw,nk,nr,ng,ny,nb,nm,nc,nw ]
def pos(self,y,x):
return "\033["+str(y)+";"+str(x)+"H"
def posprint(self, y,x,s):
sys.stdout.write( (self.pos(y,x) + str(s)).encode('utf-8') )
def clear(self):
sys.stdout.write( (self.CLR+self.pos(0,0)).encode('utf-8') )
def clear_to_end(self):
sys.stdout.write( self.CLREND.encode('utf-8') )
def color_char(self,s):
for i,c in enumerate(self.color_keys):
if c in s:
s=s.replace(c,self.color_list[i])
return s
return ""
def nocolor_string(self,s):
return ""
def setup_options():
''' Create command line options '''
usage='''
Color notation renderer in ANSI codes
Special syntaxes:
* Colors: insert string ${C}, where C is one of KRGBYMCWkrgbymcwSUZ
'''
parser=ArgumentParser(description=usage,
formatter_class=argparse.RawDescriptionHelpFormatter,
epilog=__author__)
parser.add_argument("-v","--version",action="version",version=__version__)
parser.add_argument("--no-color","-n",action="store_false",dest="color",default=True,
help="Disable color.")
parser.add_argument("-z",action="store_true",dest="zero",default=False,
help="Reset coloring at the end of each line.")
parser.add_argument("-c",action="store_true",dest="clear",default=False,
help="Clear screen first")
parser.add_argument("filename",type=str,
help="File to show")
opts=parser.parse_args()
return opts
bc=bc()
opts=setup_options()
if opts.filename=='-':
f=sys.stdin
else:
f=open(opts.filename,'r')
if opts.clear:
bc.clear()
while True:
pause=0
gray=[]
gray.append([])
colors=[]
colorFrame=0
grayFrame=0
maxRow=0
for row in f:
if not row:
sys.exit(0)
row=row.decode('utf-8').rstrip("\n\r")
if row.startswith(NEWIMAGE):
break
if row.startswith(PAUSE):
try:
new_value=row[len(PAUSE):].strip()
pause=float(new_value)
except:
pause=0
continue
if row.startswith(NEWCOLOR):
colorFrame+=1
colors.append([])
continue
if colorFrame==0:
if row.startswith(NEWCHAR):
grayFrame+=1
gray.append([])
continue
gray[grayFrame].append(row)
maxRow=max(maxRow, len(row))
else:
colors[colorFrame-1].append(row)
if len(gray[0])==0:
sys.exit(0)
for i in range(len(gray[0])):
while maxRow>len(gray[0][i]):
gray[0][i]=gray[0][i]+" "
for i in range(len(gray[0])):
for frame in colors:
if len(frame)<i+1:
frame.append('')
while len(gray[0][i])>len(frame[i]):
frame[i]=frame[i]+" "
if len(gray)>1:
for layer in gray[1:]:
if len(layer)<i+1:
layer.append('')
while len(gray[0][i])>len(layer[i]):
layer[i]=layer[i]+" "
for i in range(len(gray[0])):
for c in range(len(gray[0][i])):
if opts.color:
for frame in colors:
try:
if frame[i][c]!=" ":
sys.stdout.write(bc.color_char(frame[i][c]).encode('utf-8'))
except IndexError:
pass
char=" "
for layer in gray:
if layer[i][c]==" ": continue
char=layer[i][c]
sys.stdout.write(char.encode('utf-8'))
if opts.color and opts.zero:
sys.stdout.write(bc.Z.encode('utf-8'))
sys.stdout.write("\n")
if pause>0:
time.sleep(pause)