summaryrefslogtreecommitdiff
path: root/src/pyssg/parser.py
blob: 2888fcbacad74267130ece21df0094d439017025 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
import os
from operator import itemgetter
from markdown import Markdown
from configparser import ConfigParser

from .database import Database
from .page import Page


# parser of md files, stores list of pages and tags
class MDParser:
    def __init__(self, files: list[str],
                 config: ConfigParser,
                 db: Database,
                 md: Markdown):
        self.files: list[str] = files

        self.config: ConfigParser = config
        self.db: Database = db
        self.md: Markdown = md

        self.all_pages: list[Page] = None
        self.updated_pages: list[Page] = None
        self.all_tags: list[tuple[str]] = None


    def parse(self) -> None:
        # initialize lists
        self.all_pages = []
        self.updated_pages = []
        self.all_tags = []
        # not used, not sure why i had this
        # all_tag_names: list[str] = []

        for f in self.files:
            src_file: str = os.path.join(self.config.get('path', 'src'), f)
            # get flag if update is successful
            updated: bool = self.db.update(src_file, remove=f'{self.config.get("path", "src")}/')

            content: str = self.md.reset().convert(open(src_file).read())
            page: Page = Page(f,
                              self.db.e[f][0],
                              self.db.e[f][1],
                              content,
                              self.md.Meta,
                              self.config)
            page.parse()

            # keep a separated list for all and updated pages
            if updated:
                self.updated_pages.append(page)
            self.all_pages.append(page)

            # parse tags
            if page.tags is not None:
                # add its tag to corresponding db entry if existent
                self.db.update_tags(f, list(map(itemgetter(0), page.tags)))

                # update all_tags attribute
                for t in page.tags:
                    if t[0] not in list(map(itemgetter(0), self.all_tags)):
                        self.all_tags.append(t)

        # sort list of tags for consistency
        self.all_tags.sort(key=itemgetter(0))
        self.updated_pages.sort(reverse=True)
        self.all_pages.sort(reverse=True)

        pages_amount: int = len(self.all_pages)
        # note that prev and next are switched because of the reverse rodering
        # of all_pages
        for i, p in enumerate(self.all_pages):
            if i != 0:
                next_page: Page = self.all_pages[i - 1]
                p.next = next_page

            if i != pages_amount - 1:
                prev_page: Page = self.all_pages[i + 1]
                p.previous = prev_page