func_mark.py 6.1 KB

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