Fix to internal links heisenbug, added -d switch for Headwar.
This commit is contained in:
parent
51e1ec56c6
commit
c26b7c1f3f
59
build.py
59
build.py
@ -18,15 +18,25 @@ import shutil
|
|||||||
import argparse
|
import argparse
|
||||||
|
|
||||||
|
|
||||||
|
# Global vars
|
||||||
|
# This matches all *non* letter/number, ' ', '.', '-', and '_' chars
|
||||||
|
cleanString = re.compile(r'[^a-zA-Z0-9 \._-]+')
|
||||||
|
# This matches new 'unbreakable' links, up to the closing quote or anchor
|
||||||
|
findLinks = re.compile(r'@@[^#"]*')
|
||||||
|
|
||||||
#
|
#
|
||||||
# Create an all lowercase filename without special characters and with spaces
|
# Create an all lowercase filename without special characters and with spaces
|
||||||
# replaced with dashes.
|
# replaced with dashes.
|
||||||
#
|
#
|
||||||
def MakeFilename(s):
|
def MakeFilename(s):
|
||||||
# Cleans up the file name, removing all non ASCII or .-_ chars
|
global cleanString
|
||||||
fn = re.sub(r'[^.\-_a-zA-Z0-9 ]', '', s)
|
# Clean up the file name, removing all non letter/number or " .-_" chars.
|
||||||
fn = fn.lower()
|
# Also, convert to lower case and replace all spaces with dashes.
|
||||||
fn = fn.replace(' ', '-')
|
fn = cleanString.sub('', s).lower().replace(' ', '-')
|
||||||
|
# Double dashes can creep in from the above replacement, so we check for
|
||||||
|
# that here.
|
||||||
|
fn = fn.replace('--', '-')
|
||||||
|
|
||||||
return fn
|
return fn
|
||||||
|
|
||||||
|
|
||||||
@ -122,7 +132,8 @@ def GetFileStructure():
|
|||||||
for i in range(level + 1):
|
for i in range(level + 1):
|
||||||
fullName = fullName + fnames[i] + '/'
|
fullName = fullName + fnames[i] + '/'
|
||||||
|
|
||||||
hdr['filename'] = fullName.rstrip('/')
|
# Strip trailing '/' on filename
|
||||||
|
hdr['filename'] = fullName[:-1]
|
||||||
|
|
||||||
fs.append(hdr)
|
fs.append(hdr)
|
||||||
|
|
||||||
@ -226,25 +237,27 @@ def FindInternalLinks(fs):
|
|||||||
# them with the appropriate link.
|
# them with the appropriate link.
|
||||||
#
|
#
|
||||||
def FixInternalLinks(links, content, title):
|
def FixInternalLinks(links, content, title):
|
||||||
|
global findLinks
|
||||||
# Make key1|key2|key3|... out of our links keys
|
match = findLinks.findall(content)
|
||||||
pattern = re.compile('|'.join(links.keys()))
|
missing = []
|
||||||
|
|
||||||
# Use a lambda callback to substitute each occurance found
|
|
||||||
result = pattern.sub(lambda x: links[x.group()], content)
|
|
||||||
|
|
||||||
# Check for missing link targets, and report them to the user
|
|
||||||
match = re.findall('"@@.*"', result)
|
|
||||||
|
|
||||||
if len(match) > 0:
|
if len(match) > 0:
|
||||||
print('\nMissing link target' + ('s' if len(match) > 1 else '') + ' in "' + title + '":')
|
|
||||||
|
|
||||||
for s in match:
|
for s in match:
|
||||||
print(' ' + s[3:-1])
|
if s in links:
|
||||||
|
content = content.replace(s, links[s])
|
||||||
|
else:
|
||||||
|
missing.append(s)
|
||||||
|
|
||||||
|
# Report missing link targets to the user (if any)
|
||||||
|
if len(missing) > 0:
|
||||||
|
print('\nMissing link target' + ('s' if len(missing) > 1 else '') + ' in "' + title + '":')
|
||||||
|
|
||||||
|
for s in missing:
|
||||||
|
print(' ' + s)
|
||||||
|
|
||||||
print()
|
print()
|
||||||
|
|
||||||
return result
|
return content
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -297,14 +310,15 @@ def CreateLinkSidebar(fs, pos, childList):
|
|||||||
parser = argparse.ArgumentParser(description='A build script for the Ardour Manual')
|
parser = argparse.ArgumentParser(description='A build script for the Ardour Manual')
|
||||||
parser.add_argument('-v', '--verbose', action='store_true', help='Display the high-level structure of the manual')
|
parser.add_argument('-v', '--verbose', action='store_true', help='Display the high-level structure of the manual')
|
||||||
parser.add_argument('-q', '--quiet', action='store_true', help='Suppress all output (overrides -v)')
|
parser.add_argument('-q', '--quiet', action='store_true', help='Suppress all output (overrides -v)')
|
||||||
|
parser.add_argument('-d', '--devmode', action='store_true', help='Add content to pages to help developers debug them')
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
verbose = args.verbose
|
verbose = args.verbose
|
||||||
quiet = args.quiet
|
quiet = args.quiet
|
||||||
|
devmode = args.devmode
|
||||||
|
|
||||||
if quiet:
|
if quiet:
|
||||||
verbose = False
|
verbose = False
|
||||||
|
|
||||||
#verbose = False
|
|
||||||
level = 0
|
level = 0
|
||||||
fileCount = 0
|
fileCount = 0
|
||||||
levelNums = [0]*6
|
levelNums = [0]*6
|
||||||
@ -315,6 +329,9 @@ pageNumber = 0
|
|||||||
|
|
||||||
siteDir = './website/'
|
siteDir = './website/'
|
||||||
|
|
||||||
|
if not quiet and devmode:
|
||||||
|
print('Devmode active: scribbling extra junk to the manual...')
|
||||||
|
|
||||||
if os.access(siteDir, os.F_OK):
|
if os.access(siteDir, os.F_OK):
|
||||||
if not quiet:
|
if not quiet:
|
||||||
print('Removing stale HTML data...')
|
print('Removing stale HTML data...')
|
||||||
@ -454,6 +471,10 @@ for header in fileStruct:
|
|||||||
# Fix up any internal links
|
# Fix up any internal links
|
||||||
content = FixInternalLinks(links, content, header['title'])
|
content = FixInternalLinks(links, content, header['title'])
|
||||||
|
|
||||||
|
# Add header information to the page if in dev mode
|
||||||
|
if devmode and 'link' in header:
|
||||||
|
content = '<h1>link: ' + header['link'] + '</h2>\n<br><br>\n' + content
|
||||||
|
|
||||||
# Set up the actual page from the template
|
# Set up the actual page from the template
|
||||||
if 'style' not in header:
|
if 'style' not in header:
|
||||||
page = re.sub("{% if page.style %}.*\n.*\n{% endif %}.*\n", "", template)
|
page = re.sub("{% if page.style %}.*\n.*\n{% endif %}.*\n", "", template)
|
||||||
|
13
explode.py
13
explode.py
@ -12,6 +12,7 @@ import re
|
|||||||
import shutil
|
import shutil
|
||||||
|
|
||||||
lineCount = 0
|
lineCount = 0
|
||||||
|
cleanString = re.compile(r'[^a-zA-Z0-9 \._-]+')
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -19,10 +20,14 @@ lineCount = 0
|
|||||||
# replaced with dashes.
|
# replaced with dashes.
|
||||||
#
|
#
|
||||||
def MakeFilename(s):
|
def MakeFilename(s):
|
||||||
# Cleans up the file name, removing all non ASCII or .-_ chars
|
global cleanString
|
||||||
fn = re.sub(r'[^.\-_a-zA-Z0-9 ]', '', s)
|
# Clean up the file name, removing all non letter/number or " .-_" chars.
|
||||||
fn = fn.lower()
|
# Also, convert to lower case and replace all spaces with dashes.
|
||||||
fn = fn.replace(' ', '-')
|
fn = cleanString.sub('', s).lower().replace(' ', '-')
|
||||||
|
# Double dashes can creep in from the above replacement, so we check for
|
||||||
|
# that here.
|
||||||
|
fn = fn.replace('--', '-')
|
||||||
|
|
||||||
return fn
|
return fn
|
||||||
|
|
||||||
|
|
||||||
|
@ -1675,7 +1675,7 @@ part: subchapter
|
|||||||
---
|
---
|
||||||
|
|
||||||
---
|
---
|
||||||
title: Automating MIDI—Pitch bending and aftertouch
|
title: Automating MIDI--Pitch bending and aftertouch
|
||||||
menu_title: Automating MIDI
|
menu_title: Automating MIDI
|
||||||
include: automating-midi---pitch-bending-and-aftertouch.html
|
include: automating-midi---pitch-bending-and-aftertouch.html
|
||||||
link: automating-midi---pitch-bending-and-aftertouch
|
link: automating-midi---pitch-bending-and-aftertouch
|
||||||
@ -1684,7 +1684,7 @@ part: subchapter
|
|||||||
---
|
---
|
||||||
|
|
||||||
---
|
---
|
||||||
title: Transforming MIDI—Mathematical operations
|
title: Transforming MIDI--Mathematical operations
|
||||||
menu_title: Transforming MIDI
|
menu_title: Transforming MIDI
|
||||||
include: transforming-midi---mathematical-operations.html
|
include: transforming-midi---mathematical-operations.html
|
||||||
link: transforming-midi---mathematical-operations
|
link: transforming-midi---mathematical-operations
|
||||||
|
Loading…
Reference in New Issue
Block a user