import config import search import datetime from datetime import datetime import os from os import path import pathlib import markdown ENTRY_DIR = config.ENTRY_DIR WEBSITE = config.WEBSITE def gen_stand_string(path_ex): """ Creates a html-string for a file. If the file is markdown it will convert it. This functions ensures upscaling for future formats. Parameters: path_ex: path to a file. Returns: string: html-formatted string string equivalent to the file """ filename = os.path.join(ENTRY_DIR, path_ex) result = "" if path.exists(filename): title = open(filename,encoding="utf-8").readline().rstrip("\n").lstrip("#").lstrip(" ") text = open(filename,encoding="utf-8").readlines()[1:] filename_no_end = filename.split(".", 1)[0] result += "

" + title + "

\n" if filename.endswith(".md"): result += gen_md_content(filename, 1) return result def gen_md_content(path_ex, depth): """ Convert a markdown file to a html string. Parameters: path_ex (string): path to the markdown file depth (int): starting depth for markdown headings Returns: string: html-formatted string string equivalent to the markdown file """ result = "" if path.exists(path_ex): filename = path_ex.split(".", 1) fileend = filename[len(filename) - 1] header = "#" for i in range(depth): header += "#" header += " " markdown_lines = open(path_ex, "r",encoding="utf-8").readlines()[1:] markdown_text = "" for line in markdown_lines: markdown_text += line.replace("# ", header) result = markdown.markdown( markdown_text, extensions=["fenced_code", "tables", "nl2br"]) return result def gen_arch_string(path_ex): """ Creates and returns an index string of every file in the path_ex. Parameter: path_ex: path to the dir to show Returns: string: html-formatted archive-string """ full_path = os.path.join(ENTRY_DIR, path_ex) if path.exists(full_path): name_list = os.listdir(full_path) full_list = [os.path.join(full_path, i) for i in name_list] contents = sorted(full_list, key=os.path.getctime) content_string = "" last_month = "" for file in reversed(contents): filename = pathlib.PurePath(file) if os.path.isfile(filename): title = open(filename).readline().rstrip("\n").lstrip("#").lstrip(" ") entry_or_namespace = "entry" elif os.path.isdir(filename): title = filename.name entry_or_namespace = "namespace" else: continue filename = filename.name if filename[0] != "." and filename.__contains__("."): filename = filename.split(".", 1)[0] content_string += "
  • " content_string += "" + title + "" content_string += "
    " content_string += "
  • \n" content_string += "\n" return content_string def gen_query_res_string(query_str): """ Return the results of a query. Parameters: query_str (string): term to search Returns: string: html-formated search result """ src_results = search.search(query_str) res_string = "" res_string += "\n" return res_string def create_preview(path): """ Create a preview of a given article and return it. Parameters: path (string): path to the article Returns: string: html-formated preview """ file = open(path, "r",encoding="utf-8") first_lines = file.readlines() preview = "" preview_length = 3 for i, line in enumerate(first_lines): if i == 0: continue if i > preview_length: break if not line.isspace(): preview += markdown.markdown(line) + "
    " else: preview_length += 1 preview += "...
    " return preview print(gen_arch_string("system-software"))