func_mark.py 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. from .func_tool import *
  2. # 커스텀 마크 언젠간 다시 추가 예정
  3. class class_do_render:
  4. def __init__(self, conn):
  5. self.conn = conn
  6. def do_backlink_generate(self, data_markup, doc_data, doc_name):
  7. conn = self.conn
  8. curs = self.conn.cursor()
  9. if data_markup == 'namumark':
  10. # Link
  11. link_re = re.compile(r'\[\[(?!https?:\/\/|inter:|외부:|out:|#)((?:(?!\[\[|\]\]|\|).)+)(?:\]\]|\|)', re.I)
  12. data_link = link_re.findall(doc_data)
  13. data_link = list(set(data_link))
  14. data_link_end = {}
  15. data_link_end['cat'] = []
  16. data_link_end['file'] = []
  17. data_link_end['link'] = []
  18. data_link_end_all = []
  19. for i in data_link:
  20. data_link_in = i
  21. if data_link_in.startswith('분류:') or \
  22. data_link_in.startswith('category:'):
  23. data_link_in = re.sub(r'\\(.)', r'\1', data_link_in)
  24. data_link_end['cat'] += [re.sub(r'^분류:', 'category:', data_link_in)]
  25. elif data_link_in.startswith('파일:') or \
  26. data_link_in.startswith('file:'):
  27. data_link_in = re.sub(r'\\(.)', r'\1', data_link_in)
  28. data_link_end['file'] += [re.sub(r'^파일:', 'file:', data_link_in)]
  29. else:
  30. data_link_in = re.sub(r'([^\\])#(?:[^#]*)$', r'\1', data_link_in)
  31. if data_link_in[0] == ':':
  32. data_link_in = re.sub(r'^:분류:', 'category:', data_link_in)
  33. data_link_in = re.sub(r'^:category:', 'category:', data_link_in)
  34. data_link_in = re.sub(r'^:file:', 'file:', data_link_in)
  35. data_link_in = re.sub(r'^:파일:', 'file:', data_link_in)
  36. elif data_link_in[0] == '/':
  37. data_link_in = doc_name + data_link_in
  38. elif len(data_link_in) >= 3 and data_link_in[0:3] == '../':
  39. data_link_in = data_link_in[3:len(data_link_in)]
  40. data_link_in = '' + \
  41. re.sub('\/[^/]+$', '', doc_name) + \
  42. (('/' + data_link_in) if data_link_in != '' else '') + \
  43. ''
  44. data_link_in = re.sub(r'\\(.)', r'\1', data_link_in)
  45. data_link_end['link'] += [data_link_in]
  46. if data_link_end != {}:
  47. data_link_end['cat'] = list(set(data_link_end['cat']))
  48. data_link_end['file'] = list(set(data_link_end['file']))
  49. data_link_end['link'] = list(set(data_link_end['link']))
  50. data_link_end_all += [[doc_name, i, 'cat'] for i in data_link_end['cat']]
  51. data_link_end_all += [[doc_name, i, 'file'] for i in data_link_end['file']]
  52. data_link_end_all += [[doc_name, i, ''] for i in data_link_end['link']]
  53. data_link_no = []
  54. for i in data_link_end['link']:
  55. curs.execute(db_change("select title from data where title = ?"), [i])
  56. if not curs.fetchall():
  57. data_link_no += [[doc_name, i, 'no']]
  58. data_link_end_all += data_link_no
  59. # Include
  60. include_re = re.compile(r'\[include\(((?:(?!\)\]).)+)\)\]', re.I)
  61. data_include = include_re.findall(doc_data)
  62. data_include = list(set(data_include))
  63. for i in data_include:
  64. data_include_in = i
  65. data_include_in = re.sub(r'([^\\]),.*$', r'\1', data_include_in)
  66. data_link_end_all += [[doc_name, data_include_in, 'include']]
  67. # Redirect
  68. redirect_re = re.compile(r'^#(?:redirect|넘겨주기) ([^\n]+)', re.I)
  69. data_redirect = redirect_re.search(doc_data)
  70. if data_redirect:
  71. data_redirect = data_redirect.group(1)
  72. data_redirect = re.sub(r'([^\\])#(?:[^#]*)$', r'\1', data_redirect)
  73. data_link_end_all += [[doc_name, data_redirect, 'redirect']]
  74. else:
  75. # markup == null
  76. data_link_end_all = []
  77. return data_link_end_all
  78. def do_render(self, doc_name, doc_data, data_type, data_in):
  79. conn = self.conn
  80. curs = self.conn.cursor()
  81. data_in = None if data_in == '' else data_in
  82. curs.execute(db_change('select data from other where name = "markup"'))
  83. rep_data = curs.fetchall()
  84. rep_data = rep_data[0][0] if rep_data else 'namumark'
  85. if data_type != 'backlink':
  86. if rep_data == 'namumark':
  87. data_in = (data_in + '_') if data_in else ''
  88. doc_data = html.escape(doc_data)
  89. doc_name = html.escape(doc_name)
  90. data_end = [
  91. '<pre class="render_content_load" id="' + data_in + 'render_content_load">' + doc_data + '</pre>' + \
  92. '<div class="render_content" id="' + data_in + 'render_content" style="display: none;"></div>',
  93. '''
  94. do_onmark_render(
  95. test_mode = "normal",
  96. name_id = "''' + data_in + '''render_content",
  97. name_include = "''' + data_in + '''",
  98. name_doc = "''' + doc_name + '''"
  99. );
  100. ''',
  101. []
  102. ]
  103. elif rep_data == 'markdown':
  104. data_in = (data_in + '_') if data_in else ''
  105. doc_data = html.escape(doc_data)
  106. doc_name = html.escape(doc_name)
  107. data_end = [
  108. '<pre class="render_content_load" id="' + data_in + 'render_content_load">' + html.escape(doc_data) + '</pre>' + \
  109. '<div class="render_content" id="' + data_in + 'render_content" style="display: none;"></div>',
  110. 'new opennamu_render_markdown(' + \
  111. 'render_part_id = "render_content_load",' + \
  112. 'render_part_id_after = "render_content",' + \
  113. 'render_part_id_add = "' + data_in + '",' + \
  114. 'doc_name = "' + doc_name + '"' + \
  115. ').do_main();',
  116. []
  117. ]
  118. else:
  119. data_end = [
  120. doc_data,
  121. '',
  122. []
  123. ]
  124. if data_type == 'api_view':
  125. return [
  126. data_end[0],
  127. data_end[1]
  128. ]
  129. else:
  130. return data_end[0] + '<script>' + data_end[1] + '</script>'
  131. else:
  132. backlink = self.do_backlink_generate(
  133. rep_data,
  134. doc_data,
  135. doc_name
  136. )
  137. if backlink != []:
  138. curs.executemany(db_change("insert into back (link, title, type) values (?, ?, ?)"), backlink)
  139. curs.execute(db_change("delete from back where title = ? and type = 'no'"), [doc_name])
  140. conn.commit()