|
@@ -1,1293 +1,1296 @@
|
|
|
-from . import tool
|
|
|
|
|
-
|
|
|
|
|
-import datetime
|
|
|
|
|
-import html
|
|
|
|
|
-import re
|
|
|
|
|
-
|
|
|
|
|
-def nowiki_js(data):
|
|
|
|
|
- data = data.replace('\\', '\\\\')
|
|
|
|
|
- data = data.replace('"', '\\"')
|
|
|
|
|
- data = data.replace('\r', '')
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'^\n', '', data)
|
|
|
|
|
-
|
|
|
|
|
- data = data.replace('\n', '<br>')
|
|
|
|
|
-
|
|
|
|
|
- return data
|
|
|
|
|
-
|
|
|
|
|
-def link_fix(main_link):
|
|
|
|
|
- global end_data
|
|
|
|
|
-
|
|
|
|
|
- main_link = main_link.replace(''', "<link_comma>")
|
|
|
|
|
-
|
|
|
|
|
- if re.search(r'^:', main_link):
|
|
|
|
|
- main_link = re.sub(r'^:', '', main_link)
|
|
|
|
|
-
|
|
|
|
|
- main_link = re.sub(r'^사용자:', 'user:', main_link)
|
|
|
|
|
- main_link = re.sub(r'^파일:', 'file:', main_link)
|
|
|
|
|
- main_link = re.sub(r'^분류:', 'category:', main_link)
|
|
|
|
|
-
|
|
|
|
|
- other_link = re.search(r'[^\\]?(#[^#]+)$', main_link)
|
|
|
|
|
- if other_link:
|
|
|
|
|
- other_link = other_link.group(1)
|
|
|
|
|
-
|
|
|
|
|
- main_link = re.sub(r'(#[^#]+)$', '', main_link)
|
|
|
|
|
- else:
|
|
|
|
|
- other_link = ''
|
|
|
|
|
-
|
|
|
|
|
- main_link = main_link.replace("<link_comma>", "'")
|
|
|
|
|
- main_link = re.sub(r'\\#', '%23', main_link)
|
|
|
|
|
-
|
|
|
|
|
- find_data = re.findall(r'<span id="(nowiki_[0-9]+)">', main_link)
|
|
|
|
|
- for i in find_data:
|
|
|
|
|
- main_link = main_link.replace('<span id="' + i + '"></span>', end_data[i])
|
|
|
|
|
-
|
|
|
|
|
- find_data = re.findall(r'<span id="(nowiki_[0-9]+)">', other_link)
|
|
|
|
|
- for i in find_data:
|
|
|
|
|
- other_link = other_link.replace('<span id="' + i + '"></span>', end_data[i])
|
|
|
|
|
-
|
|
|
|
|
- return [main_link, other_link]
|
|
|
|
|
-
|
|
|
|
|
-def table_parser(data, cel_data, cel_num, start_data, num = 0, cel_color = {}):
|
|
|
|
|
- table_class = 'class="'
|
|
|
|
|
- div_style = 'style="'
|
|
|
|
|
- all_table = 'style="'
|
|
|
|
|
- cel_style = 'style="'
|
|
|
|
|
- row_style = 'style="'
|
|
|
|
|
- row = ''
|
|
|
|
|
- cel = 'colspan="' + str(round(len(start_data) / 2)) + '"'
|
|
|
|
|
-
|
|
|
|
|
- if not cel_num in cel_color:
|
|
|
|
|
- cel_color[cel_num] = ''
|
|
|
|
|
-
|
|
|
|
|
- cel_style += cel_color[cel_num]
|
|
|
|
|
-
|
|
|
|
|
- if num == 0:
|
|
|
|
|
- if re.search(r'^ ', cel_data) and re.search(r' $', cel_data):
|
|
|
|
|
- cel_style += 'text-align: center;'
|
|
|
|
|
- elif re.search(r'^ ', cel_data):
|
|
|
|
|
- cel_style += 'text-align: right;'
|
|
|
|
|
- elif re.search(r' $', cel_data):
|
|
|
|
|
- cel_style += 'text-align: left;'
|
|
|
|
|
-
|
|
|
|
|
- table_state = re.findall(r'<((?:(?!>).)+)>', data)
|
|
|
|
|
- for in_state in table_state:
|
|
|
|
|
- if re.search(r"^table ?width=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^table ?width=', '', in_state)
|
|
|
|
|
- div_style += 'width: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
- all_table += 'width: 100%;'
|
|
|
|
|
- elif re.search(r"^table ?height=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^table ?height=', '', in_state)
|
|
|
|
|
- div_style += 'height: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^table ?align=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^table ?align=', '', in_state)
|
|
|
|
|
- if table_data == 'right':
|
|
|
|
|
- div_style += 'float: right;'
|
|
|
|
|
- elif table_data == 'center':
|
|
|
|
|
- all_table += 'margin: auto;'
|
|
|
|
|
- elif re.search(r"^table ?textalign=([^=]+)$", in_state):
|
|
|
|
|
- num = 1
|
|
|
|
|
- table_data = re.sub(r'^table ?textalign=', '', in_state)
|
|
|
|
|
- if table_data == 'right':
|
|
|
|
|
- all_table += 'text-align: right;'
|
|
|
|
|
- elif table_data == 'center':
|
|
|
|
|
- all_table += 'text-align: center;'
|
|
|
|
|
- elif re.search(r"^row ?textalign=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^row ?textalign=', '', in_state)
|
|
|
|
|
- if table_data == 'right':
|
|
|
|
|
- row_style += 'text-align: right;'
|
|
|
|
|
- elif table_data == 'center':
|
|
|
|
|
- row_style += 'text-align: center;'
|
|
|
|
|
- else:
|
|
|
|
|
- row_style += 'text-align: left;'
|
|
|
|
|
- elif re.search(r'^-([0-9]+)$', in_state):
|
|
|
|
|
- cel = 'colspan="' + re.sub(r'^-', '', in_state) + '"'
|
|
|
|
|
- elif re.search(r"^(\^|v)?\|([^|]+)$", in_state):
|
|
|
|
|
- if re.search(r'^\^', in_state):
|
|
|
|
|
- cel_style += 'vertical-align: top;'
|
|
|
|
|
- elif re.search(r'^v', in_state):
|
|
|
|
|
- cel_style += 'vertical-align: bottom;'
|
|
|
|
|
-
|
|
|
|
|
- row = 'rowspan="' + re.sub(r'^(\^|v)?\|', '', in_state) + '"'
|
|
|
|
|
- elif re.search(r"^row ?bgcolor=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^row ?bgcolor=', '', in_state)
|
|
|
|
|
- row_style += 'background: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^row ?color=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^row ?color=', '', in_state)
|
|
|
|
|
- row_style += 'color: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^table ?bordercolor=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^table ?bordercolor=', '', in_state)
|
|
|
|
|
- all_table += 'border: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ' 2px solid;'
|
|
|
|
|
- elif re.search(r"^table ?bgcolor=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^table ?bgcolor=', '', in_state)
|
|
|
|
|
- all_table += 'background: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^table ?color=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^table ?color=', '', in_state)
|
|
|
|
|
- all_table += 'color: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^col ?bgcolor=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^col ?bgcolor=', '', in_state)
|
|
|
|
|
- table_data = (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data)
|
|
|
|
|
- cel_color[cel_num] += 'background: ' + table_data + ';'
|
|
|
|
|
- cel_style += 'background: ' + table_data + ';'
|
|
|
|
|
- elif re.search(r"^col ?color=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^col ?color=', '', in_state)
|
|
|
|
|
- table_data = (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data)
|
|
|
|
|
- cel_color[cel_num] += 'color: ' + table_data + ';'
|
|
|
|
|
- cel_style += 'color: ' + table_data + ';'
|
|
|
|
|
- elif re.search(r"^(bgcolor=([^=]+)|#(?:[0-9a-f-A-F]{3}){1,2}|\w+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^bgcolor=', '', in_state)
|
|
|
|
|
- cel_style += 'background: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^color=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^color=', '', in_state)
|
|
|
|
|
- cel_style += 'color: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^width=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^width=', '', in_state)
|
|
|
|
|
- cel_style += 'width: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r"^height=([^=]+)$", in_state):
|
|
|
|
|
- table_data = re.sub(r'^height=', '', in_state)
|
|
|
|
|
- cel_style += 'height: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
- elif re.search(r'^\(|:|\)$', in_state):
|
|
|
|
|
- if in_state == '(':
|
|
|
|
|
- cel_style += 'text-align: right;'
|
|
|
|
|
- elif in_state == ':':
|
|
|
|
|
- cel_style += 'text-align: center;'
|
|
|
|
|
- else:
|
|
|
|
|
- cel_style += 'text-align: left;'
|
|
|
|
|
- elif re.search(r"^table ?class=([^=]+)$", in_state):
|
|
|
|
|
- table_class += re.sub(r"^table ?class=", '', in_state)
|
|
|
|
|
-
|
|
|
|
|
- div_style += '"'
|
|
|
|
|
- all_table += '"'
|
|
|
|
|
- cel_style += '"'
|
|
|
|
|
- row_style += '"'
|
|
|
|
|
- table_class += '"'
|
|
|
|
|
-
|
|
|
|
|
- return [all_table, row_style, cel_style, row, cel, table_class, num, div_style, cel_color]
|
|
|
|
|
-
|
|
|
|
|
-def table_start(data):
|
|
|
|
|
- data = re.sub(r'\n( +)\|\|', '\n||', data)
|
|
|
|
|
- data = re.sub(r'\|\|( +)\n', '||\n', data)
|
|
|
|
|
- data = re.sub(r'(\|\|)+\n', '||\n', data)
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- cel_num = 0
|
|
|
|
|
- table_num = 0
|
|
|
|
|
- table_end = ''
|
|
|
|
|
- cel_color = {}
|
|
|
|
|
-
|
|
|
|
|
- table = re.search(r'\n((?:(?:(?:(?:\|\||\|[^|]+\|)+(?:(?:(?!\|\|).\n*)*))+)\|\|(?:\n)?)+)', data)
|
|
|
|
|
- if table:
|
|
|
|
|
- table = re.sub(r'(\|\|)+\n', '||\n', table.group(1))
|
|
|
|
|
-
|
|
|
|
|
- table_caption = re.search(r'^\|([^|]+)\|', table)
|
|
|
|
|
- if table_caption:
|
|
|
|
|
- table_caption = '<caption>' + table_caption.group(1) + '</caption>'
|
|
|
|
|
-
|
|
|
|
|
- table = re.sub(r'^\|([^|]+)\|', '||', table)
|
|
|
|
|
- else:
|
|
|
|
|
- table_caption = ''
|
|
|
|
|
-
|
|
|
|
|
- table = '\n' + table
|
|
|
|
|
-
|
|
|
|
|
- table_cel = re.findall(r'(\n(?:(?:\|\|)+)|\|\|\n(?:(?:\|\|)+)|(?:(?:\|\|)+))((?:(?:(?!\n|\|\|).)+\n*)+)', table)
|
|
|
|
|
- for i in table_cel:
|
|
|
|
|
- cel_plus = re.search(r'^((?:<(?:(?:(?!>).)*)>)+)', i[1])
|
|
|
|
|
- cel_plus = cel_plus.group(1) if cel_plus else ''
|
|
|
|
|
- cel_data = re.sub(r'^((?:<(?:(?:(?!>).)*)>)+)', '', i[1])
|
|
|
|
|
-
|
|
|
|
|
- if re.search(r'^\n', i[0]):
|
|
|
|
|
- cel_num = 1
|
|
|
|
|
-
|
|
|
|
|
- cel_plus = table_parser(
|
|
|
|
|
- cel_plus,
|
|
|
|
|
- cel_data,
|
|
|
|
|
- cel_num,
|
|
|
|
|
- re.sub(r'^\n', '', i[0]),
|
|
|
|
|
- table_num,
|
|
|
|
|
- cel_color
|
|
|
|
|
- )
|
|
|
|
|
- cel_color = cel_plus[8]
|
|
|
|
|
- table_num = cel_plus[6]
|
|
|
|
|
-
|
|
|
|
|
- table_end += '' + \
|
|
|
|
|
- '<div class="table_safe" ' + cel_plus[7] + '>' + \
|
|
|
|
|
- '<table ' + cel_plus[5] + ' ' + cel_plus[0] + '>' + \
|
|
|
|
|
- table_caption + \
|
|
|
|
|
- '<tr ' + cel_plus[1] + '>' + \
|
|
|
|
|
- '<td ' + cel_plus[2] + ' ' + cel_plus[3] + ' ' + cel_plus[4] + '>' + \
|
|
|
|
|
- cel_data
|
|
|
|
|
-
|
|
|
|
|
- elif re.search(r'\n', i[0]):
|
|
|
|
|
- cel_num = 1
|
|
|
|
|
-
|
|
|
|
|
- cel_plus = table_parser(
|
|
|
|
|
- cel_plus,
|
|
|
|
|
- cel_data,
|
|
|
|
|
- cel_num,
|
|
|
|
|
- re.sub(r'^\|\|\n', '', i[0]),
|
|
|
|
|
- table_num,
|
|
|
|
|
- cel_color
|
|
|
|
|
- )
|
|
|
|
|
- cel_color = cel_plus[8]
|
|
|
|
|
-
|
|
|
|
|
- table_end += '' + \
|
|
|
|
|
- '</td>' + \
|
|
|
|
|
- '</tr>' + \
|
|
|
|
|
- '<tr ' + cel_plus[1] + '>' + \
|
|
|
|
|
- '<td ' + cel_plus[2] + ' ' + cel_plus[3] + ' ' + cel_plus[4] + '>' + \
|
|
|
|
|
- cel_data
|
|
|
|
|
- else:
|
|
|
|
|
- cel_num += 1
|
|
|
|
|
-
|
|
|
|
|
- cel_plus = table_parser(
|
|
|
|
|
- cel_plus,
|
|
|
|
|
- cel_data,
|
|
|
|
|
- cel_num,
|
|
|
|
|
- re.sub(r'^\|\|\n', '', i[0]),
|
|
|
|
|
- table_num,
|
|
|
|
|
- cel_color
|
|
|
|
|
- )
|
|
|
|
|
- cel_color = cel_plus[8]
|
|
|
|
|
-
|
|
|
|
|
- table_end += '' + \
|
|
|
|
|
- '</td>' + \
|
|
|
|
|
- '<td ' + cel_plus[2] + ' ' + cel_plus[3] + ' ' + cel_plus[4] + '>' + \
|
|
|
|
|
- cel_data
|
|
|
|
|
-
|
|
|
|
|
- table_end += '</td></tr></table></div>'
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\n((?:(?:(?:(?:\|\||\|[^|]+\|)+(?:(?:(?!\|\|).\n*)*))+)\|\|(?:\n)?)+)', '\n' + table_end + '\n', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- return data
|
|
|
|
|
-
|
|
|
|
|
-def middle_parser(data):
|
|
|
|
|
- global end_data
|
|
|
|
|
- global plus_data
|
|
|
|
|
- global nowiki_num
|
|
|
|
|
- global include_name
|
|
|
|
|
-
|
|
|
|
|
- middle_stack = 0
|
|
|
|
|
- middle_list = []
|
|
|
|
|
- middle_num = 0
|
|
|
|
|
-
|
|
|
|
|
- html_num = 0
|
|
|
|
|
- syntax_num = 0
|
|
|
|
|
- folding_num = 0
|
|
|
|
|
-
|
|
|
|
|
- middle_re = re.compile(r'(?:{{{((?:(?:(?! |{{{|}}}|<).)*) ?)|(}}}))')
|
|
|
|
|
- middle_all_data = middle_re.findall(data)
|
|
|
|
|
- for middle_data in middle_all_data:
|
|
|
|
|
- if not middle_data[1]:
|
|
|
|
|
- if middle_stack > 0:
|
|
|
|
|
- middle_stack += 1
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'(?:{{{((?:(?! |{{{|}}}|<).)*)(?P<in> ?)|(}}}))', '<middle_start>' + middle_data[0] + '\g<in>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- if re.search(r'^(#|@|\+|\-)', middle_data[0]) and not re.search(r'^(#|@|\+|\-){2}|(#|@|\+|\-)\\', middle_data[0]):
|
|
|
|
|
- if re.search(r'^(#(?:[0-9a-f-A-F]{3}){1,2})', middle_data[0]):
|
|
|
|
|
- middle_search = re.search(r'^(#(?:[0-9a-f-A-F]{3}){1,2})', middle_data[0])
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span style="color: ' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
- elif re.search(r'^(?:#(\w+))', middle_data[0]):
|
|
|
|
|
- middle_search = re.search(r'^(?:#(\w+))', middle_data[0])
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span style="color: ' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
- elif re.search(r'^(?:@((?:[0-9a-f-A-F]{3}){1,2}))', middle_data[0]):
|
|
|
|
|
- middle_search = re.search(r'^(?:@((?:[0-9a-f-A-F]{3}){1,2}))', middle_data[0])
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span style="background: #' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
- elif re.search(r'^(?:@(\w+))', middle_data[0]):
|
|
|
|
|
- middle_search = re.search(r'^(?:@(\w+))', middle_data[0])
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span style="background: ' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
- elif re.search(r'^(\+|-)([1-5])', middle_data[0]):
|
|
|
|
|
- middle_search = re.search(r'^(\+|-)([1-5])', middle_data[0])
|
|
|
|
|
- middle_search = middle_search.groups()
|
|
|
|
|
- if middle_search[0] == '+':
|
|
|
|
|
- font_size = str(int(middle_search[1]) * 20 + 100)
|
|
|
|
|
- else:
|
|
|
|
|
- font_size = str(100 - int(middle_search[1]) * 10)
|
|
|
|
|
-
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span style="font-size: ' + font_size + '%;">', data, 1)
|
|
|
|
|
- elif re.search(r'^#!wiki', middle_data[0]):
|
|
|
|
|
- middle_data_2 = re.search(r'{{{#!wiki(?: style=(?:"|')((?:(?!"|').)*)(?:"|'))?(?: *)\n?', data)
|
|
|
|
|
- if middle_data_2:
|
|
|
|
|
- middle_data_2 = middle_data_2.groups()
|
|
|
|
|
- else:
|
|
|
|
|
- middle_data_2 = ['']
|
|
|
|
|
-
|
|
|
|
|
- middle_list += ['div_1']
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '{{{#!wiki(?: style=(?:"|')((?:(?!"|').)*)(?:"|'))?(?: *)\n?',
|
|
|
|
|
- '<div id="wiki_div" style="' + str(middle_data_2[0] if middle_data_2[0] else '') + '">',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- elif re.search(r'^#!syntax', middle_data[0]):
|
|
|
|
|
- middle_data_2 = re.search(r'{{{#!syntax ((?:(?!\n).)+)\n?', data)
|
|
|
|
|
- if middle_data_2:
|
|
|
|
|
- middle_data_2 = middle_data_2.groups()
|
|
|
|
|
- else:
|
|
|
|
|
- middle_data_2 = ['python']
|
|
|
|
|
-
|
|
|
|
|
- if syntax_num == 0:
|
|
|
|
|
- plus_data += 'hljs.initHighlightingOnLoad();\n'
|
|
|
|
|
-
|
|
|
|
|
- syntax_num = 1
|
|
|
|
|
-
|
|
|
|
|
- middle_list += ['pre']
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '{{{#!syntax ?((?:(?!\n).)*)\n?',
|
|
|
|
|
- '<pre id="syntax"><code class="' + middle_data_2[0] + '">',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- elif re.search(r'^#!folding', middle_data[0]):
|
|
|
|
|
- middle_list += ['2div']
|
|
|
|
|
-
|
|
|
|
|
- folding_data = re.search(r'{{{#!folding ?((?:(?!\n).)*)\n?', data)
|
|
|
|
|
- if folding_data:
|
|
|
|
|
- folding_data = folding_data.groups()
|
|
|
|
|
- else:
|
|
|
|
|
- folding_data = ['Test']
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '{{{#!folding ?((?:(?!\n).)*)\n?', '' + \
|
|
|
|
|
- '<div>' + \
|
|
|
|
|
- str(folding_data[0]) + ' ' + \
|
|
|
|
|
- '<div style="display: inline-block;">' + \
|
|
|
|
|
- '<a href="javascript:void(0);" onclick="do_open_folding(\'' + include_name + 'folding_' + str(folding_num) + '\', this);">' + \
|
|
|
|
|
- '(+)' + \
|
|
|
|
|
- '</a>' + \
|
|
|
|
|
- '</div_2>' + \
|
|
|
|
|
- '<div id="' + include_name + 'folding_' + str(folding_num) + '" style="display: none;">' + \
|
|
|
|
|
- '<div id="wiki_div" style="">',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
-
|
|
|
|
|
- folding_num += 1
|
|
|
|
|
- elif re.search(r'^#!html', middle_data[0]):
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- html_num += 1
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span id="' + include_name + 'render_contect_' + str(html_num) + '">', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- middle_list += ['span']
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<span>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- middle_list += ['code']
|
|
|
|
|
-
|
|
|
|
|
- middle_stack += 1
|
|
|
|
|
-
|
|
|
|
|
- data = middle_re.sub('<code>' + middle_data[0].replace('\\', '\\\\'), data, 1)
|
|
|
|
|
-
|
|
|
|
|
- middle_num += 1
|
|
|
|
|
- else:
|
|
|
|
|
- if middle_list == []:
|
|
|
|
|
- data = middle_re.sub('<middle_end>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- if middle_stack > 0:
|
|
|
|
|
- middle_stack -= 1
|
|
|
|
|
-
|
|
|
|
|
- if middle_stack > 0:
|
|
|
|
|
- data = middle_re.sub('<middle_end>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- if middle_num > 0:
|
|
|
|
|
- middle_num -= 1
|
|
|
|
|
-
|
|
|
|
|
- if middle_list[middle_num] == '2div':
|
|
|
|
|
- data = middle_re.sub('</div_1></div_2></div_2>', data, 1)
|
|
|
|
|
- elif middle_list[middle_num] == 'pre':
|
|
|
|
|
- data = middle_re.sub('</code></pre>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- data = middle_re.sub('</' + middle_list[middle_num] + '>', data, 1)
|
|
|
|
|
-
|
|
|
|
|
- del(middle_list[middle_num])
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- if middle_stack == 0:
|
|
|
|
|
- break
|
|
|
|
|
- else:
|
|
|
|
|
- if middle_list == []:
|
|
|
|
|
- data += '<middle_end>'
|
|
|
|
|
- else:
|
|
|
|
|
- if middle_stack > 0:
|
|
|
|
|
- middle_stack -= 1
|
|
|
|
|
-
|
|
|
|
|
- if middle_stack > 0:
|
|
|
|
|
- data += '<middle_end>'
|
|
|
|
|
- else:
|
|
|
|
|
- if middle_num > 0:
|
|
|
|
|
- middle_num -= 1
|
|
|
|
|
-
|
|
|
|
|
- if middle_list[middle_num] == '2div':
|
|
|
|
|
- data += '</div_1></div_2></div_2>'
|
|
|
|
|
- elif middle_list[middle_num] == 'pre':
|
|
|
|
|
- data += '</code></pre>'
|
|
|
|
|
- else:
|
|
|
|
|
- data += '</' + middle_list[middle_num] + '>'
|
|
|
|
|
-
|
|
|
|
|
- del(middle_list[middle_num])
|
|
|
|
|
-
|
|
|
|
|
- data = data.replace('<middle_start>', '{{{')
|
|
|
|
|
- data = data.replace('<middle_end>', '}}}')
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- nowiki_data = re.search(r'<code>((?:(?:(?!<\/code>).)*\n*)*)<\/code>', data)
|
|
|
|
|
- if nowiki_data:
|
|
|
|
|
- nowiki_data = nowiki_data.groups()
|
|
|
|
|
-
|
|
|
|
|
- nowiki_num += 1
|
|
|
|
|
- end_data[include_name + 'nowiki_' + str(nowiki_num)] = nowiki_data[0]
|
|
|
|
|
- plus_data += '' + \
|
|
|
|
|
- 'if(document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '")) { ' + \
|
|
|
|
|
- 'document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '").innerHTML = "' + nowiki_js(nowiki_data[0]) + '"; ' + \
|
|
|
|
|
- '}' + \
|
|
|
|
|
- '\n' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '<code>((?:(?:(?!<\/code>).)*\n*)*)<\/code>',
|
|
|
|
|
- '<span id="' + include_name + 'nowiki_' + str(nowiki_num) + '"></span>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- syntax_data = re.search(r'<code class="((?:(?!"|>|<).)+)">((?:\n*(?:(?:(?!<\/code>|<span id="nowiki_).)+)\n*)+)<\/code>', data)
|
|
|
|
|
- if syntax_data:
|
|
|
|
|
- syntax_data = syntax_data.groups()
|
|
|
|
|
-
|
|
|
|
|
- nowiki_num += 1
|
|
|
|
|
- end_data[include_name + 'nowiki_' + str(nowiki_num)] = syntax_data[1]
|
|
|
|
|
- plus_data += '' + \
|
|
|
|
|
- 'if(document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '")) { ' + \
|
|
|
|
|
- 'document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '").innerHTML = "' + nowiki_js(syntax_data[1]) + '"; ' + \
|
|
|
|
|
- '}' + \
|
|
|
|
|
- '\n' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '<code class="((?:(?!"|>|<).)+)">((?:\n*(?:(?:(?!<\/code>|<span id="syntax_).)+)\n*)+)<\/code>',
|
|
|
|
|
- '<code class="' + syntax_data[0] + '"><span id="' + include_name + 'nowiki_' + str(nowiki_num) + '"></span></code>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- return data
|
|
|
|
|
-
|
|
|
|
|
-def namumark(conn, data, title, include_num):
|
|
|
|
|
- curs = conn.cursor()
|
|
|
|
|
-
|
|
|
|
|
- global plus_data
|
|
|
|
|
- global end_data
|
|
|
|
|
- global nowiki_num
|
|
|
|
|
- global include_name
|
|
|
|
|
-
|
|
|
|
|
- nowiki_num = 0
|
|
|
|
|
- data = '\n' + data + '\n'
|
|
|
|
|
- include_name = include_num + '_' if include_num else ''
|
|
|
|
|
- plus_data = '' + \
|
|
|
|
|
- 'get_link_state("' + include_name + '");\n' + \
|
|
|
|
|
- 'get_file_state("' + include_name + '");\n' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- backlink = []
|
|
|
|
|
- end_data = {}
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'<math>(?P<in>(?:(?!<\/math>).)+)<\/math>', '[math(\g<in>)]', data)
|
|
|
|
|
-
|
|
|
|
|
- data = html.escape(data)
|
|
|
|
|
- data = data.replace('\r\n', '\n')
|
|
|
|
|
-
|
|
|
|
|
- math_re = re.compile(r'\[math\(((?:(?!\)\]).)+)\)\]', re.I)
|
|
|
|
|
- while 1:
|
|
|
|
|
- math = math_re.search(data)
|
|
|
|
|
- if math:
|
|
|
|
|
- math = math.group(1)
|
|
|
|
|
- math = math.replace('{', '<math_mid_1>')
|
|
|
|
|
- math = math.replace('}', '<math_mid_2>')
|
|
|
|
|
- math = math.replace('\\', '<math_slash>')
|
|
|
|
|
-
|
|
|
|
|
- data = math_re.sub('<math>' + math + '</math>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = data.replace('\\{', '<break_middle>')
|
|
|
|
|
- data = middle_parser(data)
|
|
|
|
|
- data = data.replace('<break_middle>', '\\{')
|
|
|
|
|
-
|
|
|
|
|
- first = 0
|
|
|
|
|
- math_re = re.compile(r'<math>((?:(?!<\/math>).)+)<\/math>', re.I)
|
|
|
|
|
- while 1:
|
|
|
|
|
- math = math_re.search(data)
|
|
|
|
|
- if math:
|
|
|
|
|
- math = math.group(1)
|
|
|
|
|
- math = math.replace('<math_mid_1>', '{')
|
|
|
|
|
- math = math.replace('<math_mid_2>', '}')
|
|
|
|
|
- math = math.replace('<math_slash>', '\\')
|
|
|
|
|
-
|
|
|
|
|
- first += 1
|
|
|
|
|
- data = math_re.sub('<span id="math_' + str(first) + '"></span>', data, 1)
|
|
|
|
|
-
|
|
|
|
|
- plus_data += '' + \
|
|
|
|
|
- 'try {' + \
|
|
|
|
|
- 'katex.render(' + \
|
|
|
|
|
- '"' + nowiki_js(html.unescape(math)) + '",' + \
|
|
|
|
|
- 'document.getElementById(\"' + include_name + 'math_' + str(first) + '\")' + \
|
|
|
|
|
- ');' + \
|
|
|
|
|
- '} catch {' + \
|
|
|
|
|
- 'document.getElementById(\"' + include_name + 'math_' + str(first) + '\").innerHTML = "<span style=\'color: red;\'>' + nowiki_js(math) + '</span>";' + \
|
|
|
|
|
- '}\n' + \
|
|
|
|
|
- ''
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- num = 0
|
|
|
|
|
- while 1:
|
|
|
|
|
- one_nowiki = re.search(r'(?:\\)(.)', data)
|
|
|
|
|
- if one_nowiki:
|
|
|
|
|
- one_nowiki = one_nowiki.groups()
|
|
|
|
|
-
|
|
|
|
|
- nowiki_num += 1
|
|
|
|
|
- end_data[include_name + 'nowiki_' + str(nowiki_num)] = one_nowiki[0]
|
|
|
|
|
- plus_data += '' + \
|
|
|
|
|
- 'if(document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '")) { ' + \
|
|
|
|
|
- 'document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '").innerHTML = "' + nowiki_js(one_nowiki[0]) + '"; ' + \
|
|
|
|
|
- '}' + \
|
|
|
|
|
- '\n' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'(?:\\)(.)', '<span id="' + include_name + 'nowiki_' + str(nowiki_num) + '"></span>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- include_re = re.compile(r'\[include\(((?:(?!\)\]).)+)\)\]', re.I)
|
|
|
|
|
- i = 0
|
|
|
|
|
- while 1:
|
|
|
|
|
- i += 1
|
|
|
|
|
-
|
|
|
|
|
- include = include_re.search(data)
|
|
|
|
|
- if include:
|
|
|
|
|
- include = include.group(1)
|
|
|
|
|
-
|
|
|
|
|
- include_data = re.search(r'^((?:(?!,).)+)', include)
|
|
|
|
|
- if include_data:
|
|
|
|
|
- include_data = include_data.group(1)
|
|
|
|
|
- else:
|
|
|
|
|
- include_data = 'Test'
|
|
|
|
|
-
|
|
|
|
|
- include_link = include_data
|
|
|
|
|
- backlink += [[title, include_link, 'include']]
|
|
|
|
|
-
|
|
|
|
|
- data = include_re.sub('' + \
|
|
|
|
|
- '<a id="' + include_name + 'include_link" class="include_' + str(i) + '" href="/w/' + tool.url_pas(include_link) + '">(' + include_link + ')</a>' + \
|
|
|
|
|
- '<div id="' + include_name + 'include_' + str(i) + '"></div>' + \
|
|
|
|
|
- '', data, 1)
|
|
|
|
|
-
|
|
|
|
|
- include_plus_data = []
|
|
|
|
|
- while 1:
|
|
|
|
|
- include_plus = re.search(r', ?((?:(?!=).)+)=((?:(?!,).)+)', include)
|
|
|
|
|
- if include_plus:
|
|
|
|
|
- include_plus = include_plus.groups()
|
|
|
|
|
-
|
|
|
|
|
- include_data_set = include_plus[1]
|
|
|
|
|
- find_data = re.findall(r'<span id="(nowiki_[0-9]+)">', include_data_set)
|
|
|
|
|
- for j in find_data:
|
|
|
|
|
- include_data_set = include_data_set.replace('<span id="' + j + '"></span>', end_data[j])
|
|
|
|
|
-
|
|
|
|
|
- include_plus_data += [[include_plus[0], include_data_set]]
|
|
|
|
|
-
|
|
|
|
|
- include = re.sub(r', ?((?:(?!=).)+)=((?:(?!,).)+)', '', include, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- plus_data += 'load_include("' + include_link + '", "' + include_name + 'include_' + str(i) + '", ' + str(include_plus_data) + ');\n'
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\r\n', '\n', data)
|
|
|
|
|
- data = re.sub(r'&', '&', data)
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\n##(((?!\n).)+)', '', data)
|
|
|
|
|
- data = re.sub(r'<div id="wiki_div" style="">\n', '<div id="wiki_div" style="">', data)
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- wiki_table_data = re.search(r'<div id="wiki_div" ((?:(?!>).)+)>((?:(?!<div id="wiki_div"|<\/div_1>).\n*)+)<\/div_1>', data)
|
|
|
|
|
- if wiki_table_data:
|
|
|
|
|
- wiki_table_data = wiki_table_data.groups()
|
|
|
|
|
- if re.search(r'\|\|', wiki_table_data[1]):
|
|
|
|
|
- end_parser = re.sub(r'\n$', '', re.sub(r'^\n', '', table_start('\n' + wiki_table_data[1] + '\n')))
|
|
|
|
|
- else:
|
|
|
|
|
- end_parser = wiki_table_data[1]
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '<div id="wiki_div" ((?:(?!>).)+)>((?:(?!<div id="wiki_div"|<\/div_1>).\n*)+)<\/div_1>',
|
|
|
|
|
- '<div ' + wiki_table_data[0] + '>' + end_parser + '</div_2>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'<\/div_2>', '</div>', data)
|
|
|
|
|
- data = re.sub(r'<\/td>', '</td_1>', data)
|
|
|
|
|
-
|
|
|
|
|
- data += '\n'
|
|
|
|
|
- data = data.replace('\\', '\')
|
|
|
|
|
-
|
|
|
|
|
- redirect_re = re.compile(r'\n#(?:redirect|넘겨주기) ((?:(?!\n).)+)\n', re.I)
|
|
|
|
|
- redirect = redirect_re.search(data)
|
|
|
|
|
- if redirect:
|
|
|
|
|
- redirect = redirect.group(1)
|
|
|
|
|
-
|
|
|
|
|
- return_link = link_fix(redirect)
|
|
|
|
|
- main_link = html.unescape(return_link[0])
|
|
|
|
|
- other_link = return_link[1]
|
|
|
|
|
-
|
|
|
|
|
- backlink += [[title, main_link, 'redirect']]
|
|
|
|
|
-
|
|
|
|
|
- data = redirect_re.sub(
|
|
|
|
|
- '\n' + \
|
|
|
|
|
- '<ul>' + \
|
|
|
|
|
- '<li>' + \
|
|
|
|
|
- '<a id="go_redirect_link" href="/w/' + tool.url_pas(main_link) + other_link + '">' + main_link + other_link + '</a>' + \
|
|
|
|
|
- '</li>' + \
|
|
|
|
|
- '</ul>' + \
|
|
|
|
|
- '\n',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
-
|
|
|
|
|
- no_toc_re = re.compile(r'\[(?:목차|toc)\((?:no)\)\]\n', re.I)
|
|
|
|
|
- toc_re = re.compile(r'\[(?:목차|toc)\]', re.I)
|
|
|
|
|
- if not no_toc_re.search(data):
|
|
|
|
|
- if not toc_re.search(data):
|
|
|
|
|
- data = re.sub(r'\n(?P<in>={1,6}) ?(?P<out>(?:(?!=).)+) ?={1,6}\n', '\n[toc]\n\g<in> \g<out> \g<in>\n', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- data = no_toc_re.sub('', data)
|
|
|
|
|
-
|
|
|
|
|
- data = '<div class="all_in_data" id="in_data_0">' + data
|
|
|
|
|
-
|
|
|
|
|
- toc_full = 0
|
|
|
|
|
- toc_top_stack = 6
|
|
|
|
|
- toc_stack = [0, 0, 0, 0, 0, 0]
|
|
|
|
|
- edit_number = 0
|
|
|
|
|
- toc_data = '<div id="toc"><span id="toc_title">TOC</span>\n\n'
|
|
|
|
|
- while 1:
|
|
|
|
|
- toc = re.search(r'\n(={1,6}) ?((?:(?!\n).)+) ?(?:={1,6})\n', data)
|
|
|
|
|
- if toc:
|
|
|
|
|
- toc = toc.groups()
|
|
|
|
|
-
|
|
|
|
|
- toc_number = len(toc[0])
|
|
|
|
|
- edit_number += 1
|
|
|
|
|
-
|
|
|
|
|
- if toc_full > toc_number:
|
|
|
|
|
- for i in range(toc_number, 6):
|
|
|
|
|
- toc_stack[i] = 0
|
|
|
|
|
-
|
|
|
|
|
- if toc_top_stack > toc_number:
|
|
|
|
|
- toc_top_stack = toc_number
|
|
|
|
|
-
|
|
|
|
|
- toc_full = toc_number
|
|
|
|
|
- toc_stack[toc_number - 1] += 1
|
|
|
|
|
- toc_number = str(toc_number)
|
|
|
|
|
- all_stack = ''
|
|
|
|
|
-
|
|
|
|
|
- for i in range(0, 6):
|
|
|
|
|
- all_stack += str(toc_stack[i]) + '.'
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- if re.search(r'[^0-9]0\.', all_stack):
|
|
|
|
|
- all_stack = re.sub(r'[^0-9]0\.', '.', all_stack)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- all_stack = re.sub(r'^0\.', '', all_stack)
|
|
|
|
|
- all_stack = re.sub(r'\.$', '', all_stack)
|
|
|
|
|
-
|
|
|
|
|
- new_toc_data = re.sub(r'=*$', '', toc[1])
|
|
|
|
|
- new_toc_data = re.sub(r' +$', '', new_toc_data)
|
|
|
|
|
- if re.search(r'^# ?(?P<in>[^#]+) ?#$', new_toc_data):
|
|
|
|
|
- fol_head = '+'
|
|
|
|
|
-
|
|
|
|
|
- new_toc_data = re.sub(r'^# ?(?P<in>[^#]+) ?#$', '\g<in>', new_toc_data)
|
|
|
|
|
- else:
|
|
|
|
|
- fol_head = '-'
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\n(={1,6}) ?((?:(?!\n).)+) ?\n',
|
|
|
|
|
- '\n' + \
|
|
|
|
|
- '</div>'
|
|
|
|
|
- '<h' + toc_number + ' id="s-' + all_stack + '">' + \
|
|
|
|
|
- '<a href="#toc">' + all_stack + '.</a> ' + new_toc_data + ' ' + \
|
|
|
|
|
- '<span style="font-size: 12px">' + \
|
|
|
|
|
- '<a href="/edit/' + tool.url_pas(title) + '?section=' + str(edit_number) + '">(Edit)</a>' + \
|
|
|
|
|
- ' ' + \
|
|
|
|
|
- '<a href="javascript:void(0);" onclick="do_open_folding(\'in_data_' + all_stack + '\', this);">' + \
|
|
|
|
|
- '(' + fol_head + ')' + \
|
|
|
|
|
- '</a>' + \
|
|
|
|
|
- '</span>' + \
|
|
|
|
|
- '</h' + toc_number + '>' + \
|
|
|
|
|
- '<div class="all_in_data"' + (' style="display: none;"' if fol_head == '+' else '') + ' id="in_data_' + all_stack + '">' + \
|
|
|
|
|
- '\n',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
-
|
|
|
|
|
- toc_main_data = new_toc_data
|
|
|
|
|
- toc_main_data = re.sub(r'\[\*((?:(?! |\]).)*)(?: ((?:(?!(\[\*(?:(?:(?!\]).)+)\]|\])).)+))?\]', '', toc_main_data)
|
|
|
|
|
- toc_main_data = re.sub(r'<span id="math_[0-9]"><\/span>', '(Math)', toc_main_data)
|
|
|
|
|
-
|
|
|
|
|
- toc_data += '' + \
|
|
|
|
|
- '<span style="margin-left: ' + str((toc_full - toc_top_stack) * 10) + 'px;">' + \
|
|
|
|
|
- '<a href="#s-' + all_stack + '">' + all_stack + '.</a> ' + toc_main_data + \
|
|
|
|
|
- '</span>' + \
|
|
|
|
|
- '\n' + \
|
|
|
|
|
- ''
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- toc_data += '</div>'
|
|
|
|
|
- data = toc_re.sub(toc_data, data)
|
|
|
|
|
-
|
|
|
|
|
- now_time = tool.get_time()
|
|
|
|
|
- time_data = re.search(r'^([0-9]{4}-[0-9]{2}-[0-9]{2})', now_time)
|
|
|
|
|
- time = time_data.group(1)
|
|
|
|
|
-
|
|
|
|
|
- macro_re = re.compile(r'\[([^[(]+)\(((?:(?!\[|\)]).)+)\)\]')
|
|
|
|
|
- macro_data = macro_re.findall(data)
|
|
|
|
|
- for i in macro_data:
|
|
|
|
|
- macro_name = i[0].lower()
|
|
|
|
|
- if macro_name == 'youtube' or macro_name == 'kakaotv' or macro_name == 'nicovideo':
|
|
|
|
|
- width = re.search(r', ?width=((?:(?!,).)+)', i[1])
|
|
|
|
|
- if width:
|
|
|
|
|
- video_width = width.group(1)
|
|
|
|
|
- if re.search(r'^[0-9]+$', video_width):
|
|
|
|
|
- video_width += 'px'
|
|
|
|
|
- else:
|
|
|
|
|
- video_width = '560px'
|
|
|
|
|
-
|
|
|
|
|
- height = re.search(r', ?height=((?:(?!,).)+)', i[1])
|
|
|
|
|
- if height:
|
|
|
|
|
- video_height = height.group(1)
|
|
|
|
|
- if re.search(r'^[0-9]+$', video_height):
|
|
|
|
|
- video_height += 'px'
|
|
|
|
|
- else:
|
|
|
|
|
- video_height = '315px'
|
|
|
|
|
-
|
|
|
|
|
- code = re.search(r'^((?:(?!,).)+)', i[1])
|
|
|
|
|
- if code:
|
|
|
|
|
- video_code = code.group(1)
|
|
|
|
|
- else:
|
|
|
|
|
- video_code = ''
|
|
|
|
|
-
|
|
|
|
|
- video_start = ''
|
|
|
|
|
-
|
|
|
|
|
- if macro_name == 'youtube':
|
|
|
|
|
- start = re.search(r', ?(start=(?:(?!,).)+)', i[1])
|
|
|
|
|
- if start:
|
|
|
|
|
- video_start = '?' + start.group(1)
|
|
|
|
|
-
|
|
|
|
|
- video_code = re.sub(r'^https:\/\/www\.youtube\.com\/watch\?v=', '', video_code)
|
|
|
|
|
- video_code = re.sub(r'^https:\/\/youtu\.be\/', '', video_code)
|
|
|
|
|
-
|
|
|
|
|
- video_src = 'https://www.youtube.com/embed/' + video_code
|
|
|
|
|
- elif macro_name == 'kakaotv':
|
|
|
|
|
- video_code = re.sub(r'^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\/', '', video_code)
|
|
|
|
|
- video_code = re.sub(r'^http:\/\/tv\.kakao\.com\/v\/', '', video_code)
|
|
|
|
|
-
|
|
|
|
|
- video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
|
|
|
|
|
- else:
|
|
|
|
|
- video_src = 'https://embed.nicovideo.jp/watch/' + video_code
|
|
|
|
|
-
|
|
|
|
|
- data = macro_re.sub(
|
|
|
|
|
- '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + video_start + '" frameborder="0" allowfullscreen></iframe>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- elif macro_name == 'anchor':
|
|
|
|
|
- data = macro_re.sub('<span id="' + i[1] + '"></span>', data, 1)
|
|
|
|
|
- elif macro_name == 'ruby':
|
|
|
|
|
- ruby_code = re.search(r'^([^,]+)', i[1])
|
|
|
|
|
- if ruby_code:
|
|
|
|
|
- ruby_code = ruby_code.group(1)
|
|
|
|
|
- else:
|
|
|
|
|
- ruby_code = 'Test'
|
|
|
|
|
-
|
|
|
|
|
- ruby_top = re.search(r'ruby=([^,]+)', i[1], flags = re.I)
|
|
|
|
|
- if ruby_top:
|
|
|
|
|
- ruby_top = ruby_top.group(1)
|
|
|
|
|
- else:
|
|
|
|
|
- ruby_top = 'Test'
|
|
|
|
|
-
|
|
|
|
|
- ruby_color = re.search(r'color=([^,]+)', i[1], flags = re.I)
|
|
|
|
|
- if ruby_color:
|
|
|
|
|
- ruby_color = 'color: ' + ruby_color.group(1) + ';'
|
|
|
|
|
- else:
|
|
|
|
|
- ruby_color = ''
|
|
|
|
|
-
|
|
|
|
|
- ruby_data = '' + \
|
|
|
|
|
- '<ruby>' + \
|
|
|
|
|
- ruby_code \
|
|
|
|
|
- + '<rp>(</rp>' + \
|
|
|
|
|
- '<rt style="' + ruby_color + '">' + ruby_top + '</rt>' + \
|
|
|
|
|
- '<rp>)</rp>' + \
|
|
|
|
|
- '</ruby>' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- data = macro_re.sub(ruby_data, data, 1)
|
|
|
|
|
- elif macro_name == 'age' or macro_name == 'dday':
|
|
|
|
|
- try:
|
|
|
|
|
- old = datetime.datetime.strptime(time, '%Y-%m-%d')
|
|
|
|
|
- will = datetime.datetime.strptime(i[1], '%Y-%m-%d')
|
|
|
|
|
-
|
|
|
|
|
- e_data = old - will
|
|
|
|
|
-
|
|
|
|
|
- if macro_name == 'age':
|
|
|
|
|
- data = macro_re.sub(str(int(e_data.days / 365)), data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- if re.search(r'^-', str(e_data.days)):
|
|
|
|
|
- e_day = str(e_data.days)
|
|
|
|
|
- else:
|
|
|
|
|
- e_day = '+' + str(e_data.days)
|
|
|
|
|
-
|
|
|
|
|
- data = macro_re.sub(e_day, data, 1)
|
|
|
|
|
- except:
|
|
|
|
|
- data = macro_re.sub('age-dday-error', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- data = macro_re.sub('<macro_start>' + i[0] + '<macro_middle>' + i[1] + '<macro_end>', data, 1)
|
|
|
|
|
-
|
|
|
|
|
- data = data.replace('<macro_start>', '[')
|
|
|
|
|
- data = data.replace('<macro_middle>', '(')
|
|
|
|
|
- data = data.replace('<macro_end>', ')]')
|
|
|
|
|
-
|
|
|
|
|
- if re.search(r'\[pagecount\]', data, flags = re.I):
|
|
|
|
|
- plus_data += 'page_count();\n'
|
|
|
|
|
- data = re.sub(r'\[pagecount\]', '<span class="all_page_count"></span>', data, flags = re.I)
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\[date\]', now_time, data, flags = re.I)
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- block = re.search(r'(\n(?:> ?(?:(?:(?!\n).)+)?\n)+)', data)
|
|
|
|
|
- if block:
|
|
|
|
|
- block = block.group(1)
|
|
|
|
|
-
|
|
|
|
|
- block = re.sub(r'^\n> ?', '', block)
|
|
|
|
|
- block = re.sub(r'\n> ?', '\n', block)
|
|
|
|
|
- block = re.sub(r'\n$', '', block)
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'(\n(?:> ?(?:(?:(?!\n).)+)?\n)+)', '\n<blockquote>' + block + '</blockquote>\n', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- hr = re.search(r'\n-{4,9}\n', data)
|
|
|
|
|
- if hr:
|
|
|
|
|
- data = re.sub(r'\n-{4,9}\n', '\n<hr>\n', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'(?P<in>\n +\* ?(?:(?:(?!\|\|).)+))\|\|', '\g<in>\n ||', data)
|
|
|
|
|
- data = re.sub(r'(?P<in><div id="folding_(?:[0-9]+)" style="display: none;"><div style="">|<blockquote>)(?P<out> )?\* ', '\g<in>\n\g<out>* ', data)
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- li = re.search(r'(\n(?:(?: *)\* ?(?:(?:(?!\n).)+)\n)+)', data)
|
|
|
|
|
- if li:
|
|
|
|
|
- li = li.group(1)
|
|
|
|
|
- while 1:
|
|
|
|
|
- sub_li = re.search(r'\n(?:( *)\* ?((?:(?!\n).)+))', li)
|
|
|
|
|
- if sub_li:
|
|
|
|
|
- sub_li = sub_li.groups()
|
|
|
|
|
-
|
|
|
|
|
- if len(sub_li[0]) == 0:
|
|
|
|
|
- margin = 20
|
|
|
|
|
- else:
|
|
|
|
|
- margin = len(sub_li[0]) * 20
|
|
|
|
|
-
|
|
|
|
|
- li = re.sub(r'\n(?:( *)\* ?((?:(?!\n).)+))', '<li style="margin-left: ' + str(margin) + 'px;">' + sub_li[1] + '</li>', li, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'(\n(?:(?: *)\* ?(?:(?:(?!\n).)+)\n)+)', '\n\n<ul>' + li + '</ul>\n', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'<\/ul>\n \|\|', '</ul>||', data)
|
|
|
|
|
- data = re.sub(r'\|\|</blockquote>', '</blockquote>||', data)
|
|
|
|
|
-
|
|
|
|
|
- while 1:
|
|
|
|
|
- indent = re.search(r'\n( +)', data)
|
|
|
|
|
- if indent:
|
|
|
|
|
- indent = len(indent.group(1))
|
|
|
|
|
-
|
|
|
|
|
- margin = '<span style="margin-left: 20px;"></span>' * indent
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\n( +)', '\n' + margin, data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = table_start(data)
|
|
|
|
|
-
|
|
|
|
|
- category = ''
|
|
|
|
|
- link_re = re.compile('\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]')
|
|
|
|
|
- category_re = re.compile(r'^(?:category|분류):', re.I)
|
|
|
|
|
- while 1:
|
|
|
|
|
- link = link_re.search(data)
|
|
|
|
|
- if link:
|
|
|
|
|
- link = link.group(1)
|
|
|
|
|
-
|
|
|
|
|
- link_split = re.search(r'((?:(?!\|).)+)(?:\|((?:(?!\|).)+))', link)
|
|
|
|
|
- if link_split:
|
|
|
|
|
- link_split = link_split.groups()
|
|
|
|
|
-
|
|
|
|
|
- main_link = link_split[0]
|
|
|
|
|
- see_link = link_split[1]
|
|
|
|
|
- else:
|
|
|
|
|
- main_link = link
|
|
|
|
|
- see_link = link
|
|
|
|
|
-
|
|
|
|
|
- if re.search(r'^((?:file|파일)|(?:out|외부)):', main_link):
|
|
|
|
|
- file_style = ''
|
|
|
|
|
-
|
|
|
|
|
- file_width = re.search(r'width=((?:(?!&).)+)', see_link)
|
|
|
|
|
- if file_width:
|
|
|
|
|
- file_width = file_width.group(1)
|
|
|
|
|
- if re.search(r'px$', file_width):
|
|
|
|
|
- file_style += 'width: ' + file_width + ';'
|
|
|
|
|
- else:
|
|
|
|
|
- file_style += 'width: ' + file_width + 'px;'
|
|
|
|
|
-
|
|
|
|
|
- file_height = re.search(r'height=((?:(?!&).)+)', see_link)
|
|
|
|
|
- if file_height:
|
|
|
|
|
- file_height = file_height.group(1)
|
|
|
|
|
- if re.search(r'px$', file_height):
|
|
|
|
|
- file_style += 'height: ' + file_height + ';'
|
|
|
|
|
- else:
|
|
|
|
|
- file_style += 'height: ' + file_height + 'px;'
|
|
|
|
|
-
|
|
|
|
|
- file_align = re.search(r'align=((?:(?!&).)+)', see_link)
|
|
|
|
|
- if file_align:
|
|
|
|
|
- file_align = file_align.group(1)
|
|
|
|
|
- if file_align == 'center':
|
|
|
|
|
- file_align = 'display: block; text-align: center;'
|
|
|
|
|
- else:
|
|
|
|
|
- file_align = 'float: ' + file_align + ';'
|
|
|
|
|
- else:
|
|
|
|
|
- file_align = ''
|
|
|
|
|
-
|
|
|
|
|
- file_color = re.search(r'bgcolor=((?:(?!&).)+)', see_link)
|
|
|
|
|
- if file_color:
|
|
|
|
|
- file_color = 'background: ' + file_color.group(1) + '; display: inline-block;'
|
|
|
|
|
- else:
|
|
|
|
|
- file_color = ''
|
|
|
|
|
-
|
|
|
|
|
- if re.search(r'^(?:out|외부):', main_link):
|
|
|
|
|
- file_src = re.sub(r'^(?:out|외부):', '', main_link)
|
|
|
|
|
-
|
|
|
|
|
- file_alt = main_link
|
|
|
|
|
- exist = 'Yes'
|
|
|
|
|
- else:
|
|
|
|
|
- file_data = re.search(r'^(?:file|파일):((?:(?!\.).)+)\.(.+)$', main_link)
|
|
|
|
|
- if file_data:
|
|
|
|
|
- file_data = file_data.groups()
|
|
|
|
|
- file_name = file_data[0]
|
|
|
|
|
- file_end = file_data[1]
|
|
|
|
|
-
|
|
|
|
|
- if main_link != title:
|
|
|
|
|
- backlink += [[title, main_link, 'file']]
|
|
|
|
|
- else:
|
|
|
|
|
- file_name = 'TEST'
|
|
|
|
|
- file_end = 'jpg'
|
|
|
|
|
-
|
|
|
|
|
- file_src = '/image/' + tool.sha224_replace(file_name) + '.' + file_end
|
|
|
|
|
- file_alt = 'file:' + file_name + '.' + file_end
|
|
|
|
|
- exist = None
|
|
|
|
|
-
|
|
|
|
|
- data = link_re.sub(
|
|
|
|
|
- '<span style="' + file_align + '">' + \
|
|
|
|
|
- '<span style="' + file_color + '"' + \
|
|
|
|
|
- 'class="' + include_name + 'file_finder" ' + \
|
|
|
|
|
- 'under_style="' + file_style + '" ' + \
|
|
|
|
|
- 'under_alt="' + file_alt + '" ' + \
|
|
|
|
|
- 'under_src="' + file_src + '" ' + \
|
|
|
|
|
- 'under_href="' + ("out_link" if exist else '/upload?name=' + tool.url_pas(file_name)) + '">' + \
|
|
|
|
|
- '</span>' + \
|
|
|
|
|
- '</span>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- elif category_re.search(main_link):
|
|
|
|
|
- if category == '':
|
|
|
|
|
- category += '<div id="cate_all"><hr><div id="cate">Category : '
|
|
|
|
|
-
|
|
|
|
|
- main_link = category_re.sub('category:', main_link)
|
|
|
|
|
- link_id = ''
|
|
|
|
|
-
|
|
|
|
|
- curs.execute(tool.db_change("select title from data where title = ?"), [main_link])
|
|
|
|
|
- if re.search(r'#blur', main_link):
|
|
|
|
|
- link_id = ' hidden_link'
|
|
|
|
|
- main_link = main_link.replace('#blur', '')
|
|
|
|
|
- see_link = see_link.replace('#blur', '')
|
|
|
|
|
-
|
|
|
|
|
- backlink += [[title, main_link, 'cat']]
|
|
|
|
|
- category += '<a class="' + include_name + 'link_finder' + link_id + '" href="/w/' + tool.url_pas(main_link) + '">' + category_re.sub('', see_link) + '</a> | '
|
|
|
|
|
-
|
|
|
|
|
- data = link_re.sub('', data, 1)
|
|
|
|
|
- elif re.search(r'^wiki:', main_link):
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
- '<a id="inside" href="/' + tool.url_pas(re.sub('^wiki:', '', main_link)) + '">' + see_link + '</a>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- elif re.search(r'^inter:((?:(?!:).)+):', main_link):
|
|
|
|
|
- inter_data = re.search(r'^inter:((?:(?!:).)+):((?:(?!\]\]|\|).)+)', main_link)
|
|
|
|
|
- inter_data = inter_data.groups()
|
|
|
|
|
-
|
|
|
|
|
- curs.execute(tool.db_change('select link, icon from inter where title = ?'), [inter_data[0]])
|
|
|
|
|
- inter = curs.fetchall()
|
|
|
|
|
- if inter:
|
|
|
|
|
- if inter[0][1] != '':
|
|
|
|
|
- inter_view = inter[0][1]
|
|
|
|
|
- else:
|
|
|
|
|
- inter_view = inter_data[0] + ':'
|
|
|
|
|
-
|
|
|
|
|
- if see_link != main_link:
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
- '<a id="inside" href="' + inter[0][0] + inter_data[1] + '">' + inter_view + see_link + '</a>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
- '<a id="inside" href="' + inter[0][0] + inter_data[1] + '">' + inter_view + inter_data[1] + '</a>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- data = link_re.sub('Not exist', data, 1)
|
|
|
|
|
- elif re.search(r'^(\/(?:.+))$', main_link):
|
|
|
|
|
- under_title = re.search(r'^(\/(?:.+))$', main_link)
|
|
|
|
|
- under_title = under_title.group(1)
|
|
|
|
|
-
|
|
|
|
|
- if see_link != main_link:
|
|
|
|
|
- data = link_re.sub('[[' + title + under_title + '|' + see_link + ']]', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- data = link_re.sub('[[' + title + under_title + ']]', data, 1)
|
|
|
|
|
- elif re.search(r'^http(s)?:\/\/', main_link):
|
|
|
|
|
- data = link_re.sub('<a id="out_link" rel="nofollow" href="' + main_link + '">' + see_link + '</a>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- return_link = link_fix(main_link)
|
|
|
|
|
- main_link = html.unescape(return_link[0])
|
|
|
|
|
- other_link = return_link[1]
|
|
|
|
|
-
|
|
|
|
|
- if re.search(r'^\/', main_link):
|
|
|
|
|
- main_link = re.sub(r'^\/', title + '/', main_link)
|
|
|
|
|
- elif re.search(r'\.\.\/\/', main_link):
|
|
|
|
|
- main_link = re.sub(r'\.\.\/\/', '/', main_link)
|
|
|
|
|
- elif re.search(r'^\.\.\/', main_link):
|
|
|
|
|
- main_link = re.sub(r'^\.\.\/', re.sub(r'(?P<in>.+)\/.*$', '\g<in>', title), main_link)
|
|
|
|
|
-
|
|
|
|
|
- if not re.search(r'^\|', main_link):
|
|
|
|
|
- if main_link != title:
|
|
|
|
|
- if main_link != '':
|
|
|
|
|
- backlink += [[title, main_link, '']]
|
|
|
|
|
-
|
|
|
|
|
- curs.execute(tool.db_change("select title from data where title = ?"), [main_link])
|
|
|
|
|
- if not curs.fetchall():
|
|
|
|
|
- backlink += [[title, main_link, 'no']]
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
- '<a class="' + include_name + 'link_finder" ' + \
|
|
|
|
|
- 'title="' + html.escape(main_link) + other_link + '" ' + \
|
|
|
|
|
- 'href="/w/' + tool.url_pas(main_link) + other_link + '"' + \
|
|
|
|
|
- '>' + see_link + '</a>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
- '<a title="' + other_link + '" href="' + other_link + '">' + see_link + '</a>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- if re.search(r'^#', other_link):
|
|
|
|
|
- data = re.sub(
|
|
|
|
|
- '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
- '<a title="' + other_link + '" href="' + other_link + '">' + other_link + '</a>',
|
|
|
|
|
- data,
|
|
|
|
|
- 1
|
|
|
|
|
- )
|
|
|
|
|
- else:
|
|
|
|
|
- data = link_re.sub('<b>' + see_link + '</b>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- data = link_re.sub('[[' + link + ']]', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- br_re = re.compile(r'\[br\]', re.I)
|
|
|
|
|
- data = br_re.sub('<br>', data)
|
|
|
|
|
-
|
|
|
|
|
- footnote_number = 0
|
|
|
|
|
-
|
|
|
|
|
- footnote_all = []
|
|
|
|
|
- footnote_dict = {}
|
|
|
|
|
- footnote_re = {}
|
|
|
|
|
-
|
|
|
|
|
- footdata_all = '<hr><ul id="footnote_data">'
|
|
|
|
|
-
|
|
|
|
|
- re_footnote = re.compile(r'(?:\[\*((?:(?! |\]).)*)(?: ((?:(?!(?:\[\*|\])).)+))?\]|(\[(?:각주|footnote)\]))')
|
|
|
|
|
- while 1:
|
|
|
|
|
- footnote = re_footnote.search(data)
|
|
|
|
|
- if footnote:
|
|
|
|
|
- footnote_data = footnote.groups()
|
|
|
|
|
- if footnote_data[2]:
|
|
|
|
|
- footnote_all.sort()
|
|
|
|
|
-
|
|
|
|
|
- for footdata in footnote_all:
|
|
|
|
|
- if footdata[2] == 0:
|
|
|
|
|
- footdata_in = ''
|
|
|
|
|
- else:
|
|
|
|
|
- footdata_in = footdata[2]
|
|
|
|
|
-
|
|
|
|
|
- footdata_all += '' + \
|
|
|
|
|
- '<li>' + \
|
|
|
|
|
- '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + str(footdata[0]) + '\', 1);" ' + \
|
|
|
|
|
- 'id="' + include_name + 'cfn-' + str(footdata[0]) + '">' + \
|
|
|
|
|
- '(' + footdata[1] + ')' + \
|
|
|
|
|
- '</a> <span id="' + include_name + 'fn-' + str(footdata[0]) + '">' + footdata_in + '</span>' + \
|
|
|
|
|
- '</li>' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- data = re_footnote.sub(footdata_all + '</ul>', data, 1)
|
|
|
|
|
-
|
|
|
|
|
- footnote_all = []
|
|
|
|
|
- footdata_all = '<hr><ul id="footnote_data">'
|
|
|
|
|
- else:
|
|
|
|
|
- footnote = footnote_data[1]
|
|
|
|
|
- footnote_name = footnote_data[0]
|
|
|
|
|
- if footnote_name and not footnote:
|
|
|
|
|
- if footnote_name in footnote_dict:
|
|
|
|
|
- footnote_re[footnote_name] += 1
|
|
|
|
|
-
|
|
|
|
|
- foot_plus_num = str(footnote_re[footnote_name])
|
|
|
|
|
- footshort = footnote_dict[footnote_name] + '.' + foot_plus_num
|
|
|
|
|
-
|
|
|
|
|
- footnote_all += [[float(footshort), footshort, 0]]
|
|
|
|
|
-
|
|
|
|
|
- data = re_footnote.sub('' + \
|
|
|
|
|
- '<sup>' + \
|
|
|
|
|
- '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + footshort + '\', 0);" ' + \
|
|
|
|
|
- 'id="' + include_name + 'rfn-' + footshort + '">' + \
|
|
|
|
|
- '(' + footnote_name + ')' + \
|
|
|
|
|
- '</a>' + \
|
|
|
|
|
- '</sup><span id="' + include_name + 'dfn-' + footshort + '"></span>' + \
|
|
|
|
|
- '', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- data = re_footnote.sub('<sup><a href="javascript:void(0);">(' + footnote_name + ')</a></sup>', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- footnote_number += 1
|
|
|
|
|
-
|
|
|
|
|
- if not footnote_name:
|
|
|
|
|
- footnote_name = str(footnote_number)
|
|
|
|
|
-
|
|
|
|
|
- footnote_dict.update({ footnote_name : str(footnote_number) })
|
|
|
|
|
-
|
|
|
|
|
- if not footnote_name in footnote_re:
|
|
|
|
|
- footnote_re.update({ footnote_name : 0 })
|
|
|
|
|
- else:
|
|
|
|
|
- footnote_re[footnote_name] += 1
|
|
|
|
|
-
|
|
|
|
|
- footnote_all += [[footnote_number, footnote_name, footnote]]
|
|
|
|
|
-
|
|
|
|
|
- data = re_footnote.sub('' + \
|
|
|
|
|
- '<sup>' + \
|
|
|
|
|
- '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + str(footnote_number) + '\', 0);" ' + \
|
|
|
|
|
- 'id="' + include_name + 'rfn-' + str(footnote_number) + '">' + \
|
|
|
|
|
- '(' + footnote_name + ')' + \
|
|
|
|
|
- '</a>' + \
|
|
|
|
|
- '</sup><span id="' + include_name + 'dfn-' + str(footnote_number) + '"></span>' + \
|
|
|
|
|
- '', data, 1)
|
|
|
|
|
- else:
|
|
|
|
|
- break
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\n+$', '', data)
|
|
|
|
|
-
|
|
|
|
|
- footnote_all.sort()
|
|
|
|
|
-
|
|
|
|
|
- for footdata in footnote_all:
|
|
|
|
|
- if footdata[2] == 0:
|
|
|
|
|
- footdata_in = ''
|
|
|
|
|
- else:
|
|
|
|
|
- footdata_in = str(footdata[2])
|
|
|
|
|
-
|
|
|
|
|
- footdata_all += '' + \
|
|
|
|
|
- '<li>' + \
|
|
|
|
|
- '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + str(footdata[0]) + '\', 1);" ' + \
|
|
|
|
|
- 'id="' + include_name + 'cfn-' + str(footdata[0]) + '">' + \
|
|
|
|
|
- '(' + str(footdata[1]) + ')' + \
|
|
|
|
|
- '</a> <span id="' + include_name + 'fn-' + str(footdata[0]) + '">' + footdata_in + '</span>' + \
|
|
|
|
|
- '</li>' + \
|
|
|
|
|
- ''
|
|
|
|
|
-
|
|
|
|
|
- footdata_all += '</ul>'
|
|
|
|
|
- footdata_all = '</div>' + footdata_all
|
|
|
|
|
- if footdata_all == '</div><hr><ul id="footnote_data"></ul>':
|
|
|
|
|
- footdata_all = '</div>'
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'\n$', footdata_all, data + '\n', 1)
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r''''(?P<in>((?!''').)+)'''', '<b>\g<in></b>', data)
|
|
|
|
|
- data = re.sub(r'''(?P<in>((?!'').)+)''', '<i>\g<in></i>', data)
|
|
|
|
|
- data = re.sub(r'~~(?P<in>(?:(?!~~).)+)~~', '<s>\g<in></s>', data)
|
|
|
|
|
- data = re.sub(r'--(?P<in>(?:(?!--).)+)--', '<s>\g<in></s>', data)
|
|
|
|
|
- data = re.sub(r'__(?P<in>(?:(?!__).)+)__', '<u>\g<in></u>', data)
|
|
|
|
|
- data = re.sub(r'\^\^(?P<in>(?:(?!\^\^).)+)\^\^', '<sup>\g<in></sup>', data)
|
|
|
|
|
- data = re.sub(r',,(?P<in>(?:(?!,,).)+),,', '<sub>\g<in></sub>', data)
|
|
|
|
|
-
|
|
|
|
|
- if category != '':
|
|
|
|
|
- category = re.sub(r' \| $', '', category) + '</div></div>'
|
|
|
|
|
-
|
|
|
|
|
- data += category
|
|
|
|
|
-
|
|
|
|
|
- data = re.sub(r'<\/td_1>', '</td>', data)
|
|
|
|
|
- data = re.sub(r'<\/ul>\n?', '</ul>', data)
|
|
|
|
|
- data = re.sub(r'<\/pre>\n?', '</pre>', data)
|
|
|
|
|
- data = re.sub(r'(?P<in><div class="all_in_data"(?:(?:(?!id=).)+)? id="in_data_([^"]+)">)(\n)+', '\g<in>', data)
|
|
|
|
|
- data = re.sub(r'\n\n<ul>', '\n<ul>', data)
|
|
|
|
|
- data = re.sub(r'<\/ul>\n\n', '</ul>', data)
|
|
|
|
|
- data = re.sub(r'^(\n)+', '', data)
|
|
|
|
|
- data = re.sub(r'(\n)+<hr><ul id="footnote_data">', '<hr><ul id="footnote_data">', data)
|
|
|
|
|
- data = re.sub(r'(?P<in><td(((?!>).)*)>)\n', '\g<in>', data)
|
|
|
|
|
- data = re.sub(r'(\n)?<hr>(\n)?', '<hr>', data)
|
|
|
|
|
- data = re.sub(r'<\/ul>\n\n<ul>', '</ul>\n<ul>', data)
|
|
|
|
|
- data = re.sub(r'<\/ul>\n<ul>', '</ul><ul>', data)
|
|
|
|
|
- data = re.sub(r'\n<\/ul>', '</ul>', data)
|
|
|
|
|
- data = re.sub(r'\n', '<br>', data)
|
|
|
|
|
-
|
|
|
|
|
- plus_data = 'render_html("' + include_name + 'render_contect");\n' + plus_data
|
|
|
|
|
-
|
|
|
|
|
- return [data, plus_data, backlink]
|
|
|
|
|
|
|
+from . import tool
|
|
|
|
|
+
|
|
|
|
|
+import datetime
|
|
|
|
|
+import html
|
|
|
|
|
+import re
|
|
|
|
|
+
|
|
|
|
|
+def nowiki_js(data):
|
|
|
|
|
+ data = data.replace('\\', '\\\\')
|
|
|
|
|
+ data = data.replace('"', '\\"')
|
|
|
|
|
+ data = data.replace('\r', '')
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'^\n', '', data)
|
|
|
|
|
+
|
|
|
|
|
+ data = data.replace('\n', '<br>')
|
|
|
|
|
+
|
|
|
|
|
+ return data
|
|
|
|
|
+
|
|
|
|
|
+def link_fix(main_link):
|
|
|
|
|
+ global end_data
|
|
|
|
|
+
|
|
|
|
|
+ main_link = main_link.replace(''', "<link_comma>")
|
|
|
|
|
+
|
|
|
|
|
+ if re.search(r'^:', main_link):
|
|
|
|
|
+ main_link = re.sub(r'^:', '', main_link)
|
|
|
|
|
+
|
|
|
|
|
+ main_link = re.sub(r'^사용자:', 'user:', main_link)
|
|
|
|
|
+ main_link = re.sub(r'^파일:', 'file:', main_link)
|
|
|
|
|
+ main_link = re.sub(r'^분류:', 'category:', main_link)
|
|
|
|
|
+
|
|
|
|
|
+ other_link = re.search(r'[^\\]?(#[^#]+)$', main_link)
|
|
|
|
|
+ if other_link:
|
|
|
|
|
+ other_link = other_link.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ main_link = re.sub(r'(#[^#]+)$', '', main_link)
|
|
|
|
|
+ else:
|
|
|
|
|
+ other_link = ''
|
|
|
|
|
+
|
|
|
|
|
+ main_link = main_link.replace("<link_comma>", "'")
|
|
|
|
|
+ main_link = re.sub(r'\\#', '%23', main_link)
|
|
|
|
|
+
|
|
|
|
|
+ find_data = re.findall(r'<span id="(nowiki_[0-9]+)">', main_link)
|
|
|
|
|
+ for i in find_data:
|
|
|
|
|
+ main_link = main_link.replace('<span id="' + i + '"></span>', end_data[i])
|
|
|
|
|
+
|
|
|
|
|
+ find_data = re.findall(r'<span id="(nowiki_[0-9]+)">', other_link)
|
|
|
|
|
+ for i in find_data:
|
|
|
|
|
+ other_link = other_link.replace('<span id="' + i + '"></span>', end_data[i])
|
|
|
|
|
+
|
|
|
|
|
+ return [main_link, other_link]
|
|
|
|
|
+
|
|
|
|
|
+def table_parser(data, cel_data, cel_num, start_data, num = 0, cel_color = {}):
|
|
|
|
|
+ table_class = 'class="'
|
|
|
|
|
+ div_style = 'style="'
|
|
|
|
|
+ all_table = 'style="'
|
|
|
|
|
+ cel_style = 'style="'
|
|
|
|
|
+ row_style = 'style="'
|
|
|
|
|
+ row = ''
|
|
|
|
|
+ cel = 'colspan="' + str(round(len(start_data) / 2)) + '"'
|
|
|
|
|
+
|
|
|
|
|
+ if not cel_num in cel_color:
|
|
|
|
|
+ cel_color[cel_num] = ''
|
|
|
|
|
+
|
|
|
|
|
+ cel_style += cel_color[cel_num]
|
|
|
|
|
+
|
|
|
|
|
+ if num == 0:
|
|
|
|
|
+ if re.search(r'^ ', cel_data) and re.search(r' $', cel_data):
|
|
|
|
|
+ cel_style += 'text-align: center;'
|
|
|
|
|
+ elif re.search(r'^ ', cel_data):
|
|
|
|
|
+ cel_style += 'text-align: right;'
|
|
|
|
|
+ elif re.search(r' $', cel_data):
|
|
|
|
|
+ cel_style += 'text-align: left;'
|
|
|
|
|
+
|
|
|
|
|
+ table_state = re.findall(r'<((?:(?!>).)+)>', data)
|
|
|
|
|
+ for in_state in table_state:
|
|
|
|
|
+ if re.search(r"^table ?width=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^table ?width=', '', in_state)
|
|
|
|
|
+ div_style += 'width: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
+ all_table += 'width: 100%;'
|
|
|
|
|
+ elif re.search(r"^table ?height=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^table ?height=', '', in_state)
|
|
|
|
|
+ div_style += 'height: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^table ?align=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^table ?align=', '', in_state)
|
|
|
|
|
+ if table_data == 'right':
|
|
|
|
|
+ div_style += 'float: right;'
|
|
|
|
|
+ elif table_data == 'center':
|
|
|
|
|
+ all_table += 'margin: auto;'
|
|
|
|
|
+ elif re.search(r"^table ?textalign=([^=]+)$", in_state):
|
|
|
|
|
+ num = 1
|
|
|
|
|
+ table_data = re.sub(r'^table ?textalign=', '', in_state)
|
|
|
|
|
+ if table_data == 'right':
|
|
|
|
|
+ all_table += 'text-align: right;'
|
|
|
|
|
+ elif table_data == 'center':
|
|
|
|
|
+ all_table += 'text-align: center;'
|
|
|
|
|
+ elif re.search(r"^row ?textalign=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^row ?textalign=', '', in_state)
|
|
|
|
|
+ if table_data == 'right':
|
|
|
|
|
+ row_style += 'text-align: right;'
|
|
|
|
|
+ elif table_data == 'center':
|
|
|
|
|
+ row_style += 'text-align: center;'
|
|
|
|
|
+ else:
|
|
|
|
|
+ row_style += 'text-align: left;'
|
|
|
|
|
+ elif re.search(r'^-([0-9]+)$', in_state):
|
|
|
|
|
+ cel = 'colspan="' + re.sub(r'^-', '', in_state) + '"'
|
|
|
|
|
+ elif re.search(r"^(\^|v)?\|([^|]+)$", in_state):
|
|
|
|
|
+ if re.search(r'^\^', in_state):
|
|
|
|
|
+ cel_style += 'vertical-align: top;'
|
|
|
|
|
+ elif re.search(r'^v', in_state):
|
|
|
|
|
+ cel_style += 'vertical-align: bottom;'
|
|
|
|
|
+
|
|
|
|
|
+ row = 'rowspan="' + re.sub(r'^(\^|v)?\|', '', in_state) + '"'
|
|
|
|
|
+ elif re.search(r"^row ?bgcolor=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^row ?bgcolor=', '', in_state)
|
|
|
|
|
+ row_style += 'background: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^row ?color=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^row ?color=', '', in_state)
|
|
|
|
|
+ row_style += 'color: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^table ?bordercolor=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^table ?bordercolor=', '', in_state)
|
|
|
|
|
+ all_table += 'border: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ' 2px solid;'
|
|
|
|
|
+ elif re.search(r"^table ?bgcolor=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^table ?bgcolor=', '', in_state)
|
|
|
|
|
+ all_table += 'background: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^table ?color=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^table ?color=', '', in_state)
|
|
|
|
|
+ all_table += 'color: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^col ?bgcolor=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^col ?bgcolor=', '', in_state)
|
|
|
|
|
+ table_data = (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data)
|
|
|
|
|
+ cel_color[cel_num] += 'background: ' + table_data + ';'
|
|
|
|
|
+ cel_style += 'background: ' + table_data + ';'
|
|
|
|
|
+ elif re.search(r"^col ?color=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^col ?color=', '', in_state)
|
|
|
|
|
+ table_data = (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data)
|
|
|
|
|
+ cel_color[cel_num] += 'color: ' + table_data + ';'
|
|
|
|
|
+ cel_style += 'color: ' + table_data + ';'
|
|
|
|
|
+ elif re.search(r"^(bgcolor=([^=]+)|#(?:[0-9a-f-A-F]{3}){1,2}|\w+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^bgcolor=', '', in_state)
|
|
|
|
|
+ cel_style += 'background: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^color=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^color=', '', in_state)
|
|
|
|
|
+ cel_style += 'color: ' + (re.sub(',([^,]*)', '', table_data) if re.search(r',', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^width=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^width=', '', in_state)
|
|
|
|
|
+ cel_style += 'width: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r"^height=([^=]+)$", in_state):
|
|
|
|
|
+ table_data = re.sub(r'^height=', '', in_state)
|
|
|
|
|
+ cel_style += 'height: ' + ((table_data + 'px') if re.search(r'^[0-9]+$', table_data) else table_data) + ';'
|
|
|
|
|
+ elif re.search(r'^\(|:|\)$', in_state):
|
|
|
|
|
+ if in_state == '(':
|
|
|
|
|
+ cel_style += 'text-align: right;'
|
|
|
|
|
+ elif in_state == ':':
|
|
|
|
|
+ cel_style += 'text-align: center;'
|
|
|
|
|
+ else:
|
|
|
|
|
+ cel_style += 'text-align: left;'
|
|
|
|
|
+ elif re.search(r"^table ?class=([^=]+)$", in_state):
|
|
|
|
|
+ table_class += re.sub(r"^table ?class=", '', in_state)
|
|
|
|
|
+
|
|
|
|
|
+ div_style += '"'
|
|
|
|
|
+ all_table += '"'
|
|
|
|
|
+ cel_style += '"'
|
|
|
|
|
+ row_style += '"'
|
|
|
|
|
+ table_class += '"'
|
|
|
|
|
+
|
|
|
|
|
+ return [all_table, row_style, cel_style, row, cel, table_class, num, div_style, cel_color]
|
|
|
|
|
+
|
|
|
|
|
+def table_start(data):
|
|
|
|
|
+ data = re.sub(r'\n( +)\|\|', '\n||', data)
|
|
|
|
|
+ data = re.sub(r'\|\|( +)\n', '||\n', data)
|
|
|
|
|
+ data = re.sub(r'(\|\|)+\n', '||\n', data)
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ cel_num = 0
|
|
|
|
|
+ table_num = 0
|
|
|
|
|
+ table_end = ''
|
|
|
|
|
+ cel_color = {}
|
|
|
|
|
+
|
|
|
|
|
+ table = re.search(r'\n((?:(?:(?:(?:\|\||\|[^|]+\|)+(?:(?:(?!\|\|).\n*)*))+)\|\|(?:\n)?)+)', data)
|
|
|
|
|
+ if table:
|
|
|
|
|
+ table = re.sub(r'(\|\|)+\n', '||\n', table.group(1))
|
|
|
|
|
+
|
|
|
|
|
+ table_caption = re.search(r'^\|([^|]+)\|', table)
|
|
|
|
|
+ if table_caption:
|
|
|
|
|
+ table_caption = '<caption>' + table_caption.group(1) + '</caption>'
|
|
|
|
|
+
|
|
|
|
|
+ table = re.sub(r'^\|([^|]+)\|', '||', table)
|
|
|
|
|
+ else:
|
|
|
|
|
+ table_caption = ''
|
|
|
|
|
+
|
|
|
|
|
+ table = '\n' + table
|
|
|
|
|
+
|
|
|
|
|
+ table_cel = re.findall(r'(\n(?:(?:\|\|)+)|\|\|\n(?:(?:\|\|)+)|(?:(?:\|\|)+))((?:(?:(?!\n|\|\|).)+\n*)+)', table)
|
|
|
|
|
+ for i in table_cel:
|
|
|
|
|
+ cel_plus = re.search(r'^((?:<(?:(?:(?!>).)*)>)+)', i[1])
|
|
|
|
|
+ cel_plus = cel_plus.group(1) if cel_plus else ''
|
|
|
|
|
+ cel_data = re.sub(r'^((?:<(?:(?:(?!>).)*)>)+)', '', i[1])
|
|
|
|
|
+
|
|
|
|
|
+ if re.search(r'^\n', i[0]):
|
|
|
|
|
+ cel_num = 1
|
|
|
|
|
+
|
|
|
|
|
+ cel_plus = table_parser(
|
|
|
|
|
+ cel_plus,
|
|
|
|
|
+ cel_data,
|
|
|
|
|
+ cel_num,
|
|
|
|
|
+ re.sub(r'^\n', '', i[0]),
|
|
|
|
|
+ table_num,
|
|
|
|
|
+ cel_color
|
|
|
|
|
+ )
|
|
|
|
|
+ cel_color = cel_plus[8]
|
|
|
|
|
+ table_num = cel_plus[6]
|
|
|
|
|
+
|
|
|
|
|
+ table_end += '' + \
|
|
|
|
|
+ '<div class="table_safe" ' + cel_plus[7] + '>' + \
|
|
|
|
|
+ '<table ' + cel_plus[5] + ' ' + cel_plus[0] + '>' + \
|
|
|
|
|
+ table_caption + \
|
|
|
|
|
+ '<tr ' + cel_plus[1] + '>' + \
|
|
|
|
|
+ '<td ' + cel_plus[2] + ' ' + cel_plus[3] + ' ' + cel_plus[4] + '>' + \
|
|
|
|
|
+ cel_data
|
|
|
|
|
+
|
|
|
|
|
+ elif re.search(r'\n', i[0]):
|
|
|
|
|
+ cel_num = 1
|
|
|
|
|
+
|
|
|
|
|
+ cel_plus = table_parser(
|
|
|
|
|
+ cel_plus,
|
|
|
|
|
+ cel_data,
|
|
|
|
|
+ cel_num,
|
|
|
|
|
+ re.sub(r'^\|\|\n', '', i[0]),
|
|
|
|
|
+ table_num,
|
|
|
|
|
+ cel_color
|
|
|
|
|
+ )
|
|
|
|
|
+ cel_color = cel_plus[8]
|
|
|
|
|
+
|
|
|
|
|
+ table_end += '' + \
|
|
|
|
|
+ '</td>' + \
|
|
|
|
|
+ '</tr>' + \
|
|
|
|
|
+ '<tr ' + cel_plus[1] + '>' + \
|
|
|
|
|
+ '<td ' + cel_plus[2] + ' ' + cel_plus[3] + ' ' + cel_plus[4] + '>' + \
|
|
|
|
|
+ cel_data
|
|
|
|
|
+ else:
|
|
|
|
|
+ cel_num += 1
|
|
|
|
|
+
|
|
|
|
|
+ cel_plus = table_parser(
|
|
|
|
|
+ cel_plus,
|
|
|
|
|
+ cel_data,
|
|
|
|
|
+ cel_num,
|
|
|
|
|
+ re.sub(r'^\|\|\n', '', i[0]),
|
|
|
|
|
+ table_num,
|
|
|
|
|
+ cel_color
|
|
|
|
|
+ )
|
|
|
|
|
+ cel_color = cel_plus[8]
|
|
|
|
|
+
|
|
|
|
|
+ table_end += '' + \
|
|
|
|
|
+ '</td>' + \
|
|
|
|
|
+ '<td ' + cel_plus[2] + ' ' + cel_plus[3] + ' ' + cel_plus[4] + '>' + \
|
|
|
|
|
+ cel_data
|
|
|
|
|
+
|
|
|
|
|
+ table_end += '</td></tr></table></div>'
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\n((?:(?:(?:(?:\|\||\|[^|]+\|)+(?:(?:(?!\|\|).\n*)*))+)\|\|(?:\n)?)+)', '\n' + table_end + '\n', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ return data
|
|
|
|
|
+
|
|
|
|
|
+def middle_parser(data):
|
|
|
|
|
+ global end_data
|
|
|
|
|
+ global plus_data
|
|
|
|
|
+ global nowiki_num
|
|
|
|
|
+ global include_name
|
|
|
|
|
+
|
|
|
|
|
+ middle_stack = 0
|
|
|
|
|
+ middle_list = []
|
|
|
|
|
+ middle_num = 0
|
|
|
|
|
+
|
|
|
|
|
+ html_num = 0
|
|
|
|
|
+ syntax_num = 0
|
|
|
|
|
+ folding_num = 0
|
|
|
|
|
+
|
|
|
|
|
+ middle_re = re.compile(r'(?:{{{((?:(?:(?! |{{{|}}}|<).)*) ?)|(}}}))')
|
|
|
|
|
+ middle_all_data = middle_re.findall(data)
|
|
|
|
|
+ for middle_data in middle_all_data:
|
|
|
|
|
+ if not middle_data[1]:
|
|
|
|
|
+ if middle_stack > 0:
|
|
|
|
|
+ middle_stack += 1
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'(?:{{{((?:(?! |{{{|}}}|<).)*)(?P<in> ?)|(}}}))', '<middle_start>' + middle_data[0] + '\g<in>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ if re.search(r'^(#|@|\+|\-)', middle_data[0]) and not re.search(r'^(#|@|\+|\-){2}|(#|@|\+|\-)\\', middle_data[0]):
|
|
|
|
|
+ if re.search(r'^(#(?:[0-9a-f-A-F]{3}){1,2})', middle_data[0]):
|
|
|
|
|
+ middle_search = re.search(r'^(#(?:[0-9a-f-A-F]{3}){1,2})', middle_data[0])
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span style="color: ' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
+ elif re.search(r'^(?:#(\w+))', middle_data[0]):
|
|
|
|
|
+ middle_search = re.search(r'^(?:#(\w+))', middle_data[0])
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span style="color: ' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
+ elif re.search(r'^(?:@((?:[0-9a-f-A-F]{3}){1,2}))', middle_data[0]):
|
|
|
|
|
+ middle_search = re.search(r'^(?:@((?:[0-9a-f-A-F]{3}){1,2}))', middle_data[0])
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span style="background: #' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
+ elif re.search(r'^(?:@(\w+))', middle_data[0]):
|
|
|
|
|
+ middle_search = re.search(r'^(?:@(\w+))', middle_data[0])
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span style="background: ' + middle_search.group(1) + ';">', data, 1)
|
|
|
|
|
+ elif re.search(r'^(\+|-)([1-5])', middle_data[0]):
|
|
|
|
|
+ middle_search = re.search(r'^(\+|-)([1-5])', middle_data[0])
|
|
|
|
|
+ middle_search = middle_search.groups()
|
|
|
|
|
+ if middle_search[0] == '+':
|
|
|
|
|
+ font_size = str(int(middle_search[1]) * 20 + 100)
|
|
|
|
|
+ else:
|
|
|
|
|
+ font_size = str(100 - int(middle_search[1]) * 10)
|
|
|
|
|
+
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span style="font-size: ' + font_size + '%;">', data, 1)
|
|
|
|
|
+ elif re.search(r'^#!wiki', middle_data[0]):
|
|
|
|
|
+ middle_data_2 = re.search(r'{{{#!wiki(?: style=(?:"|')((?:(?!"|').)*)(?:"|'))?(?: *)\n?', data)
|
|
|
|
|
+ if middle_data_2:
|
|
|
|
|
+ middle_data_2 = middle_data_2.groups()
|
|
|
|
|
+ else:
|
|
|
|
|
+ middle_data_2 = ['']
|
|
|
|
|
+
|
|
|
|
|
+ middle_list += ['div_1']
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ r'{{{#!wiki(?: style=(?:"|')((?:(?!"|').)*)(?:"|'))?(?: *)\n?',
|
|
|
|
|
+ '<div id="wiki_div" style="' + str(middle_data_2[0] if middle_data_2[0] else '') + '">',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ elif re.search(r'^#!syntax', middle_data[0]):
|
|
|
|
|
+ middle_data_2 = re.search(r'{{{#!syntax ((?:(?!\n|{{{).)+)\n?', data)
|
|
|
|
|
+ if middle_data_2:
|
|
|
|
|
+ middle_data_2 = middle_data_2.groups()
|
|
|
|
|
+ else:
|
|
|
|
|
+ middle_data_2 = ['python']
|
|
|
|
|
+
|
|
|
|
|
+ if syntax_num == 0:
|
|
|
|
|
+ plus_data += 'hljs.initHighlightingOnLoad();\n'
|
|
|
|
|
+
|
|
|
|
|
+ syntax_num = 1
|
|
|
|
|
+
|
|
|
|
|
+ middle_list += ['pre']
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ r'{{{#!syntax ?((?:(?!\n|{{{).)*)\n?',
|
|
|
|
|
+ '<pre id="syntax"><code class="' + middle_data_2[0] + '">',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ elif re.search(r'^#!folding', middle_data[0]):
|
|
|
|
|
+ middle_list += ['2div']
|
|
|
|
|
+
|
|
|
|
|
+ folding_data = re.search(r'{{{#!folding ?((?:(?!\n).)*)\n?', data)
|
|
|
|
|
+ if folding_data:
|
|
|
|
|
+ folding_data = folding_data.groups()
|
|
|
|
|
+ else:
|
|
|
|
|
+ folding_data = ['Test']
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ r'{{{#!folding ?((?:(?!\n).)*)\n?', '' + \
|
|
|
|
|
+ '<div>' + \
|
|
|
|
|
+ str(folding_data[0]) + ' ' + \
|
|
|
|
|
+ '<div style="display: inline-block;">' + \
|
|
|
|
|
+ '<a href="javascript:void(0);" onclick="do_open_folding(\'' + include_name + 'folding_' + str(folding_num) + '\', this);">' + \
|
|
|
|
|
+ '(+)' + \
|
|
|
|
|
+ '</a>' + \
|
|
|
|
|
+ '</div_2>' + \
|
|
|
|
|
+ '<div id="' + include_name + 'folding_' + str(folding_num) + '" style="display: none;">' + \
|
|
|
|
|
+ '<div id="wiki_div" style="">',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+
|
|
|
|
|
+ folding_num += 1
|
|
|
|
|
+ elif re.search(r'^#!html', middle_data[0]):
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ html_num += 1
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span id="' + include_name + 'render_contect_' + str(html_num) + '">', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ middle_list += ['span']
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<span>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ middle_list += ['code']
|
|
|
|
|
+
|
|
|
|
|
+ middle_stack += 1
|
|
|
|
|
+
|
|
|
|
|
+ data = middle_re.sub('<code>' + middle_data[0].replace('\\', '\\\\'), data, 1)
|
|
|
|
|
+
|
|
|
|
|
+ middle_num += 1
|
|
|
|
|
+ else:
|
|
|
|
|
+ if middle_list == []:
|
|
|
|
|
+ data = middle_re.sub('<middle_end>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ if middle_stack > 0:
|
|
|
|
|
+ middle_stack -= 1
|
|
|
|
|
+
|
|
|
|
|
+ if middle_stack > 0:
|
|
|
|
|
+ data = middle_re.sub('<middle_end>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ if middle_num > 0:
|
|
|
|
|
+ middle_num -= 1
|
|
|
|
|
+
|
|
|
|
|
+ if middle_list[middle_num] == '2div':
|
|
|
|
|
+ data = middle_re.sub('</div_1></div_2></div_2>', data, 1)
|
|
|
|
|
+ elif middle_list[middle_num] == 'pre':
|
|
|
|
|
+ data = middle_re.sub('</code></pre>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = middle_re.sub('</' + middle_list[middle_num] + '>', data, 1)
|
|
|
|
|
+
|
|
|
|
|
+ del(middle_list[middle_num])
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ if middle_stack == 0:
|
|
|
|
|
+ break
|
|
|
|
|
+ else:
|
|
|
|
|
+ if middle_list == []:
|
|
|
|
|
+ data += '<middle_end>'
|
|
|
|
|
+ else:
|
|
|
|
|
+ if middle_stack > 0:
|
|
|
|
|
+ middle_stack -= 1
|
|
|
|
|
+
|
|
|
|
|
+ if middle_stack > 0:
|
|
|
|
|
+ data += '<middle_end>'
|
|
|
|
|
+ else:
|
|
|
|
|
+ if middle_num > 0:
|
|
|
|
|
+ middle_num -= 1
|
|
|
|
|
+
|
|
|
|
|
+ if middle_list[middle_num] == '2div':
|
|
|
|
|
+ data += '</div_1></div_2></div_2>'
|
|
|
|
|
+ elif middle_list[middle_num] == 'pre':
|
|
|
|
|
+ data += '</code></pre>'
|
|
|
|
|
+ else:
|
|
|
|
|
+ data += '</' + middle_list[middle_num] + '>'
|
|
|
|
|
+
|
|
|
|
|
+ del(middle_list[middle_num])
|
|
|
|
|
+
|
|
|
|
|
+ data = data.replace('<middle_start>', '{{{')
|
|
|
|
|
+ data = data.replace('<middle_end>', '}}}')
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ nowiki_data = re.search(r'<code>((?:(?:(?!<\/code>).)*\n*)*)<\/code>', data)
|
|
|
|
|
+ if nowiki_data:
|
|
|
|
|
+ nowiki_data = nowiki_data.groups()
|
|
|
|
|
+
|
|
|
|
|
+ nowiki_num += 1
|
|
|
|
|
+ end_data[include_name + 'nowiki_' + str(nowiki_num)] = nowiki_data[0]
|
|
|
|
|
+ plus_data += '' + \
|
|
|
|
|
+ 'if(document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '")) { ' + \
|
|
|
|
|
+ 'document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '").innerHTML = "' + nowiki_js(nowiki_data[0]) + '"; ' + \
|
|
|
|
|
+ '}' + \
|
|
|
|
|
+ '\n' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '<code>((?:(?:(?!<\/code>).)*\n*)*)<\/code>',
|
|
|
|
|
+ '<span id="' + include_name + 'nowiki_' + str(nowiki_num) + '"></span>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ syntax_data = re.search(
|
|
|
|
|
+ r'<code class="((?:(?!"|>|<).)+)">((?:\n*(?:(?:(?!<\/code>|<span id="(?:(?:(?!nowiki_).)*)nowiki_).)+)\n*)+)<\/code>',
|
|
|
|
|
+ data
|
|
|
|
|
+ )
|
|
|
|
|
+ if syntax_data:
|
|
|
|
|
+ syntax_data = syntax_data.groups()
|
|
|
|
|
+
|
|
|
|
|
+ nowiki_num += 1
|
|
|
|
|
+ end_data[include_name + 'nowiki_' + str(nowiki_num)] = syntax_data[1]
|
|
|
|
|
+ plus_data += '' + \
|
|
|
|
|
+ 'if(document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '")) { ' + \
|
|
|
|
|
+ 'document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '").innerHTML = "' + nowiki_js(syntax_data[1]) + '"; ' + \
|
|
|
|
|
+ '}' + \
|
|
|
|
|
+ '\n' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ r'<code class="((?:(?!"|>|<).)+)">((?:\n*(?:(?:(?!<\/code>|<span id="(?:(?:(?!nowiki_).)*)nowiki_).)+)\n*)+)<\/code>',
|
|
|
|
|
+ '<code class="' + syntax_data[0] + '"><span id="' + include_name + 'nowiki_' + str(nowiki_num) + '"></span></code>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ return data
|
|
|
|
|
+
|
|
|
|
|
+def namumark(conn, data, title, include_num):
|
|
|
|
|
+ curs = conn.cursor()
|
|
|
|
|
+
|
|
|
|
|
+ global plus_data
|
|
|
|
|
+ global end_data
|
|
|
|
|
+ global nowiki_num
|
|
|
|
|
+ global include_name
|
|
|
|
|
+
|
|
|
|
|
+ nowiki_num = 0
|
|
|
|
|
+ data = '\n' + data + '\n'
|
|
|
|
|
+ include_name = include_num + '_' if include_num else ''
|
|
|
|
|
+ plus_data = '' + \
|
|
|
|
|
+ 'get_link_state("' + include_name + '");\n' + \
|
|
|
|
|
+ 'get_file_state("' + include_name + '");\n' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ backlink = []
|
|
|
|
|
+ end_data = {}
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'<math>(?P<in>(?:(?!<\/math>).)+)<\/math>', '[math(\g<in>)]', data)
|
|
|
|
|
+
|
|
|
|
|
+ data = html.escape(data)
|
|
|
|
|
+ data = data.replace('\r\n', '\n')
|
|
|
|
|
+
|
|
|
|
|
+ math_re = re.compile(r'\[math\(((?:(?!\)\]).)+)\)\]', re.I)
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ math = math_re.search(data)
|
|
|
|
|
+ if math:
|
|
|
|
|
+ math = math.group(1)
|
|
|
|
|
+ math = math.replace('{', '<math_mid_1>')
|
|
|
|
|
+ math = math.replace('}', '<math_mid_2>')
|
|
|
|
|
+ math = math.replace('\\', '<math_slash>')
|
|
|
|
|
+
|
|
|
|
|
+ data = math_re.sub('<math>' + math + '</math>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = data.replace('\\{', '<break_middle>')
|
|
|
|
|
+ data = middle_parser(data)
|
|
|
|
|
+ data = data.replace('<break_middle>', '\\{')
|
|
|
|
|
+
|
|
|
|
|
+ first = 0
|
|
|
|
|
+ math_re = re.compile(r'<math>((?:(?!<\/math>).)+)<\/math>', re.I)
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ math = math_re.search(data)
|
|
|
|
|
+ if math:
|
|
|
|
|
+ math = math.group(1)
|
|
|
|
|
+ math = math.replace('<math_mid_1>', '{')
|
|
|
|
|
+ math = math.replace('<math_mid_2>', '}')
|
|
|
|
|
+ math = math.replace('<math_slash>', '\\')
|
|
|
|
|
+
|
|
|
|
|
+ first += 1
|
|
|
|
|
+ data = math_re.sub('<span id="math_' + str(first) + '"></span>', data, 1)
|
|
|
|
|
+
|
|
|
|
|
+ plus_data += '' + \
|
|
|
|
|
+ 'try {' + \
|
|
|
|
|
+ 'katex.render(' + \
|
|
|
|
|
+ '"' + nowiki_js(html.unescape(math)) + '",' + \
|
|
|
|
|
+ 'document.getElementById(\"' + include_name + 'math_' + str(first) + '\")' + \
|
|
|
|
|
+ ');' + \
|
|
|
|
|
+ '} catch {' + \
|
|
|
|
|
+ 'document.getElementById(\"' + include_name + 'math_' + str(first) + '\").innerHTML = "<span style=\'color: red;\'>' + nowiki_js(math) + '</span>";' + \
|
|
|
|
|
+ '}\n' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ num = 0
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ one_nowiki = re.search(r'(?:\\)(.)', data)
|
|
|
|
|
+ if one_nowiki:
|
|
|
|
|
+ one_nowiki = one_nowiki.groups()
|
|
|
|
|
+
|
|
|
|
|
+ nowiki_num += 1
|
|
|
|
|
+ end_data[include_name + 'nowiki_' + str(nowiki_num)] = one_nowiki[0]
|
|
|
|
|
+ plus_data += '' + \
|
|
|
|
|
+ 'if(document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '")) { ' + \
|
|
|
|
|
+ 'document.getElementById("' + include_name + 'nowiki_' + str(nowiki_num) + '").innerHTML = "' + nowiki_js(one_nowiki[0]) + '"; ' + \
|
|
|
|
|
+ '}' + \
|
|
|
|
|
+ '\n' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'(?:\\)(.)', '<span id="' + include_name + 'nowiki_' + str(nowiki_num) + '"></span>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ include_re = re.compile(r'\[include\(((?:(?!\)\]).)+)\)\]', re.I)
|
|
|
|
|
+ i = 0
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ i += 1
|
|
|
|
|
+
|
|
|
|
|
+ include = include_re.search(data)
|
|
|
|
|
+ if include:
|
|
|
|
|
+ include = include.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ include_data = re.search(r'^((?:(?!,).)+)', include)
|
|
|
|
|
+ if include_data:
|
|
|
|
|
+ include_data = include_data.group(1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ include_data = 'Test'
|
|
|
|
|
+
|
|
|
|
|
+ include_link = include_data
|
|
|
|
|
+ backlink += [[title, include_link, 'include']]
|
|
|
|
|
+
|
|
|
|
|
+ data = include_re.sub('' + \
|
|
|
|
|
+ '<a id="' + include_name + 'include_link" class="include_' + str(i) + '" href="/w/' + tool.url_pas(include_link) + '">(' + include_link + ')</a>' + \
|
|
|
|
|
+ '<div id="' + include_name + 'include_' + str(i) + '"></div>' + \
|
|
|
|
|
+ '', data, 1)
|
|
|
|
|
+
|
|
|
|
|
+ include_plus_data = []
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ include_plus = re.search(r', ?((?:(?!=).)+)=((?:(?!,).)+)', include)
|
|
|
|
|
+ if include_plus:
|
|
|
|
|
+ include_plus = include_plus.groups()
|
|
|
|
|
+
|
|
|
|
|
+ include_data_set = include_plus[1]
|
|
|
|
|
+ find_data = re.findall(r'<span id="(nowiki_[0-9]+)">', include_data_set)
|
|
|
|
|
+ for j in find_data:
|
|
|
|
|
+ include_data_set = include_data_set.replace('<span id="' + j + '"></span>', end_data[j])
|
|
|
|
|
+
|
|
|
|
|
+ include_plus_data += [[include_plus[0], include_data_set]]
|
|
|
|
|
+
|
|
|
|
|
+ include = re.sub(r', ?((?:(?!=).)+)=((?:(?!,).)+)', '', include, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ plus_data += 'load_include("' + include_link + '", "' + include_name + 'include_' + str(i) + '", ' + str(include_plus_data) + ');\n'
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\r\n', '\n', data)
|
|
|
|
|
+ data = re.sub(r'&', '&', data)
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\n##(((?!\n).)+)', '', data)
|
|
|
|
|
+ data = re.sub(r'<div id="wiki_div" style="">\n', '<div id="wiki_div" style="">', data)
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ wiki_table_data = re.search(r'<div id="wiki_div" ((?:(?!>).)+)>((?:(?!<div id="wiki_div"|<\/div_1>).\n*)+)<\/div_1>', data)
|
|
|
|
|
+ if wiki_table_data:
|
|
|
|
|
+ wiki_table_data = wiki_table_data.groups()
|
|
|
|
|
+ if re.search(r'\|\|', wiki_table_data[1]):
|
|
|
|
|
+ end_parser = re.sub(r'\n$', '', re.sub(r'^\n', '', table_start('\n' + wiki_table_data[1] + '\n')))
|
|
|
|
|
+ else:
|
|
|
|
|
+ end_parser = wiki_table_data[1]
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '<div id="wiki_div" ((?:(?!>).)+)>((?:(?!<div id="wiki_div"|<\/div_1>).\n*)+)<\/div_1>',
|
|
|
|
|
+ '<div ' + wiki_table_data[0] + '>' + end_parser + '</div_2>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'<\/div_2>', '</div>', data)
|
|
|
|
|
+ data = re.sub(r'<\/td>', '</td_1>', data)
|
|
|
|
|
+
|
|
|
|
|
+ data += '\n'
|
|
|
|
|
+ data = data.replace('\\', '\')
|
|
|
|
|
+
|
|
|
|
|
+ redirect_re = re.compile(r'\n#(?:redirect|넘겨주기) ((?:(?!\n).)+)\n', re.I)
|
|
|
|
|
+ redirect = redirect_re.search(data)
|
|
|
|
|
+ if redirect:
|
|
|
|
|
+ redirect = redirect.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ return_link = link_fix(redirect)
|
|
|
|
|
+ main_link = html.unescape(return_link[0])
|
|
|
|
|
+ other_link = return_link[1]
|
|
|
|
|
+
|
|
|
|
|
+ backlink += [[title, main_link, 'redirect']]
|
|
|
|
|
+
|
|
|
|
|
+ data = redirect_re.sub(
|
|
|
|
|
+ '\n' + \
|
|
|
|
|
+ '<ul>' + \
|
|
|
|
|
+ '<li>' + \
|
|
|
|
|
+ '<a id="go_redirect_link" href="/w/' + tool.url_pas(main_link) + other_link + '">' + main_link + other_link + '</a>' + \
|
|
|
|
|
+ '</li>' + \
|
|
|
|
|
+ '</ul>' + \
|
|
|
|
|
+ '\n',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+
|
|
|
|
|
+ no_toc_re = re.compile(r'\[(?:목차|toc)\((?:no)\)\]\n', re.I)
|
|
|
|
|
+ toc_re = re.compile(r'\[(?:목차|toc)\]', re.I)
|
|
|
|
|
+ if not no_toc_re.search(data):
|
|
|
|
|
+ if not toc_re.search(data):
|
|
|
|
|
+ data = re.sub(r'\n(?P<in>={1,6}) ?(?P<out>(?:(?!=).)+) ?={1,6}\n', '\n[toc]\n\g<in> \g<out> \g<in>\n', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = no_toc_re.sub('', data)
|
|
|
|
|
+
|
|
|
|
|
+ data = '<div class="all_in_data" id="in_data_0">' + data
|
|
|
|
|
+
|
|
|
|
|
+ toc_full = 0
|
|
|
|
|
+ toc_top_stack = 6
|
|
|
|
|
+ toc_stack = [0, 0, 0, 0, 0, 0]
|
|
|
|
|
+ edit_number = 0
|
|
|
|
|
+ toc_data = '<div id="toc"><span id="toc_title">TOC</span>\n\n'
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ toc = re.search(r'\n(={1,6}) ?((?:(?!\n).)+) ?(?:={1,6})\n', data)
|
|
|
|
|
+ if toc:
|
|
|
|
|
+ toc = toc.groups()
|
|
|
|
|
+
|
|
|
|
|
+ toc_number = len(toc[0])
|
|
|
|
|
+ edit_number += 1
|
|
|
|
|
+
|
|
|
|
|
+ if toc_full > toc_number:
|
|
|
|
|
+ for i in range(toc_number, 6):
|
|
|
|
|
+ toc_stack[i] = 0
|
|
|
|
|
+
|
|
|
|
|
+ if toc_top_stack > toc_number:
|
|
|
|
|
+ toc_top_stack = toc_number
|
|
|
|
|
+
|
|
|
|
|
+ toc_full = toc_number
|
|
|
|
|
+ toc_stack[toc_number - 1] += 1
|
|
|
|
|
+ toc_number = str(toc_number)
|
|
|
|
|
+ all_stack = ''
|
|
|
|
|
+
|
|
|
|
|
+ for i in range(0, 6):
|
|
|
|
|
+ all_stack += str(toc_stack[i]) + '.'
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ if re.search(r'[^0-9]0\.', all_stack):
|
|
|
|
|
+ all_stack = re.sub(r'[^0-9]0\.', '.', all_stack)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ all_stack = re.sub(r'^0\.', '', all_stack)
|
|
|
|
|
+ all_stack = re.sub(r'\.$', '', all_stack)
|
|
|
|
|
+
|
|
|
|
|
+ new_toc_data = re.sub(r'=*$', '', toc[1])
|
|
|
|
|
+ new_toc_data = re.sub(r' +$', '', new_toc_data)
|
|
|
|
|
+ if re.search(r'^# ?(?P<in>[^#]+) ?#$', new_toc_data):
|
|
|
|
|
+ fol_head = '+'
|
|
|
|
|
+
|
|
|
|
|
+ new_toc_data = re.sub(r'^# ?(?P<in>[^#]+) ?#$', '\g<in>', new_toc_data)
|
|
|
|
|
+ else:
|
|
|
|
|
+ fol_head = '-'
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\n(={1,6}) ?((?:(?!\n).)+) ?\n',
|
|
|
|
|
+ '\n' + \
|
|
|
|
|
+ '</div>'
|
|
|
|
|
+ '<h' + toc_number + ' id="s-' + all_stack + '">' + \
|
|
|
|
|
+ '<a href="#toc">' + all_stack + '.</a> ' + new_toc_data + ' ' + \
|
|
|
|
|
+ '<span style="font-size: 12px">' + \
|
|
|
|
|
+ '<a href="/edit/' + tool.url_pas(title) + '?section=' + str(edit_number) + '">(Edit)</a>' + \
|
|
|
|
|
+ ' ' + \
|
|
|
|
|
+ '<a href="javascript:void(0);" onclick="do_open_folding(\'in_data_' + all_stack + '\', this);">' + \
|
|
|
|
|
+ '(' + fol_head + ')' + \
|
|
|
|
|
+ '</a>' + \
|
|
|
|
|
+ '</span>' + \
|
|
|
|
|
+ '</h' + toc_number + '>' + \
|
|
|
|
|
+ '<div class="all_in_data"' + (' style="display: none;"' if fol_head == '+' else '') + ' id="in_data_' + all_stack + '">' + \
|
|
|
|
|
+ '\n',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+
|
|
|
|
|
+ toc_main_data = new_toc_data
|
|
|
|
|
+ toc_main_data = re.sub(r'\[\*((?:(?! |\]).)*)(?: ((?:(?!(\[\*(?:(?:(?!\]).)+)\]|\])).)+))?\]', '', toc_main_data)
|
|
|
|
|
+ toc_main_data = re.sub(r'<span id="math_[0-9]"><\/span>', '(Math)', toc_main_data)
|
|
|
|
|
+
|
|
|
|
|
+ toc_data += '' + \
|
|
|
|
|
+ '<span style="margin-left: ' + str((toc_full - toc_top_stack) * 10) + 'px;">' + \
|
|
|
|
|
+ '<a href="#s-' + all_stack + '">' + all_stack + '.</a> ' + toc_main_data + \
|
|
|
|
|
+ '</span>' + \
|
|
|
|
|
+ '\n' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ toc_data += '</div>'
|
|
|
|
|
+ data = toc_re.sub(toc_data, data)
|
|
|
|
|
+
|
|
|
|
|
+ now_time = tool.get_time()
|
|
|
|
|
+ time_data = re.search(r'^([0-9]{4}-[0-9]{2}-[0-9]{2})', now_time)
|
|
|
|
|
+ time = time_data.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ macro_re = re.compile(r'\[([^[(]+)\(((?:(?!\[|\)]).)+)\)\]')
|
|
|
|
|
+ macro_data = macro_re.findall(data)
|
|
|
|
|
+ for i in macro_data:
|
|
|
|
|
+ macro_name = i[0].lower()
|
|
|
|
|
+ if macro_name == 'youtube' or macro_name == 'kakaotv' or macro_name == 'nicovideo':
|
|
|
|
|
+ width = re.search(r', ?width=((?:(?!,).)+)', i[1])
|
|
|
|
|
+ if width:
|
|
|
|
|
+ video_width = width.group(1)
|
|
|
|
|
+ if re.search(r'^[0-9]+$', video_width):
|
|
|
|
|
+ video_width += 'px'
|
|
|
|
|
+ else:
|
|
|
|
|
+ video_width = '560px'
|
|
|
|
|
+
|
|
|
|
|
+ height = re.search(r', ?height=((?:(?!,).)+)', i[1])
|
|
|
|
|
+ if height:
|
|
|
|
|
+ video_height = height.group(1)
|
|
|
|
|
+ if re.search(r'^[0-9]+$', video_height):
|
|
|
|
|
+ video_height += 'px'
|
|
|
|
|
+ else:
|
|
|
|
|
+ video_height = '315px'
|
|
|
|
|
+
|
|
|
|
|
+ code = re.search(r'^((?:(?!,).)+)', i[1])
|
|
|
|
|
+ if code:
|
|
|
|
|
+ video_code = code.group(1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ video_code = ''
|
|
|
|
|
+
|
|
|
|
|
+ video_start = ''
|
|
|
|
|
+
|
|
|
|
|
+ if macro_name == 'youtube':
|
|
|
|
|
+ start = re.search(r', ?(start=(?:(?!,).)+)', i[1])
|
|
|
|
|
+ if start:
|
|
|
|
|
+ video_start = '?' + start.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ video_code = re.sub(r'^https:\/\/www\.youtube\.com\/watch\?v=', '', video_code)
|
|
|
|
|
+ video_code = re.sub(r'^https:\/\/youtu\.be\/', '', video_code)
|
|
|
|
|
+
|
|
|
|
|
+ video_src = 'https://www.youtube.com/embed/' + video_code
|
|
|
|
|
+ elif macro_name == 'kakaotv':
|
|
|
|
|
+ video_code = re.sub(r'^https:\/\/tv\.kakao\.com\/channel\/9262\/cliplink\/', '', video_code)
|
|
|
|
|
+ video_code = re.sub(r'^http:\/\/tv\.kakao\.com\/v\/', '', video_code)
|
|
|
|
|
+
|
|
|
|
|
+ video_src = 'https://tv.kakao.com/embed/player/cliplink/' + video_code +'?service=kakao_tv'
|
|
|
|
|
+ else:
|
|
|
|
|
+ video_src = 'https://embed.nicovideo.jp/watch/' + video_code
|
|
|
|
|
+
|
|
|
|
|
+ data = macro_re.sub(
|
|
|
|
|
+ '<iframe style="width: ' + video_width + '; height: ' + video_height + ';" src="' + video_src + video_start + '" frameborder="0" allowfullscreen></iframe>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ elif macro_name == 'anchor':
|
|
|
|
|
+ data = macro_re.sub('<span id="' + i[1] + '"></span>', data, 1)
|
|
|
|
|
+ elif macro_name == 'ruby':
|
|
|
|
|
+ ruby_code = re.search(r'^([^,]+)', i[1])
|
|
|
|
|
+ if ruby_code:
|
|
|
|
|
+ ruby_code = ruby_code.group(1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ ruby_code = 'Test'
|
|
|
|
|
+
|
|
|
|
|
+ ruby_top = re.search(r'ruby=([^,]+)', i[1], flags = re.I)
|
|
|
|
|
+ if ruby_top:
|
|
|
|
|
+ ruby_top = ruby_top.group(1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ ruby_top = 'Test'
|
|
|
|
|
+
|
|
|
|
|
+ ruby_color = re.search(r'color=([^,]+)', i[1], flags = re.I)
|
|
|
|
|
+ if ruby_color:
|
|
|
|
|
+ ruby_color = 'color: ' + ruby_color.group(1) + ';'
|
|
|
|
|
+ else:
|
|
|
|
|
+ ruby_color = ''
|
|
|
|
|
+
|
|
|
|
|
+ ruby_data = '' + \
|
|
|
|
|
+ '<ruby>' + \
|
|
|
|
|
+ ruby_code \
|
|
|
|
|
+ + '<rp>(</rp>' + \
|
|
|
|
|
+ '<rt style="' + ruby_color + '">' + ruby_top + '</rt>' + \
|
|
|
|
|
+ '<rp>)</rp>' + \
|
|
|
|
|
+ '</ruby>' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ data = macro_re.sub(ruby_data, data, 1)
|
|
|
|
|
+ elif macro_name == 'age' or macro_name == 'dday':
|
|
|
|
|
+ try:
|
|
|
|
|
+ old = datetime.datetime.strptime(time, '%Y-%m-%d')
|
|
|
|
|
+ will = datetime.datetime.strptime(i[1], '%Y-%m-%d')
|
|
|
|
|
+
|
|
|
|
|
+ e_data = old - will
|
|
|
|
|
+
|
|
|
|
|
+ if macro_name == 'age':
|
|
|
|
|
+ data = macro_re.sub(str(int(e_data.days / 365)), data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ if re.search(r'^-', str(e_data.days)):
|
|
|
|
|
+ e_day = str(e_data.days)
|
|
|
|
|
+ else:
|
|
|
|
|
+ e_day = '+' + str(e_data.days)
|
|
|
|
|
+
|
|
|
|
|
+ data = macro_re.sub(e_day, data, 1)
|
|
|
|
|
+ except:
|
|
|
|
|
+ data = macro_re.sub('age-dday-error', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = macro_re.sub('<macro_start>' + i[0] + '<macro_middle>' + i[1] + '<macro_end>', data, 1)
|
|
|
|
|
+
|
|
|
|
|
+ data = data.replace('<macro_start>', '[')
|
|
|
|
|
+ data = data.replace('<macro_middle>', '(')
|
|
|
|
|
+ data = data.replace('<macro_end>', ')]')
|
|
|
|
|
+
|
|
|
|
|
+ if re.search(r'\[pagecount\]', data, flags = re.I):
|
|
|
|
|
+ plus_data += 'page_count();\n'
|
|
|
|
|
+ data = re.sub(r'\[pagecount\]', '<span class="all_page_count"></span>', data, flags = re.I)
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\[date\]', now_time, data, flags = re.I)
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ block = re.search(r'(\n(?:> ?(?:(?:(?!\n).)+)?\n)+)', data)
|
|
|
|
|
+ if block:
|
|
|
|
|
+ block = block.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ block = re.sub(r'^\n> ?', '', block)
|
|
|
|
|
+ block = re.sub(r'\n> ?', '\n', block)
|
|
|
|
|
+ block = re.sub(r'\n$', '', block)
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'(\n(?:> ?(?:(?:(?!\n).)+)?\n)+)', '\n<blockquote>' + block + '</blockquote>\n', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ hr = re.search(r'\n-{4,9}\n', data)
|
|
|
|
|
+ if hr:
|
|
|
|
|
+ data = re.sub(r'\n-{4,9}\n', '\n<hr>\n', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'(?P<in>\n +\* ?(?:(?:(?!\|\|).)+))\|\|', '\g<in>\n ||', data)
|
|
|
|
|
+ data = re.sub(r'(?P<in><div id="folding_(?:[0-9]+)" style="display: none;"><div style="">|<blockquote>)(?P<out> )?\* ', '\g<in>\n\g<out>* ', data)
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ li = re.search(r'(\n(?:(?: *)\* ?(?:(?:(?!\n).)+)\n)+)', data)
|
|
|
|
|
+ if li:
|
|
|
|
|
+ li = li.group(1)
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ sub_li = re.search(r'\n(?:( *)\* ?((?:(?!\n).)+))', li)
|
|
|
|
|
+ if sub_li:
|
|
|
|
|
+ sub_li = sub_li.groups()
|
|
|
|
|
+
|
|
|
|
|
+ if len(sub_li[0]) == 0:
|
|
|
|
|
+ margin = 20
|
|
|
|
|
+ else:
|
|
|
|
|
+ margin = len(sub_li[0]) * 20
|
|
|
|
|
+
|
|
|
|
|
+ li = re.sub(r'\n(?:( *)\* ?((?:(?!\n).)+))', '<li style="margin-left: ' + str(margin) + 'px;">' + sub_li[1] + '</li>', li, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'(\n(?:(?: *)\* ?(?:(?:(?!\n).)+)\n)+)', '\n\n<ul>' + li + '</ul>\n', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'<\/ul>\n \|\|', '</ul>||', data)
|
|
|
|
|
+ data = re.sub(r'\|\|</blockquote>', '</blockquote>||', data)
|
|
|
|
|
+
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ indent = re.search(r'\n( +)', data)
|
|
|
|
|
+ if indent:
|
|
|
|
|
+ indent = len(indent.group(1))
|
|
|
|
|
+
|
|
|
|
|
+ margin = '<span style="margin-left: 20px;"></span>' * indent
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\n( +)', '\n' + margin, data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = table_start(data)
|
|
|
|
|
+
|
|
|
|
|
+ category = ''
|
|
|
|
|
+ link_re = re.compile('\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]')
|
|
|
|
|
+ category_re = re.compile(r'^(?:category|분류):', re.I)
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ link = link_re.search(data)
|
|
|
|
|
+ if link:
|
|
|
|
|
+ link = link.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ link_split = re.search(r'((?:(?!\|).)+)(?:\|((?:(?!\|).)+))', link)
|
|
|
|
|
+ if link_split:
|
|
|
|
|
+ link_split = link_split.groups()
|
|
|
|
|
+
|
|
|
|
|
+ main_link = link_split[0]
|
|
|
|
|
+ see_link = link_split[1]
|
|
|
|
|
+ else:
|
|
|
|
|
+ main_link = link
|
|
|
|
|
+ see_link = link
|
|
|
|
|
+
|
|
|
|
|
+ if re.search(r'^((?:file|파일)|(?:out|외부)):', main_link):
|
|
|
|
|
+ file_style = ''
|
|
|
|
|
+
|
|
|
|
|
+ file_width = re.search(r'width=((?:(?!&).)+)', see_link)
|
|
|
|
|
+ if file_width:
|
|
|
|
|
+ file_width = file_width.group(1)
|
|
|
|
|
+ if re.search(r'px$', file_width):
|
|
|
|
|
+ file_style += 'width: ' + file_width + ';'
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_style += 'width: ' + file_width + 'px;'
|
|
|
|
|
+
|
|
|
|
|
+ file_height = re.search(r'height=((?:(?!&).)+)', see_link)
|
|
|
|
|
+ if file_height:
|
|
|
|
|
+ file_height = file_height.group(1)
|
|
|
|
|
+ if re.search(r'px$', file_height):
|
|
|
|
|
+ file_style += 'height: ' + file_height + ';'
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_style += 'height: ' + file_height + 'px;'
|
|
|
|
|
+
|
|
|
|
|
+ file_align = re.search(r'align=((?:(?!&).)+)', see_link)
|
|
|
|
|
+ if file_align:
|
|
|
|
|
+ file_align = file_align.group(1)
|
|
|
|
|
+ if file_align == 'center':
|
|
|
|
|
+ file_align = 'display: block; text-align: center;'
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_align = 'float: ' + file_align + ';'
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_align = ''
|
|
|
|
|
+
|
|
|
|
|
+ file_color = re.search(r'bgcolor=((?:(?!&).)+)', see_link)
|
|
|
|
|
+ if file_color:
|
|
|
|
|
+ file_color = 'background: ' + file_color.group(1) + '; display: inline-block;'
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_color = ''
|
|
|
|
|
+
|
|
|
|
|
+ if re.search(r'^(?:out|외부):', main_link):
|
|
|
|
|
+ file_src = re.sub(r'^(?:out|외부):', '', main_link)
|
|
|
|
|
+
|
|
|
|
|
+ file_alt = main_link
|
|
|
|
|
+ exist = 'Yes'
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_data = re.search(r'^(?:file|파일):((?:(?!\.).)+)\.(.+)$', main_link)
|
|
|
|
|
+ if file_data:
|
|
|
|
|
+ file_data = file_data.groups()
|
|
|
|
|
+ file_name = file_data[0]
|
|
|
|
|
+ file_end = file_data[1]
|
|
|
|
|
+
|
|
|
|
|
+ if main_link != title:
|
|
|
|
|
+ backlink += [[title, main_link, 'file']]
|
|
|
|
|
+ else:
|
|
|
|
|
+ file_name = 'TEST'
|
|
|
|
|
+ file_end = 'jpg'
|
|
|
|
|
+
|
|
|
|
|
+ file_src = '/image/' + tool.sha224_replace(file_name) + '.' + file_end
|
|
|
|
|
+ file_alt = 'file:' + file_name + '.' + file_end
|
|
|
|
|
+ exist = None
|
|
|
|
|
+
|
|
|
|
|
+ data = link_re.sub(
|
|
|
|
|
+ '<span style="' + file_align + '">' + \
|
|
|
|
|
+ '<span style="' + file_color + '"' + \
|
|
|
|
|
+ 'class="' + include_name + 'file_finder" ' + \
|
|
|
|
|
+ 'under_style="' + file_style + '" ' + \
|
|
|
|
|
+ 'under_alt="' + file_alt + '" ' + \
|
|
|
|
|
+ 'under_src="' + file_src + '" ' + \
|
|
|
|
|
+ 'under_href="' + ("out_link" if exist else '/upload?name=' + tool.url_pas(file_name)) + '">' + \
|
|
|
|
|
+ '</span>' + \
|
|
|
|
|
+ '</span>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ elif category_re.search(main_link):
|
|
|
|
|
+ if category == '':
|
|
|
|
|
+ category += '<div id="cate_all"><hr><div id="cate">Category : '
|
|
|
|
|
+
|
|
|
|
|
+ main_link = category_re.sub('category:', main_link)
|
|
|
|
|
+ link_id = ''
|
|
|
|
|
+
|
|
|
|
|
+ curs.execute(tool.db_change("select title from data where title = ?"), [main_link])
|
|
|
|
|
+ if re.search(r'#blur', main_link):
|
|
|
|
|
+ link_id = ' hidden_link'
|
|
|
|
|
+ main_link = main_link.replace('#blur', '')
|
|
|
|
|
+ see_link = see_link.replace('#blur', '')
|
|
|
|
|
+
|
|
|
|
|
+ backlink += [[title, main_link, 'cat']]
|
|
|
|
|
+ category += '<a class="' + include_name + 'link_finder' + link_id + '" href="/w/' + tool.url_pas(main_link) + '">' + category_re.sub('', see_link) + '</a> | '
|
|
|
|
|
+
|
|
|
|
|
+ data = link_re.sub('', data, 1)
|
|
|
|
|
+ elif re.search(r'^wiki:', main_link):
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
+ '<a id="inside" href="/' + tool.url_pas(re.sub('^wiki:', '', main_link)) + '">' + see_link + '</a>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ elif re.search(r'^inter:((?:(?!:).)+):', main_link):
|
|
|
|
|
+ inter_data = re.search(r'^inter:((?:(?!:).)+):((?:(?!\]\]|\|).)+)', main_link)
|
|
|
|
|
+ inter_data = inter_data.groups()
|
|
|
|
|
+
|
|
|
|
|
+ curs.execute(tool.db_change('select link, icon from inter where title = ?'), [inter_data[0]])
|
|
|
|
|
+ inter = curs.fetchall()
|
|
|
|
|
+ if inter:
|
|
|
|
|
+ if inter[0][1] != '':
|
|
|
|
|
+ inter_view = inter[0][1]
|
|
|
|
|
+ else:
|
|
|
|
|
+ inter_view = inter_data[0] + ':'
|
|
|
|
|
+
|
|
|
|
|
+ if see_link != main_link:
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
+ '<a id="inside" href="' + inter[0][0] + inter_data[1] + '">' + inter_view + see_link + '</a>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
+ '<a id="inside" href="' + inter[0][0] + inter_data[1] + '">' + inter_view + inter_data[1] + '</a>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = link_re.sub('Not exist', data, 1)
|
|
|
|
|
+ elif re.search(r'^(\/(?:.+))$', main_link):
|
|
|
|
|
+ under_title = re.search(r'^(\/(?:.+))$', main_link)
|
|
|
|
|
+ under_title = under_title.group(1)
|
|
|
|
|
+
|
|
|
|
|
+ if see_link != main_link:
|
|
|
|
|
+ data = link_re.sub('[[' + title + under_title + '|' + see_link + ']]', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = link_re.sub('[[' + title + under_title + ']]', data, 1)
|
|
|
|
|
+ elif re.search(r'^http(s)?:\/\/', main_link):
|
|
|
|
|
+ data = link_re.sub('<a id="out_link" rel="nofollow" href="' + main_link + '">' + see_link + '</a>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ return_link = link_fix(main_link)
|
|
|
|
|
+ main_link = html.unescape(return_link[0])
|
|
|
|
|
+ other_link = return_link[1]
|
|
|
|
|
+
|
|
|
|
|
+ if re.search(r'^\/', main_link):
|
|
|
|
|
+ main_link = re.sub(r'^\/', title + '/', main_link)
|
|
|
|
|
+ elif re.search(r'\.\.\/\/', main_link):
|
|
|
|
|
+ main_link = re.sub(r'\.\.\/\/', '/', main_link)
|
|
|
|
|
+ elif re.search(r'^\.\.\/', main_link):
|
|
|
|
|
+ main_link = re.sub(r'^\.\.\/', re.sub(r'(?P<in>.+)\/.*$', '\g<in>', title), main_link)
|
|
|
|
|
+
|
|
|
|
|
+ if not re.search(r'^\|', main_link):
|
|
|
|
|
+ if main_link != title:
|
|
|
|
|
+ if main_link != '':
|
|
|
|
|
+ backlink += [[title, main_link, '']]
|
|
|
|
|
+
|
|
|
|
|
+ curs.execute(tool.db_change("select title from data where title = ?"), [main_link])
|
|
|
|
|
+ if not curs.fetchall():
|
|
|
|
|
+ backlink += [[title, main_link, 'no']]
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
+ '<a class="' + include_name + 'link_finder" ' + \
|
|
|
|
|
+ 'title="' + html.escape(main_link) + other_link + '" ' + \
|
|
|
|
|
+ 'href="/w/' + tool.url_pas(main_link) + other_link + '"' + \
|
|
|
|
|
+ '>' + see_link + '</a>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
+ '<a title="' + other_link + '" href="' + other_link + '">' + see_link + '</a>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ if re.search(r'^#', other_link):
|
|
|
|
|
+ data = re.sub(
|
|
|
|
|
+ '\[\[((?:(?!\[\[|\]\]|<\/td>).)+)\]\]',
|
|
|
|
|
+ '<a title="' + other_link + '" href="' + other_link + '">' + other_link + '</a>',
|
|
|
|
|
+ data,
|
|
|
|
|
+ 1
|
|
|
|
|
+ )
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = link_re.sub('<b>' + see_link + '</b>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = link_re.sub('[[' + link + ']]', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ br_re = re.compile(r'\[br\]', re.I)
|
|
|
|
|
+ data = br_re.sub('<br>', data)
|
|
|
|
|
+
|
|
|
|
|
+ footnote_number = 0
|
|
|
|
|
+
|
|
|
|
|
+ footnote_all = []
|
|
|
|
|
+ footnote_dict = {}
|
|
|
|
|
+ footnote_re = {}
|
|
|
|
|
+
|
|
|
|
|
+ footdata_all = '<hr><ul id="footnote_data">'
|
|
|
|
|
+
|
|
|
|
|
+ re_footnote = re.compile(r'(?:\[\*((?:(?! |\]).)*)(?: ((?:(?!(?:\[\*|\])).)+))?\]|(\[(?:각주|footnote)\]))')
|
|
|
|
|
+ while 1:
|
|
|
|
|
+ footnote = re_footnote.search(data)
|
|
|
|
|
+ if footnote:
|
|
|
|
|
+ footnote_data = footnote.groups()
|
|
|
|
|
+ if footnote_data[2]:
|
|
|
|
|
+ footnote_all.sort()
|
|
|
|
|
+
|
|
|
|
|
+ for footdata in footnote_all:
|
|
|
|
|
+ if footdata[2] == 0:
|
|
|
|
|
+ footdata_in = ''
|
|
|
|
|
+ else:
|
|
|
|
|
+ footdata_in = footdata[2]
|
|
|
|
|
+
|
|
|
|
|
+ footdata_all += '' + \
|
|
|
|
|
+ '<li>' + \
|
|
|
|
|
+ '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + str(footdata[0]) + '\', 1);" ' + \
|
|
|
|
|
+ 'id="' + include_name + 'cfn-' + str(footdata[0]) + '">' + \
|
|
|
|
|
+ '(' + footdata[1] + ')' + \
|
|
|
|
|
+ '</a> <span id="' + include_name + 'fn-' + str(footdata[0]) + '">' + footdata_in + '</span>' + \
|
|
|
|
|
+ '</li>' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ data = re_footnote.sub(footdata_all + '</ul>', data, 1)
|
|
|
|
|
+
|
|
|
|
|
+ footnote_all = []
|
|
|
|
|
+ footdata_all = '<hr><ul id="footnote_data">'
|
|
|
|
|
+ else:
|
|
|
|
|
+ footnote = footnote_data[1]
|
|
|
|
|
+ footnote_name = footnote_data[0]
|
|
|
|
|
+ if footnote_name and not footnote:
|
|
|
|
|
+ if footnote_name in footnote_dict:
|
|
|
|
|
+ footnote_re[footnote_name] += 1
|
|
|
|
|
+
|
|
|
|
|
+ foot_plus_num = str(footnote_re[footnote_name])
|
|
|
|
|
+ footshort = footnote_dict[footnote_name] + '.' + foot_plus_num
|
|
|
|
|
+
|
|
|
|
|
+ footnote_all += [[float(footshort), footshort, 0]]
|
|
|
|
|
+
|
|
|
|
|
+ data = re_footnote.sub('' + \
|
|
|
|
|
+ '<sup>' + \
|
|
|
|
|
+ '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + footshort + '\', 0);" ' + \
|
|
|
|
|
+ 'id="' + include_name + 'rfn-' + footshort + '">' + \
|
|
|
|
|
+ '(' + footnote_name + ')' + \
|
|
|
|
|
+ '</a>' + \
|
|
|
|
|
+ '</sup><span id="' + include_name + 'dfn-' + footshort + '"></span>' + \
|
|
|
|
|
+ '', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ data = re_footnote.sub('<sup><a href="javascript:void(0);">(' + footnote_name + ')</a></sup>', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ footnote_number += 1
|
|
|
|
|
+
|
|
|
|
|
+ if not footnote_name:
|
|
|
|
|
+ footnote_name = str(footnote_number)
|
|
|
|
|
+
|
|
|
|
|
+ footnote_dict.update({ footnote_name : str(footnote_number) })
|
|
|
|
|
+
|
|
|
|
|
+ if not footnote_name in footnote_re:
|
|
|
|
|
+ footnote_re.update({ footnote_name : 0 })
|
|
|
|
|
+ else:
|
|
|
|
|
+ footnote_re[footnote_name] += 1
|
|
|
|
|
+
|
|
|
|
|
+ footnote_all += [[footnote_number, footnote_name, footnote]]
|
|
|
|
|
+
|
|
|
|
|
+ data = re_footnote.sub('' + \
|
|
|
|
|
+ '<sup>' + \
|
|
|
|
|
+ '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + str(footnote_number) + '\', 0);" ' + \
|
|
|
|
|
+ 'id="' + include_name + 'rfn-' + str(footnote_number) + '">' + \
|
|
|
|
|
+ '(' + footnote_name + ')' + \
|
|
|
|
|
+ '</a>' + \
|
|
|
|
|
+ '</sup><span id="' + include_name + 'dfn-' + str(footnote_number) + '"></span>' + \
|
|
|
|
|
+ '', data, 1)
|
|
|
|
|
+ else:
|
|
|
|
|
+ break
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\n+$', '', data)
|
|
|
|
|
+
|
|
|
|
|
+ footnote_all.sort()
|
|
|
|
|
+
|
|
|
|
|
+ for footdata in footnote_all:
|
|
|
|
|
+ if footdata[2] == 0:
|
|
|
|
|
+ footdata_in = ''
|
|
|
|
|
+ else:
|
|
|
|
|
+ footdata_in = str(footdata[2])
|
|
|
|
|
+
|
|
|
|
|
+ footdata_all += '' + \
|
|
|
|
|
+ '<li>' + \
|
|
|
|
|
+ '<a href="javascript:do_open_foot(\'' + include_name + 'fn-' + str(footdata[0]) + '\', 1);" ' + \
|
|
|
|
|
+ 'id="' + include_name + 'cfn-' + str(footdata[0]) + '">' + \
|
|
|
|
|
+ '(' + str(footdata[1]) + ')' + \
|
|
|
|
|
+ '</a> <span id="' + include_name + 'fn-' + str(footdata[0]) + '">' + footdata_in + '</span>' + \
|
|
|
|
|
+ '</li>' + \
|
|
|
|
|
+ ''
|
|
|
|
|
+
|
|
|
|
|
+ footdata_all += '</ul>'
|
|
|
|
|
+ footdata_all = '</div>' + footdata_all
|
|
|
|
|
+ if footdata_all == '</div><hr><ul id="footnote_data"></ul>':
|
|
|
|
|
+ footdata_all = '</div>'
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'\n$', footdata_all, data + '\n', 1)
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r''''(?P<in>((?!''').)+)'''', '<b>\g<in></b>', data)
|
|
|
|
|
+ data = re.sub(r'''(?P<in>((?!'').)+)''', '<i>\g<in></i>', data)
|
|
|
|
|
+ data = re.sub(r'~~(?P<in>(?:(?!~~).)+)~~', '<s>\g<in></s>', data)
|
|
|
|
|
+ data = re.sub(r'--(?P<in>(?:(?!--).)+)--', '<s>\g<in></s>', data)
|
|
|
|
|
+ data = re.sub(r'__(?P<in>(?:(?!__).)+)__', '<u>\g<in></u>', data)
|
|
|
|
|
+ data = re.sub(r'\^\^(?P<in>(?:(?!\^\^).)+)\^\^', '<sup>\g<in></sup>', data)
|
|
|
|
|
+ data = re.sub(r',,(?P<in>(?:(?!,,).)+),,', '<sub>\g<in></sub>', data)
|
|
|
|
|
+
|
|
|
|
|
+ if category != '':
|
|
|
|
|
+ category = re.sub(r' \| $', '', category) + '</div></div>'
|
|
|
|
|
+
|
|
|
|
|
+ data += category
|
|
|
|
|
+
|
|
|
|
|
+ data = re.sub(r'<\/td_1>', '</td>', data)
|
|
|
|
|
+ data = re.sub(r'<\/ul>\n?', '</ul>', data)
|
|
|
|
|
+ data = re.sub(r'<\/pre>\n?', '</pre>', data)
|
|
|
|
|
+ data = re.sub(r'(?P<in><div class="all_in_data"(?:(?:(?!id=).)+)? id="in_data_([^"]+)">)(\n)+', '\g<in>', data)
|
|
|
|
|
+ data = re.sub(r'\n\n<ul>', '\n<ul>', data)
|
|
|
|
|
+ data = re.sub(r'<\/ul>\n\n', '</ul>', data)
|
|
|
|
|
+ data = re.sub(r'^(\n)+', '', data)
|
|
|
|
|
+ data = re.sub(r'(\n)+<hr><ul id="footnote_data">', '<hr><ul id="footnote_data">', data)
|
|
|
|
|
+ data = re.sub(r'(?P<in><td(((?!>).)*)>)\n', '\g<in>', data)
|
|
|
|
|
+ data = re.sub(r'(\n)?<hr>(\n)?', '<hr>', data)
|
|
|
|
|
+ data = re.sub(r'<\/ul>\n\n<ul>', '</ul>\n<ul>', data)
|
|
|
|
|
+ data = re.sub(r'<\/ul>\n<ul>', '</ul><ul>', data)
|
|
|
|
|
+ data = re.sub(r'\n<\/ul>', '</ul>', data)
|
|
|
|
|
+ data = re.sub(r'\n', '<br>', data)
|
|
|
|
|
+
|
|
|
|
|
+ plus_data = 'render_html("' + include_name + 'render_contect");\n' + plus_data
|
|
|
|
|
+
|
|
|
|
|
+ return [data, plus_data, backlink]
|