diff options
| author | Guido van Rossum <guido@python.org> | 1995-03-15 11:26:26 +0000 | 
|---|---|---|
| committer | Guido van Rossum <guido@python.org> | 1995-03-15 11:26:26 +0000 | 
| commit | b819bdfe8371be00b572e2e88e55b63730be7a7c (patch) | |
| tree | 260432e8c036cb70e5e3ecc9216f56030ea7e622 /Doc/partparse.py | |
| parent | 26a9d37e5c473f1489553ec9e0e8c0444a88ae9f (diff) | |
| download | cpython-git-b819bdfe8371be00b572e2e88e55b63730be7a7c.tar.gz | |
handle a few new things
Diffstat (limited to 'Doc/partparse.py')
| -rw-r--r-- | Doc/partparse.py | 48 | 
1 files changed, 33 insertions, 15 deletions
| diff --git a/Doc/partparse.py b/Doc/partparse.py index a62d6947f1..3c1c046000 100644 --- a/Doc/partparse.py +++ b/Doc/partparse.py @@ -788,6 +788,7 @@ def getnextarg(length, buf, pp, item):  			item = item+1  		return length, item  	else: +	        ch = pp[item]  		try:  			str = `s(buf, ch.data)`  		except TypeError: @@ -852,9 +853,9 @@ class Wobj:  		return self  	def write(self, data):  		self.data = self.data + data -		 +  # ignore these commands -ignoredcommands = ('bcode', 'ecode', 'optional') +ignoredcommands = ('bcode', 'ecode')  # map commands like these to themselves as plaintext  wordsselves = ('UNIX', 'ABC', 'C', 'ASCII', 'EOF')  # \{ --> {,  \} --> }, etc @@ -1080,7 +1081,7 @@ def do_funcdesc(length, buf, pp, i):  	idxsi = hist.indexsubitem	# words  	command = ''  	cat_class = '' -	if idxsi and idxsi[-1] in ('method', 'attribute'): +	if idxsi and idxsi[-1] in ('method', 'protocol'):  		command = 'defmethod'  		cat_class = string.join(idxsi[:-1])  	elif len(idxsi) == 2 and idxsi[1] == 'function': @@ -1170,9 +1171,9 @@ def do_datadesc(length, buf, pp, i):  	command = ''  	cat_class = ''  	class_class = '' -	if idxsi[-1] == 'attribute': +	if idxsi[-1] in ('attribute', 'option'):  		command = 'defcv' -		cat_class = 'attribute' +		cat_class = idxsi[-1]  		class_class = string.join(idxsi[:-1])  	elif len(idxsi) == 3 and idxsi[:2] == ['in', 'module']:  		command = 'defcv' @@ -1332,7 +1333,12 @@ def changeit(buf, pp):  					  chunk(GROUP, ch.where, ingroupch)]  				length, i = length+2, i+2 -			elif envname == 'tableiii': +			elif (envname == 'tableiii') or \ +			     (envname == 'tableii'): +				if (envname == 'tableii'): +					ltable = 2 +				else: +					ltable = 3  				wh = ch.where  				newcode = [] @@ -1359,7 +1365,8 @@ def changeit(buf, pp):  				del pp[i:newi]  				length = length - (newi-i) -				for count in range(3): +				itembody = [] +				for count in range(ltable):  					length, newi = getnextarg(length, buf, pp, i)  					emphgroup = [\  						  chunk(CSNAME, wh, 'emph'), \ @@ -1368,7 +1375,7 @@ def changeit(buf, pp):  					length = length - (newi-i)  					if count == 0:  						itemarg = emphgroup -					elif count == 2: +					elif count == ltable-1:  						itembody = itembody + \  							  [chunk(PLAIN, wh, '  ---  ')] + \  							  emphgroup @@ -1437,7 +1444,7 @@ def changeit(buf, pp):  					  chunk(GROUP, ch.where, [\  					  chunk(PLAIN, ch.where, 'table')])]  				i, length = i+2, length+2 -			elif envname == 'tableiii': +			elif (envname == 'tableiii') or (envname == 'tableii'):  				pp[i:i] = [\  					  chunk(CSLINE, ch.where, 'end'), \  					  chunk(GROUP, ch.where, [\ @@ -1457,7 +1464,16 @@ def changeit(buf, pp):  		elif ch.chtype == chunk_type(CSNAME):  			# control name transformations -			if s(buf, ch.data) in ignoredcommands: +			if s(buf, ch.data) == 'optional': +				pp[i-1].chtype = chunk_type (PLAIN) +				pp[i-1].data = '[' +				if (i < length) and \ +				   (pp[i].chtype == chunk_type(GROUP)): +					cp=pp[i].data +					pp[i:i+1]=cp + [\ +					    chunk(PLAIN, ch.where, ']')] +					length = length+len(cp) +			elif s(buf, ch.data) in ignoredcommands:  				del pp[i-1]  				i, length = i-1, length-1  			elif s(buf, ch.data) == '@' and \ @@ -1503,7 +1519,7 @@ def changeit(buf, pp):  					length = length - (newi-i)  					length, newi = getnextarg(length, buf, pp, i)  					text = flattext(buf, pp[i:newi]) -					if text[0] != '(' or text[-1] != ')': +					if text[:1] != '(' or text[-1:] != ')':  						raise error, 'expected indexsubitme enclosed in braces'  					words = string.split(text[1:-1])  					hist.indexsubitem = words @@ -1527,7 +1543,7 @@ def changeit(buf, pp):  				cat_class = ''  				if len(idxsi) >= 2 and idxsi[1] in \ -					  ('method', 'function'): +					  ('method', 'function', 'protocol'):  					command = 'findex'  				elif len(idxsi) >= 2 and idxsi[1] in \  					  ('exception', 'object'): @@ -1590,7 +1606,8 @@ def changeit(buf, pp):  				# \e --> \  				ch.data = '\\'  				ch.chtype = chunk_type(PLAIN) -			elif s(buf, ch.data) == 'lineiii': +			elif (s(buf, ch.data) == 'lineiii') or\ +			     (s(buf, ch.data) == 'lineii'):  				# This is the most tricky one  				# \lineiii{a1}{a2}[{a3}] -->  				# @item @<cts. of itemargmacro>{a1} @@ -1603,10 +1620,11 @@ def changeit(buf, pp):  				if not hist.inenv:  					raise error, \  						  'no environment for lineiii' -				if hist.inenv[0] != 'tableiii': +				if (hist.inenv[0] != 'tableiii') and\ +				   (hist.inenv[0] != 'tableii'):  					raise error, \  						  'wrong command (' + \ -						  `'lineiii'` + \ +						  s(buf, ch.data)+ \  						  ') in wrong environment (' \  						  + `hist.inenv[0]` + ')'  				ch.chtype = chunk_type(CSLINE) | 
