34 lines
1.1 KiB
Python
34 lines
1.1 KiB
Python
from orgparse import loads
|
|
|
|
blogDir: str = "./blogs"
|
|
debug: bool = True
|
|
|
|
def debugPrint(msg: str) -> None:
|
|
if debug:
|
|
print("(ORG HANDLER) PRINT: " + msg)
|
|
|
|
def checkAndRetrieveMetadata(fileData: str, metadataName: str):
|
|
line = fileData.readline()
|
|
metadataFullName = "#+" + metadataName + ":"
|
|
if metadataFullName in line:
|
|
linetoarray = line.split()
|
|
return " ".join(linetoarray[1:])
|
|
else:
|
|
debugPrint("Could not find " + metadataFullName + " metadata field of document!")
|
|
return False
|
|
|
|
def orgToHTML(orgData: str) -> str:
|
|
try:
|
|
orgRoot = loads(orgData)
|
|
parsedHTML = ""
|
|
|
|
for node in orgRoot[1:]:
|
|
if node.heading:
|
|
headingLevel = str(node.level if node.level <= 6 else 6)
|
|
parsedHTML += "<h" + headingLevel + ">" + node.heading + "</h" + headingLevel + ">" + "\n"
|
|
if node.body:
|
|
parsedHTML += node.body + "\n"
|
|
return parsedHTML
|
|
except Exception as error:
|
|
debugPrint("Error parsing org! Unexpected error: " + repr(error) + ".")
|