#!/usr/bin/env python3

import os
import datetime
import markdown

def load(fn):
  with open(fn) as f:
    return f.read()

style = load('autogen/html-style')
sitetitle = load('autogen/html-title').strip()

files = []

os.makedirs('doc/html',exist_ok=True)

with open('autogen/html-files') as f:
  for line in f:
    line = line.strip()
    line = line.split(':')
    if len(line) != 3: continue
    files += [line]

class superscripts(markdown.extensions.Extension):
  def extendMarkdown(self,md):
    md.inlinePatterns.register(markdown.inlinepatterns.SimpleTagInlineProcessor(r'()\^(.*?)\^','sup'),'sup',175)

# this paragraph derived from python-markdown
AUTOLINK_RE = r'<((?:[Ff]|[Hh][Tt])[Tt][Pp][Ss]?://[^<>]*)>'
class ttautolinkprocessor(markdown.inlinepatterns.InlineProcessor):
  def handleMatch(self,m,data):
    tt = markdown.inlinepatterns.etree.Element('span')
    tt.set('class','url')
    tt.text = markdown.inlinepatterns.util.AtomicString(m.group(1))
    e = markdown.inlinepatterns.etree.Element('a')
    e.set('href',self.unescape(m.group(1)))
    e.append(tt)
    return e,m.start(0),m.end(0)

class ttautolink(markdown.extensions.Extension):
  def extendMarkdown(self,md):
    md.inlinePatterns.register(ttautolinkprocessor(AUTOLINK_RE,md),'autolink',119)

for md,html,pagetitle in files:
  fnmd = 'doc/%s.md' % md
  fnhtml = 'doc/html/%s.html' % html
  output = ''

  x = load(fnmd)
  x = markdown.markdown(x,extensions=['markdown.extensions.extra','markdown.extensions.tables',superscripts(),ttautolink()])
  mtime = datetime.datetime.utcfromtimestamp(os.path.getmtime(fnmd)).strftime('%Y.%m.%d')

  output += '<html>\n<head>\n'
  output += style
  output += '<title>\n'
  output += sitetitle
  output += ': '
  output += pagetitle
  output += '</title>\n'
  output += '</head>\n'
  output += '<body>\n'

  output += '<div class=fixed>\n'

  output += '<div class=headline>\n'
  output += sitetitle
  output += '</div>\n'

  for submd,subhtml,subpagetitle in files:
    if subhtml == html:
      output += '<div class="navt here">'
      output += pagetitle+'\n'
    else:
      output += '<div class="navt away">'
      output += '<a href=%s.html>%s</a>\n' % (subhtml,subpagetitle)
    output += '</div>'
  output += '</div>\n'

  output += '<div class=main>\n'
  output += '<div class=pagetitle>'+sitetitle+': '+pagetitle+'</div>\n'
  output += x
  output += '<hr><font size=1><b>Version:</b>\n'
  output += 'This is version %s of the "%s" web page.\n' % (mtime,pagetitle)
  output += '</font>\n'
  output += '</div>\n'

  output += '</body>\n'
  output += '</html>\n'

  if not os.path.exists(fnhtml) or output != load(fnhtml):
    with open(fnhtml+'.new','w') as f:
      f.write(output)
    os.chmod(fnhtml+'.new',0o444)
    os.rename(fnhtml+'.new',fnhtml)