summaryrefslogtreecommitdiff
path: root/docs
diff options
context:
space:
mode:
authorBen Gamari <ben@smart-cactus.org>2019-10-06 17:05:50 -0400
committerMarge Bot <ben+marge-bot@smart-cactus.org>2019-10-08 05:12:58 -0400
commitca4791dba46b0c285763d3dd76a9c8a61b279a35 (patch)
tree44e4442269456e44b3e19984e27ae77d75eace93 /docs
parent0a26f9e8e4714d547b8c20d2d5ce1ba0644316bf (diff)
downloadhaskell-ca4791dba46b0c285763d3dd76a9c8a61b279a35.tar.gz
users-guide: Rework pragma key generation
Previously we had a hack to handle the case of multi-token SPECIALISE pragmas. Now we use a slightly more general rule of using a prefix of tokens containing only alphabetical characters.
Diffstat (limited to 'docs')
-rw-r--r--docs/users_guide/conf.py14
1 files changed, 8 insertions, 6 deletions
diff --git a/docs/users_guide/conf.py b/docs/users_guide/conf.py
index c3d5a3590c..1f6f8b5b11 100644
--- a/docs/users_guide/conf.py
+++ b/docs/users_guide/conf.py
@@ -147,14 +147,16 @@ def parse_ghci_cmd(env, sig, signode):
return name
def parse_pragma(env, sig, signode):
+ # Collect a prefix of alphabetical tokens to use as the pragma name
parts = sig.split(' ')
- idx = parts[0]
+ idx_parts = []
+ for part in parts:
+ if all(c.isalpha() or c == "_" for c in part):
+ idx_parts.append(part)
+ else:
+ break
+ idx = '-'.join(idx_parts)
- # To avoid re-using the same HTTP anchor #pragma-SPECIALIZE in multiple
- # places, we disambiguate the anchor by adding the second word after it (if
- # one exists).
- if idx == "SPECIALIZE" and 1 in parts and parts[1].isalpha():
- idx += "-" + parts[1]
name = '{-# ' + sig + ' #-}'
signode += addnodes.desc_name(name, name)
return idx