2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#!/usr/bin/env python3  
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-24 01:48:03 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# This script makes RST files from the XML class reference for use with the online docs.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  argparse  
						 
					
						
							
								
									
										
										
										
											2017-09-22 16:55:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  os  
						 
					
						
							
								
									
										
										
										
											2018-06-11 13:35:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  re  
						 
					
						
							
								
									
										
										
										
											2022-06-11 00:16:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  sys  
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								import  xml . etree . ElementTree  as  ET  
						 
					
						
							
								
									
										
										
										
											2019-04-04 21:40:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  collections  import  OrderedDict  
						 
					
						
							
								
									
										
										
										
											2024-05-21 15:14:59 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  typing  import  Any ,  Dict ,  List ,  Optional ,  TextIO ,  Tuple ,  Union  
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								sys . path . insert ( 0 ,  root_directory  :=  os . path . join ( os . path . dirname ( os . path . abspath ( __file__ ) ) ,  " ../../ " ) )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  version  
						 
					
						
							
								
									
										
										
										
											2025-03-25 12:20:00 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from  misc . utility . color  import  Ansi ,  force_stderr_color ,  force_stdout_color  
						 
					
						
							
								
									
										
										
										
											2022-07-26 18:20:51 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-15 10:39:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# $DOCS_URL/path/to/page.html(#fragment-tag)  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								GODOT_DOCS_PATTERN  =  re . compile ( r " ^ \ $DOCS_URL/(.*) \ .html(#.*)?$ " )  
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Based on reStructuredText inline markup recognition rules  
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# https://docutils.sourceforge.io/docs/ref/rst/restructuredtext.html#inline-markup-recognition-rules  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								MARKUP_ALLOWED_PRECEDENT  =  "  -:/ ' \" <([ { "  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								MARKUP_ALLOWED_SUBSEQUENT  =  "  -.,:;!? \\ / ' \" )]}> "  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Used to translate section headings and other hardcoded strings when required with  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# the --lang argument. The BASE_STRINGS list should be synced with what we actually  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# write in this script (check `translate()` uses), and also hardcoded in  
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# `scripts/extract_classes.py` (godotengine/godot-editor-l10n repo) to include them in the source POT file.  
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								BASE_STRINGS  =  [  
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:47:53 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " All classes " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Globals " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Nodes " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Resources " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-24 21:06:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Editor-only " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:47:53 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Other objects " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Variant types " , 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Description " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Tutorials " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Properties " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Constructors " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Methods " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Operators " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Theme Properties " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Signals " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Enumerations " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Constants " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Annotations " , 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Property Descriptions " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Constructor Descriptions " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Method Descriptions " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Operator Descriptions " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Theme Property Descriptions " , 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Inherits: " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Inherited By: " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " (overrides  %s ) " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Default " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Setter " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " value " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Getter " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This method should typically be overridden by the user to have any effect. " , 
							 
						 
					
						
							
								
									
										
										
										
											2025-06-05 11:11:08 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " This method is required to be overridden when extending its base class. " , 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " This method has no side effects. It doesn ' t modify any of the instance ' s member variables. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This method accepts any number of arguments after the ones described here. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This method is used to construct a type. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This method doesn ' t need an instance to be called, so it can be called directly using the class name. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This method describes a valid operator to use with this type as left-hand operand. " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " This value is an integer composed as a bitmask of the following flags. " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " No return value. " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-08 13:17:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " There is currently no description for this class. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this signal. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-16 18:19:41 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " There is currently no description for this enum. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this constant. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-08 13:17:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " There is currently no description for this annotation. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this constructor. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this operator. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There is currently no description for this theme property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " There are notable differences when using this API with C#. See :ref:`doc_c_sharp_differences` for more information. " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Deprecated: " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Experimental: " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This signal may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This constant may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This property may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This constructor may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This method may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This operator may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " This theme property may be changed or removed in future versions. " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 16:39:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " [b]Note:[/b] The returned array is [i]copied[/i] and any changes to it will not update the original property value. See [ %s ] for more details. " , 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								]  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								strings_l10n :  Dict [ str ,  str ]  =  { }  
						 
					
						
							
								
									
										
										
										
											2018-06-11 13:35:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								CLASS_GROUPS :  Dict [ str ,  str ]  =  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " global " :  " Globals " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " node " :  " Nodes " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " resource " :  " Resources " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:47:53 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " object " :  " Other objects " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-24 21:06:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " editor " :  " Editor-only " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:47:53 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " variant " :  " Variant types " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								CLASS_GROUPS_BASE :  Dict [ str ,  str ]  =  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " node " :  " Node " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " resource " :  " Resource " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " object " :  " Object " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-24 21:06:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " variant " :  " Variant " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
									
										
										
										
											2023-04-24 21:06:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Sync with editor\register_editor_types.cpp  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								EDITOR_CLASSES :  List [ str ]  =  [  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " FileSystemDock " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " ScriptCreateDialog " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " ScriptEditor " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " ScriptEditorBase " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								]  
						 
					
						
							
								
									
										
										
										
											2023-07-08 13:17:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Sync with the types mentioned in https://docs.godotengine.org/en/stable/tutorials/scripting/c_sharp/c_sharp_differences.html  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								CLASSES_WITH_CSHARP_DIFFERENCES :  List [ str ]  =  [  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " @GlobalScope " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " String " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-30 14:42:02 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " StringName " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-08 13:17:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " NodePath " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Signal " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Callable " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " RID " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Basis " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Transform2D " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Transform3D " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Rect2 " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Rect2i " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " AABB " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Quaternion " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Projection " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Color " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " Dictionary " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedByteArray " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedColorArray " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedFloat32Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedFloat64Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedInt32Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedInt64Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedStringArray " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedVector2Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedVector3Array " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-04-08 07:51:34 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " PackedVector4Array " , 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-08 13:17:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " Variant " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								]  
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 16:39:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								PACKED_ARRAY_TYPES :  List [ str ]  =  [  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedByteArray " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedColorArray " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedFloat32Array " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-09-22 21:09:08 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " PackedFloat64Array " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 16:39:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " PackedInt32Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedInt64Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedStringArray " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedVector2Array " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " PackedVector3Array " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-04-08 07:51:34 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    " PackedVector4Array " , 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 16:39:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class  State :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-11 00:43:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . num_errors  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . num_warnings  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . classes :  OrderedDict [ str ,  ClassDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . current_class :  str  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Additional content and structure checks and validators. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . script_language_parity_check :  ScriptLanguageParityCheck  =  ScriptLanguageParityCheck ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  parse_class ( self ,  class_root :  ET . Element ,  filepath :  str )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        class_name  =  class_root . attrib [ " name " ] 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 02:52:27 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . current_class  =  class_name 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        class_def  =  ClassDef ( class_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . classes [ class_name ]  =  class_def 
							 
						 
					
						
							
								
									
										
										
										
											2021-02-14 03:10:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        class_def . filepath  =  filepath 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        inherits  =  class_root . get ( " inherits " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  inherits  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            class_def . inherits  =  inherits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        class_def . deprecated  =  class_root . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        class_def . experimental  =  class_root . get ( " experimental " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        brief_desc  =  class_root . find ( " brief_description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  brief_desc  is  not  None  and  brief_desc . text : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            class_def . brief_description  =  brief_desc . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        desc  =  class_root . find ( " description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  desc  is  not  None  and  desc . text : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            class_def . description  =  desc . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-07-03 18:18:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        keywords  =  class_root . get ( " keywords " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  keywords  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            class_def . keywords  =  keywords 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        properties  =  class_root . find ( " members " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  properties  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  property  in  properties : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  property . tag  ==  " member " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                property_name  =  property . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  property_name  in  class_def . properties : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    print_error ( f ' { class_name } .xml: Duplicate property  " { property_name } " . ' ,  self ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                type_name  =  TypeName . from_element ( property ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                setter  =  property . get ( " setter " )  or  None   # Use or None so '' gets turned into None. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                getter  =  property . get ( " getter " )  or  None 
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                default_value  =  property . get ( " default " )  or  None 
							 
						 
					
						
							
								
									
										
										
										
											2019-11-29 14:21:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  default_value  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    default_value  =  f " `` { default_value } `` " 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-02 22:38:49 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                overrides  =  property . get ( " overrides " )  or  None 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                property_def  =  PropertyDef ( 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-02 22:38:49 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    property_name ,  type_name ,  setter ,  getter ,  property . text ,  default_value ,  overrides 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                property_def . deprecated  =  property . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                property_def . experimental  =  property . get ( " experimental " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                class_def . properties [ property_name ]  =  property_def 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        constructors  =  class_root . find ( " constructors " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  constructors  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  constructor  in  constructors : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  constructor . tag  ==  " constructor " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_name  =  constructor . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                qualifiers  =  constructor . get ( " qualifiers " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return_element  =  constructor . find ( " return " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  return_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    return_type  =  TypeName . from_element ( return_element ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    return_type  =  TypeName ( " void " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 21:11:48 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                params  =  self . parse_params ( constructor ,  " constructor " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                desc_element  =  constructor . find ( " description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_desc  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  desc_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    method_desc  =  desc_element . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_def  =  MethodDef ( method_name ,  return_type ,  params ,  method_desc ,  qualifiers ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                method_def . definition_name  =  " constructor " 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                method_def . deprecated  =  constructor . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_def . experimental  =  constructor . get ( " experimental " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  method_name  not  in  class_def . constructors : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    class_def . constructors [ method_name ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                class_def . constructors [ method_name ] . append ( method_def ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        methods  =  class_root . find ( " methods " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  methods  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  method  in  methods : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  method . tag  ==  " method " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_name  =  method . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                qualifiers  =  method . get ( " qualifiers " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return_element  =  method . find ( " return " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  return_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    return_type  =  TypeName . from_element ( return_element ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    return_type  =  TypeName ( " void " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 21:11:48 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                params  =  self . parse_params ( method ,  " method " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                desc_element  =  method . find ( " description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_desc  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  desc_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    method_desc  =  desc_element . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_def  =  MethodDef ( method_name ,  return_type ,  params ,  method_desc ,  qualifiers ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                method_def . deprecated  =  method . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_def . experimental  =  method . get ( " experimental " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  method_name  not  in  class_def . methods : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    class_def . methods [ method_name ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                class_def . methods [ method_name ] . append ( method_def ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        operators  =  class_root . find ( " operators " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  operators  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  operator  in  operators : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  operator . tag  ==  " operator " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_name  =  operator . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                qualifiers  =  operator . get ( " qualifiers " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return_element  =  operator . find ( " return " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  return_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    return_type  =  TypeName . from_element ( return_element ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    return_type  =  TypeName ( " void " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 21:11:48 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                params  =  self . parse_params ( operator ,  " operator " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                desc_element  =  operator . find ( " description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_desc  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  desc_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    method_desc  =  desc_element . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_def  =  MethodDef ( method_name ,  return_type ,  params ,  method_desc ,  qualifiers ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                method_def . definition_name  =  " operator " 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                method_def . deprecated  =  operator . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                method_def . experimental  =  operator . get ( " experimental " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  method_name  not  in  class_def . operators : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    class_def . operators [ method_name ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                class_def . operators [ method_name ] . append ( method_def ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        constants  =  class_root . find ( " constants " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  constants  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  constant  in  constants : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  constant . tag  ==  " constant " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                constant_name  =  constant . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                value  =  constant . attrib [ " value " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                enum  =  constant . get ( " enum " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                is_bitfield  =  constant . get ( " is_bitfield " )  ==  " true " 
							 
						 
					
						
							
								
									
										
										
										
											2022-06-24 11:16:37 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                constant_def  =  ConstantDef ( constant_name ,  value ,  constant . text ,  is_bitfield ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                constant_def . deprecated  =  constant . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                constant_def . experimental  =  constant . get ( " experimental " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  enum  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  constant_name  in  class_def . constants : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        print_error ( f ' { class_name } .xml: Duplicate constant  " { constant_name } " . ' ,  self ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        continue 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    class_def . constants [ constant_name ]  =  constant_def 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  enum  in  class_def . enums : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        enum_def  =  class_def . enums [ enum ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    else : 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        enum_def  =  EnumDef ( enum ,  TypeName ( " int " ,  enum ) ,  is_bitfield ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        class_def . enums [ enum ]  =  enum_def 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    enum_def . values [ constant_name ]  =  constant_def 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        annotations  =  class_root . find ( " annotations " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  annotations  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  annotation  in  annotations : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  annotation . tag  ==  " annotation " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                annotation_name  =  annotation . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                qualifiers  =  annotation . get ( " qualifiers " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 21:11:48 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                params  =  self . parse_params ( annotation ,  " annotation " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                desc_element  =  annotation . find ( " description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                annotation_desc  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  desc_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    annotation_desc  =  desc_element . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-04 15:42:20 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                annotation_def  =  AnnotationDef ( annotation_name ,  params ,  annotation_desc ,  qualifiers ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  annotation_name  not  in  class_def . annotations : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    class_def . annotations [ annotation_name ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                class_def . annotations [ annotation_name ] . append ( annotation_def ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        signals  =  class_root . find ( " signals " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  signals  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  signal  in  signals : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  signal . tag  ==  " signal " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                signal_name  =  signal . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  signal_name  in  class_def . signals : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    print_error ( f ' { class_name } .xml: Duplicate signal  " { signal_name } " . ' ,  self ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 21:11:48 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                params  =  self . parse_params ( signal ,  " signal " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                desc_element  =  signal . find ( " description " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                signal_desc  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  desc_element  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    signal_desc  =  desc_element . text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                signal_def  =  SignalDef ( signal_name ,  params ,  signal_desc ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                signal_def . deprecated  =  signal . get ( " deprecated " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                signal_def . experimental  =  signal . get ( " experimental " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                class_def . signals [ signal_name ]  =  signal_def 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        theme_items  =  class_root . find ( " theme_items " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  theme_items  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  theme_item  in  theme_items : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  theme_item . tag  ==  " theme_item " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                theme_item_name  =  theme_item . attrib [ " name " ] 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                theme_item_data_name  =  theme_item . attrib [ " data_type " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                theme_item_id  =  " {} _ {} " . format ( theme_item_data_name ,  theme_item_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  theme_item_id  in  class_def . theme_items : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        f ' { class_name } .xml: Duplicate theme property  " { theme_item_name } "  of type  " { theme_item_data_name } " . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        self , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                default_value  =  theme_item . get ( " default " )  or  None 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  default_value  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    default_value  =  f " `` { default_value } `` " 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                theme_item_def  =  ThemeItemDef ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    theme_item_name , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    TypeName . from_element ( theme_item ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    theme_item_data_name , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    theme_item . text , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    default_value , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-18 15:03:03 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                class_def . theme_items [ theme_item_name ]  =  theme_item_def 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        tutorials  =  class_root . find ( " tutorials " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  tutorials  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  link  in  tutorials : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                assert  link . tag  ==  " link " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  link . text  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-29 21:55:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    class_def . tutorials . append ( ( link . text . strip ( ) ,  link . get ( " title " ,  " " ) ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 02:52:27 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . current_class  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 21:11:48 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  parse_params ( self ,  root :  ET . Element ,  context :  str )  - >  List [ " ParameterDef " ] : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        param_elements  =  root . findall ( " param " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 02:52:27 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        params :  Any  =  [ None ]  *  len ( param_elements ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  param_index ,  param_element  in  enumerate ( param_elements ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            param_name  =  param_element . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            index  =  int ( param_element . attrib [ " index " ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            type_name  =  TypeName . from_element ( param_element ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            default  =  param_element . get ( " default " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  param_name . strip ( )  ==  " "  or  param_name . startswith ( " _unnamed_arg " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f ' { self . current_class } .xml: Empty argument name in  { context }   " { root . attrib [ " name " ] } "  at position  { param_index } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 02:52:27 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    self , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            params [ index ]  =  ParameterDef ( param_name ,  type_name ,  default ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        cast :  List [ ParameterDef ]  =  params 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  cast 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  sort_classes ( self )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . classes  =  OrderedDict ( sorted ( self . classes . items ( ) ,  key = lambda  t :  t [ 0 ] . lower ( ) ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  TagState :  
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  raw :  str ,  name :  str ,  arguments :  str ,  closing :  bool )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . raw  =  raw 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . name  =  name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . arguments  =  arguments 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . closing  =  closing 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  TypeName :  
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  type_name :  str ,  enum :  Optional [ str ]  =  None ,  is_bitfield :  bool  =  False )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . type_name  =  type_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . enum  =  enum 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . is_bitfield  =  is_bitfield 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  to_rst ( self ,  state :  State )  - >  str : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  self . enum  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  make_enum ( self . enum ,  self . is_bitfield ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        elif  self . type_name  ==  " void " : 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  " |void| " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  make_type ( self . type_name ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    @classmethod 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  from_element ( cls ,  element :  ET . Element )  - >  " TypeName " : 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  cls ( element . attrib [ " type " ] ,  element . get ( " enum " ) ,  element . get ( " is_bitfield " )  ==  " true " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  DefinitionBase :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  __init__ ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        definition_name :  str , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name :  str , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  - >  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . definition_name  =  definition_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . name  =  name 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . deprecated :  Optional [ str ]  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . experimental :  Optional [ str ]  =  None 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class  PropertyDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name :  str , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        type_name :  TypeName , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        setter :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        getter :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        text :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        default_value :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        overrides :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " property " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . type_name  =  type_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . setter  =  setter 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . getter  =  getter 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . text  =  text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . default_value  =  default_value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . overrides  =  overrides 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  ParameterDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  name :  str ,  type_name :  TypeName ,  default_value :  Optional [ str ] )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " parameter " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . type_name  =  type_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . default_value  =  default_value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  SignalDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  name :  str ,  parameters :  List [ ParameterDef ] ,  description :  Optional [ str ] )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " signal " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . parameters  =  parameters 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . description  =  description 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  AnnotationDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-08-04 15:42:20 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name :  str , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        parameters :  List [ ParameterDef ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        description :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        qualifiers :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " annotation " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-04 15:42:20 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . parameters  =  parameters 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . description  =  description 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . qualifiers  =  qualifiers 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  MethodDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name :  str , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return_type :  TypeName , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        parameters :  List [ ParameterDef ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        description :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        qualifiers :  Optional [ str ] , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " method " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . return_type  =  return_type 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . parameters  =  parameters 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . description  =  description 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . qualifiers  =  qualifiers 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  ConstantDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  name :  str ,  value :  str ,  text :  Optional [ str ] ,  bitfield :  bool )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " constant " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . value  =  value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . text  =  text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . is_bitfield  =  bitfield 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  EnumDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  name :  str ,  type_name :  TypeName ,  bitfield :  bool )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " enum " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . type_name  =  type_name 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . values :  OrderedDict [ str ,  ConstantDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . is_bitfield  =  bitfield 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  ThemeItemDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self ,  name :  str ,  type_name :  TypeName ,  data_name :  str ,  text :  Optional [ str ] ,  default_value :  Optional [ str ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " theme property " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . type_name  =  type_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . data_name  =  data_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . text  =  text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . default_value  =  default_value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class  ClassDef ( DefinitionBase ) :  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  __init__ ( self ,  name :  str )  - >  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super ( ) . __init__ ( " class " ,  name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . class_group  =  " variant " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . editor_class  =  self . _is_editor_class ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . constants :  OrderedDict [ str ,  ConstantDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . enums :  OrderedDict [ str ,  EnumDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . properties :  OrderedDict [ str ,  PropertyDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . constructors :  OrderedDict [ str ,  List [ MethodDef ] ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . methods :  OrderedDict [ str ,  List [ MethodDef ] ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . operators :  OrderedDict [ str ,  List [ MethodDef ] ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . signals :  OrderedDict [ str ,  SignalDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-04 15:42:20 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . annotations :  OrderedDict [ str ,  List [ AnnotationDef ] ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . theme_items :  OrderedDict [ str ,  ThemeItemDef ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . inherits :  Optional [ str ]  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . brief_description :  Optional [ str ]  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . description :  Optional [ str ]  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . tutorials :  List [ Tuple [ str ,  str ] ]  =  [ ] 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-03 18:18:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        self . keywords :  Optional [ str ]  =  None 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Used to match the class with XML source for output filtering purposes. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . filepath :  str  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  _is_editor_class ( self )  - >  bool : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  self . name . startswith ( " Editor " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  self . name  in  EDITOR_CLASSES : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  update_class_group ( self ,  state :  State )  - >  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        group_name  =  " variant " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  self . name . startswith ( " @ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            group_name  =  " global " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        elif  self . inherits : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            inherits  =  self . inherits . strip ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            while  inherits  in  state . classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  inherits  ==  " Node " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    group_name  =  " node " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  inherits  ==  " Resource " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    group_name  =  " resource " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  inherits  ==  " Object " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    group_name  =  " object " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                inode  =  state . classes [ inherits ] . inherits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  inode : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    inherits  =  inode . strip ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . class_group  =  group_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Checks if code samples have both GDScript and C# variations.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# For simplicity we assume that a GDScript example is always present, and ignore contexts  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# which don't necessarily need C# examples.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class  ScriptLanguageParityCheck :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  __init__ ( self )  - >  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . hit_map :  OrderedDict [ str ,  List [ Tuple [ DefinitionBase ,  str ] ] ]  =  OrderedDict ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . hit_count  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  add_hit ( self ,  class_name :  str ,  context :  DefinitionBase ,  error :  str ,  state :  State )  - >  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_name  in  [ " @GDScript " ,  " @GlobalScope " ] : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return   # We don't expect these contexts to have parity. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        class_def  =  state . classes [ class_name ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_def . class_group  ==  " variant "  and  class_def . name  !=  " Object " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return   # Variant types are replaced with native types in C#, we don't expect parity. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . hit_count  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_name  not  in  self . hit_map : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            self . hit_map [ class_name ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self . hit_map [ class_name ] . append ( ( context ,  error ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Entry point for the RST generator.  
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  main ( )  - >  None :  
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser  =  argparse . ArgumentParser ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    parser . add_argument ( " path " ,  nargs = " + " ,  help = " A path to an XML file or a directory containing XML files to parse. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-02-14 03:10:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( " --filter " ,  default = " " ,  help = " The filepath pattern for XML files to filter. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( " --lang " ,  " -l " ,  default = " en " ,  help = " Language to use for section headings. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-06-11 00:16:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " --color " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        action = " store_true " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        help = " If passed, force colored output even if stdout is not a TTY (useful for continuous integration). " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    group  =  parser . add_mutually_exclusive_group ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    group . add_argument ( " --output " ,  " -o " ,  default = " . " ,  help = " The directory to save output .rst files in. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    group . add_argument ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " --dry-run " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        action = " store_true " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        help = " If passed, no output will be generated and XML files are only checked for errors. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    parser . add_argument ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " --verbose " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        action = " store_true " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        help = " If passed, enables verbose printing. " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    args  =  parser . parse_args ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-07 15:55:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  args . color : 
							 
						 
					
						
							
								
									
										
										
										
											2025-03-25 12:20:00 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        force_stdout_color ( True ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        force_stderr_color ( True ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-06-11 00:16:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Retrieve heading translations for the given language. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  not  args . dry_run  and  args . lang  !=  " en " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        lang_file  =  os . path . join ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            os . path . dirname ( os . path . realpath ( __file__ ) ) ,  " .. " ,  " translations " ,  " {} .po " . format ( args . lang ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  os . path . exists ( lang_file ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            try : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-23 22:21:46 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                import  polib   # type: ignore 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            except  ImportError : 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                print ( " Base template strings localization requires `polib`. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                exit ( 1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            pofile  =  polib . pofile ( lang_file ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  entry  in  pofile . translated_entries ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  entry . msgid  in  BASE_STRINGS : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    strings_l10n [ entry . msgid ]  =  entry . msgstr 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            print ( f ' No PO file at  " { lang_file } "  for language  " { args . lang } " . ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 10:53:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-05-27 22:24:15 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print ( " Checking for errors in the XML class reference... " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    file_list :  List [ str ]  =  [ ] 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  path  in  args . path : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Cut off trailing slashes so os.path.basename doesn't choke. 
							 
						 
					
						
							
								
									
										
										
										
											2022-01-24 10:30:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  path . endswith ( " / " )  or  path . endswith ( " \\ " ) : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            path  =  path [ : - 1 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-04-19 12:23:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  os . path . basename ( path )  in  [ " modules " ,  " platform " ] : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  subdir ,  dirs ,  _  in  os . walk ( path ) : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  " doc_classes "  in  dirs : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    doc_dir  =  os . path . join ( subdir ,  " doc_classes " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    class_file_names  =  ( f  for  f  in  os . listdir ( doc_dir )  if  f . endswith ( " .xml " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    file_list  + =  ( os . path . join ( doc_dir ,  f )  for  f  in  class_file_names ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        elif  os . path . isdir ( path ) : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            file_list  + =  ( os . path . join ( path ,  f )  for  f  in  os . listdir ( path )  if  f . endswith ( " .xml " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        elif  os . path . isfile ( path ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  not  path . endswith ( " .xml " ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                print ( f ' Got non-.xml file  " { path } "  in input, skipping. ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                continue 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            file_list . append ( path ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    classes :  Dict [ str ,  Tuple [ ET . Element ,  str ] ]  =  { } 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    state  =  State ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 19:05:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  cur_file  in  file_list : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        try : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            tree  =  ET . parse ( cur_file ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        except  ET . ParseError  as  e : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            print_error ( f " { cur_file } : Parse error while reading the file:  { e } " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            continue 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        doc  =  tree . getroot ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        name  =  doc . attrib [ " name " ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  name  in  classes : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            print_error ( f ' { cur_file } : Duplicate class  " { name } " . ' ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            continue 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-14 03:10:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        classes [ name ]  =  ( doc ,  cur_file ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 19:05:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  name ,  data  in  classes . items ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        try : 
							 
						 
					
						
							
								
									
										
										
										
											2021-02-14 03:10:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            state . parse_class ( data [ 0 ] ,  data [ 1 ] ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        except  Exception  as  e : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            print_error ( f " { name } .xml: Exception while parsing class:  { e } " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    state . sort_classes ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-14 03:10:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pattern  =  re . compile ( args . filter ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-07-08 21:54:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Create the output folder recursively if it doesn't already exist. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    os . makedirs ( args . output ,  exist_ok = True ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print ( " Generating the RST class reference... " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    grouped_classes :  Dict [ str ,  List [ str ] ]  =  { } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  class_name ,  class_def  in  state . classes . items ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2021-02-14 03:10:39 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  args . filter  and  not  pattern . search ( class_def . filepath ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            continue 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        state . current_class  =  class_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        class_def . update_class_group ( state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        make_rst_class ( class_def ,  state ,  args . dry_run ,  args . output ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  class_def . class_group  not  in  grouped_classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            grouped_classes [ class_def . class_group ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        grouped_classes [ class_def . class_group ] . append ( class_name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  class_def . editor_class : 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-24 21:06:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  " editor "  not  in  grouped_classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                grouped_classes [ " editor " ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            grouped_classes [ " editor " ] . append ( class_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print ( " " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    print ( " Generating the index file... " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    make_rst_index ( grouped_classes ,  args . dry_run ,  args . output ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print ( " " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Print out checks. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  state . script_language_parity_check . hit_count  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  not  args . verbose : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            print ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f " { Ansi . YELLOW } { state . script_language_parity_check . hit_count }  code samples failed parity check. Use --verbose to get more information. { Ansi . RESET } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            print ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f " { Ansi . YELLOW } { state . script_language_parity_check . hit_count }  code samples failed parity check: { Ansi . RESET } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  class_name  in  state . script_language_parity_check . hit_map . keys ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                class_hits  =  state . script_language_parity_check . hit_map [ class_name ] 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                print ( f ' { Ansi . YELLOW } -  { len ( class_hits ) }  hits in class  " { class_name } " { Ansi . RESET } ' ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  context ,  error  in  class_hits : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    print ( f "   -  { error }  in  { format_context_name ( context ) } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        print ( " " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Print out warnings and errors, or lack thereof, and exit with an appropriate code. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  state . num_warnings  > =  2 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        print ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f " { Ansi . YELLOW } { state . num_warnings }  warnings were found in the class reference XML. Please check the messages above. { Ansi . RESET } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  state . num_warnings  ==  1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        print ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f " { Ansi . YELLOW } 1 warning was found in the class reference XML. Please check the messages above. { Ansi . RESET } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  state . num_errors  > =  2 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        print ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f " { Ansi . RED } { state . num_errors }  errors were found in the class reference XML. Please check the messages above. { Ansi . RESET } " 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  state . num_errors  ==  1 : 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        print ( f " { Ansi . RED } 1 error was found in the class reference XML. Please check the messages above. { Ansi . RESET } " ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  state . num_warnings  ==  0  and  state . num_errors  ==  0 : 
							 
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        print ( f " { Ansi . GREEN } No warnings or errors found in the class reference XML. { Ansi . RESET } " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-08 21:54:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  not  args . dry_run : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            print ( f " Wrote reStructuredText files for each class to:  { args . output } " ) 
							 
						 
					
						
							
								
									
										
										
										
											2020-05-27 22:24:15 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        exit ( 1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Common helpers.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  print_error ( error :  str ,  state :  State )  - >  None :  
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print ( f " { Ansi . RED } { Ansi . BOLD } ERROR: { Ansi . REGULAR }   { error } { Ansi . RESET } " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    state . num_errors  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  print_warning ( warning :  str ,  state :  State )  - >  None :  
						 
					
						
							
								
									
										
										
										
											2024-06-22 09:42:30 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print ( f " { Ansi . YELLOW } { Ansi . BOLD } WARNING: { Ansi . REGULAR }   { warning } { Ansi . RESET } " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    state . num_warnings  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  translate ( string :  str )  - >  str :  
						 
					
						
							
								
									
										
										
										
											2021-12-22 16:35:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    """ Translate a string based on translations sourced from `doc/translations/*.po` 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  a  language  if  defined  via  the  - - lang  command  line  argument . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Returns  the  original  string  if  no  translation  exists . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """ 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  strings_l10n . get ( string ,  string ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  get_git_branch ( )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  hasattr ( version ,  " docs " )  and  version . docs  !=  " latest " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  version . docs 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  " master " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Generator methods.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_rst_class ( class_def :  ClassDef ,  state :  State ,  dry_run :  bool ,  output_dir :  str )  - >  None :  
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    class_name  =  class_def . name 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    with  open ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        os . devnull  if  dry_run  else  os . path . join ( output_dir ,  f " class_ { sanitize_class_name ( class_name ,  True ) } .rst " ) , 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        " w " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        encoding = " utf-8 " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        newline = " \n " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  as  f : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Remove the "Edit on Github" button from the online docs page. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( " :github_url: hide \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Add keywords metadata. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_def . keywords  is  not  None  and  class_def . keywords  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( f " .. meta:: \n \t :keywords:  { class_def . keywords } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Warn contributors not to edit this file directly. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Also provide links to the source files for reference. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        git_branch  =  get_git_branch ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        source_xml_path  =  os . path . relpath ( class_def . filepath ,  root_directory ) . replace ( " \\ " ,  " / " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        source_github_url  =  f " https://github.com/godotengine/godot/tree/ { git_branch } / { source_xml_path } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        generator_github_url  =  f " https://github.com/godotengine/godot/tree/ { git_branch } /doc/tools/make_rst.py " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( " .. DO NOT EDIT THIS FILE!!! \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( " .. Generated automatically from Godot engine sources. \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( f " .. Generator:  { generator_github_url } . \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( f " .. XML source:  { source_github_url } . \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Document reference id and header. 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f . write ( f " .. _class_ { sanitize_class_name ( class_name ) } : \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f . write ( make_heading ( class_name ,  " = " ,  False ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( make_deprecated_experimental ( class_def ,  state ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        ### INHERITANCE TREE ### 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Ascendants 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_def . inherits : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            inherits  =  class_def . inherits . strip ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-03 09:55:09 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f . write ( f " ** { translate ( ' Inherits: ' ) } **  " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            first  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2024-09-22 20:56:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            while  inherits  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  not  first : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( "  **<**  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    first  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( make_type ( inherits ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-09-22 20:56:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  inherits  not  in  state . classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    break   # Parent unknown. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                inode  =  state . classes [ inherits ] . inherits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  inode : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    inherits  =  inode . strip ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Descendants 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        inherited :  List [ str ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  c  in  state . classes . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  c . inherits  and  c . inherits . strip ( )  ==  class_name : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                inherited . append ( c . name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( inherited ) : 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-03 09:55:09 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f . write ( f " ** { translate ( ' Inherited By: ' ) } **  " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  i ,  child  in  enumerate ( inherited ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  i  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( " ,  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( make_type ( child ,  state ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ### INTRODUCTION ### 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        has_description  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Brief description 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_def . brief_description  is  not  None  and  class_def . brief_description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            has_description  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f . write ( f " { format_text_block ( class_def . brief_description . strip ( ) ,  class_def ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Class description 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  class_def . description  is  not  None  and  class_def . description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            has_description  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-introduction-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Description " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f . write ( f " { format_text_block ( class_def . description . strip ( ) ,  class_def ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  not  has_description : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    " There is currently no description for this class. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  class_def . name  in  CLASSES_WITH_CSHARP_DIFFERENCES : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. note:: \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    " There are notable differences when using this API with C#. See :ref:`doc_c_sharp_differences` for more information. " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Online tutorials 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . tutorials )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-introduction-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Tutorials " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  url ,  title  in  class_def . tutorials : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( f " -  { make_link ( url ,  title ) } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ### REFERENCE TABLES ### 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Reused container for reference tables. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        ml :  List [ Tuple [ Optional [ str ] ,  . . . ] ]  =  [ ] 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Properties reference table 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . properties )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-reftable-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Properties " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ml  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  property_def  in  class_def . properties . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                type_rst  =  property_def . type_name . to_rst ( state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                default  =  property_def . default_value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  default  is  not  None  and  property_def . overrides : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ref  =  f " :ref:` { property_def . overrides } <class_ { sanitize_class_name ( property_def . overrides ) } _property_ { property_def . name } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Not using translate() for now as it breaks table formatting. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ml . append ( ( type_rst ,  property_def . name ,  f " { default }  (overrides  { ref } ) " ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ref  =  f " :ref:` { property_def . name } <class_ { sanitize_class_name ( class_name ) } _property_ { property_def . name } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ml . append ( ( type_rst ,  ref ,  default ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            format_table ( f ,  ml ,  True ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Constructors, Methods, Operators reference tables 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . constructors )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-reftable-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Constructors " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ml  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  method_list  in  class_def . constructors . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  m  in  method_list : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ml . append ( make_method_signature ( class_def ,  m ,  " constructor " ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            format_table ( f ,  ml ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  len ( class_def . methods )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-reftable-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Methods " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ml  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  method_list  in  class_def . methods . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  m  in  method_list : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ml . append ( make_method_signature ( class_def ,  m ,  " method " ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            format_table ( f ,  ml ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  len ( class_def . operators )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-reftable-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Operators " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ml  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  method_list  in  class_def . operators . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  m  in  method_list : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ml . append ( make_method_signature ( class_def ,  m ,  " operator " ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            format_table ( f ,  ml ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Theme properties reference table 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . theme_items )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-reftable-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Theme Properties " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            ml  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  theme_item_def  in  class_def . theme_items . values ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                ref  =  f " :ref:` { theme_item_def . name } <class_ { sanitize_class_name ( class_name ) } _theme_ { theme_item_def . data_name } _ { theme_item_def . name } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                ml . append ( ( theme_item_def . type_name . to_rst ( state ) ,  ref ,  theme_item_def . default_value ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            format_table ( f ,  ml ,  True ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ### DETAILED DESCRIPTIONS ### 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Signal descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . signals )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Signals " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  signal  in  class_def . signals . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-06-24 11:16:37 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Create signal signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                signal_anchor  =  f " class_ { sanitize_class_name ( class_name ) } _signal_ { signal . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " .. _ { signal_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                self_link  =  f " :ref:`🔗< { signal_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " .. rst-class:: classref-signal \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                _ ,  signature  =  make_method_signature ( class_def ,  signal ,  " " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " { signature }   { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Add signal description, or a call to action if it's missing. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( make_deprecated_experimental ( signal ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  signal . description  is  not  None  and  signal . description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( f " { format_text_block ( signal . description . strip ( ) ,  signal ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                elif  signal . deprecated  is  None  and  signal . experimental  is  None : 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-16 18:19:41 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        translate ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            " There is currently no description for this signal. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-16 18:19:41 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                index  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Enumeration descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . enums )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Enumerations " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  e  in  class_def . enums . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Create enumeration signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                enum_anchor  =  f " enum_ { sanitize_class_name ( class_name ) } _ { e . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " .. _ { enum_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                self_link  =  f " :ref:`🔗< { enum_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " .. rst-class:: classref-enumeration \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  e . is_bitfield : 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " flags ** { e . name } **:  { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " enum ** { e . name } **:  { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                for  value  in  e . values . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    # Also create signature and anchor point for each enum constant. 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " .. _class_ { sanitize_class_name ( class_name ) } _constant_ { value . name } : \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. rst-class:: classref-enumeration-constant \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " { e . type_name . to_rst ( state ) }  ** { value . name } ** = `` { value . value } `` \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Add enum constant description. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( make_deprecated_experimental ( value ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  value . text  is  not  None  and  value . text . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( f " { format_text_block ( value . text . strip ( ) ,  value ,  state ) } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  value . deprecated  is  None  and  value . experimental  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                " There is currently no description for this enum. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                index  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Constant descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . constants )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Constants " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  constant  in  class_def . constants . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # Create constant signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                constant_anchor  =  f " class_ { sanitize_class_name ( class_name ) } _constant_ { constant . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " .. _ { constant_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                self_link  =  f " :ref:`🔗< { constant_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " .. rst-class:: classref-constant \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " ** { constant . name } ** = `` { constant . value } ``  { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # Add constant description. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( make_deprecated_experimental ( constant ,  state ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  constant . text  is  not  None  and  constant . text . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( f " { format_text_block ( constant . text . strip ( ) ,  constant ,  state ) } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                elif  constant . deprecated  is  None  and  constant . experimental  is  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        translate ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            " There is currently no description for this constant. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-04 18:56:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Annotation descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . annotations )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Annotations " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  method_list  in  class_def . annotations . values ( ) :   # type: ignore 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  i ,  m  in  enumerate ( method_list ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-09-03 13:42:34 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Create annotation signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    self_link  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  i  ==  0 : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        annotation_anchor  =  f " class_ { sanitize_class_name ( class_name ) } _annotation_ { m . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        f . write ( f " .. _ { annotation_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        self_link  =  f "  :ref:`🔗< { annotation_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. rst-class:: classref-annotation \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    _ ,  signature  =  make_method_signature ( class_def ,  m ,  " " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " { signature } { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Add annotation description, or a call to action if it's missing. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  m . description  is  not  None  and  m . description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( f " { format_text_block ( m . description . strip ( ) ,  m ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                " There is currently no description for this annotation. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    index  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Property descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  any ( not  p . overrides  for  p  in  class_def . properties . values ( ) )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Property Descriptions " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  property_def  in  class_def . properties . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  property_def . overrides : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Create property signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                property_anchor  =  f " class_ { sanitize_class_name ( class_name ) } _property_ { property_def . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " .. _ { property_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                self_link  =  f " :ref:`🔗< { property_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " .. rst-class:: classref-property \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                property_default  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  property_def . default_value  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    property_default  =  f "  =  { property_def . default_value } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f " { property_def . type_name . to_rst ( state ) }  ** { property_def . name } ** { property_default }   { self_link } \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Create property setter and getter records. 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                property_setget  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  property_def . setter  is  not  None  and  not  property_def . setter . startswith ( " _ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    property_setter  =  make_setter_signature ( class_def ,  property_def ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    property_setget  + =  f " -  { property_setter } \n " 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  property_def . getter  is  not  None  and  not  property_def . getter . startswith ( " _ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    property_getter  =  make_getter_signature ( class_def ,  property_def ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    property_setget  + =  f " -  { property_getter } \n " 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  property_setget  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( " .. rst-class:: classref-property-setget \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( property_setget ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Add property description, or a call to action if it's missing. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( make_deprecated_experimental ( property_def ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  property_def . text  is  not  None  and  property_def . text . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( f " { format_text_block ( property_def . text . strip ( ) ,  property_def ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                elif  property_def . deprecated  is  None  and  property_def . experimental  is  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        translate ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            " There is currently no description for this property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-09-04 10:54:50 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Add copy note to built-in properties returning `Packed*Array`. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  property_def . type_name . type_name  in  PACKED_ARRAY_TYPES : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    copy_note  =  f " [b]Note:[/b] The returned array is [i]copied[/i] and any changes to it will not update the original property value. See [ { property_def . type_name . type_name } ] for more details. " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( f " { format_text_block ( copy_note ,  property_def ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                index  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Constructor, Method, Operator descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . constructors )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Constructor Descriptions " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  method_list  in  class_def . constructors . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  i ,  m  in  enumerate ( method_list ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Create constructor signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    self_link  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  i  ==  0 : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        constructor_anchor  =  f " class_ { sanitize_class_name ( class_name ) } _constructor_ { m . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        f . write ( f " .. _ { constructor_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        self_link  =  f "  :ref:`🔗< { constructor_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2023-11-08 15:16:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. rst-class:: classref-constructor \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ret_type ,  signature  =  make_method_signature ( class_def ,  m ,  " " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " { ret_type }   { signature } { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Add constructor description, or a call to action if it's missing. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( make_deprecated_experimental ( m ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  m . description  is  not  None  and  m . description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( f " { format_text_block ( m . description . strip ( ) ,  m ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  m . deprecated  is  None  and  m . experimental  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                " There is currently no description for this constructor. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            +  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    index  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . methods )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Method Descriptions " ,  " - " ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  method_list  in  class_def . methods . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  i ,  m  in  enumerate ( method_list ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    # Create method signature and anchor point. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    self_link  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  i  ==  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        method_qualifier  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        if  m . name . startswith ( " _ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            method_qualifier  =  " private_ " 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        method_anchor  =  f " class_ { sanitize_class_name ( class_name ) } _ { method_qualifier } method_ { m . name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        f . write ( f " .. _ { method_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        self_link  =  f "  :ref:`🔗< { method_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( " .. rst-class:: classref-method \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ret_type ,  signature  =  make_method_signature ( class_def ,  m ,  " " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( f " { ret_type }   { signature } { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    # Add method description, or a call to action if it's missing. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( make_deprecated_experimental ( m ,  state ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  m . description  is  not  None  and  m . description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( f " { format_text_block ( m . description . strip ( ) ,  m ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  m . deprecated  is  None  and  m . experimental  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                " There is currently no description for this method. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            +  " \n \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    index  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  len ( class_def . operators )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Operator Descriptions " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  method_list  in  class_def . operators . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                for  i ,  m  in  enumerate ( method_list ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Create operator signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    operator_anchor  =  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f " class_ { sanitize_class_name ( class_name ) } _operator_ { sanitize_operator_name ( m . name ,  state ) } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    for  parameter  in  m . parameters : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        operator_anchor  + =  f " _ { parameter . type_name . type_name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " .. _ { operator_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    self_link  =  f " :ref:`🔗< { operator_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( " .. rst-class:: classref-operator \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ret_type ,  signature  =  make_method_signature ( class_def ,  m ,  " " ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f " { ret_type }   { signature }   { self_link } \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    # Add operator description, or a call to action if it's missing. 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( make_deprecated_experimental ( m ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  m . description  is  not  None  and  m . description . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( f " { format_text_block ( m . description . strip ( ) ,  m ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    elif  m . deprecated  is  None  and  m . experimental  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                " There is currently no description for this operator. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            +  " \n \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    index  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Theme property descriptions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( class_def . theme_items )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_separator ( True ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( " .. rst-class:: classref-descriptions-group \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            f . write ( make_heading ( " Theme Property Descriptions " ,  " - " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            index  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  theme_item_def  in  class_def . theme_items . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  index  !=  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( make_separator ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Create theme property signature and anchor point. 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                theme_item_anchor  =  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f " class_ { sanitize_class_name ( class_name ) } _theme_ { theme_item_def . data_name } _ { theme_item_def . name } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( f " .. _ { theme_item_anchor } : \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                self_link  =  f " :ref:`🔗< { theme_item_anchor } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " .. rst-class:: classref-themeproperty \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                theme_item_default  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  theme_item_def . default_value  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    theme_item_default  =  f "  =  { theme_item_def . default_value } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-03 22:29:01 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f " { theme_item_def . type_name . to_rst ( state ) }  ** { theme_item_def . name } ** { theme_item_default }   { self_link } \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Add theme property description, or a call to action if it's missing. 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( make_deprecated_experimental ( theme_item_def ,  state ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  theme_item_def . text  is  not  None  and  theme_item_def . text . strip ( )  !=  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( f " { format_text_block ( theme_item_def . text . strip ( ) ,  theme_item_def ,  state ) } \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                elif  theme_item_def . deprecated  is  None  and  theme_item_def . experimental  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( " .. container:: contribute \n \n \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    f . write ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            " There is currently no description for this theme property. Please help us by :ref:`contributing one <doc_updating_the_class_reference>`! " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        +  " \n \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-19 18:17:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                index  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-04 19:54:41 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f . write ( make_footer ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-30 11:41:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_type ( klass :  str ,  state :  State )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  klass . find ( " * " )  !=  - 1 :   # Pointer, ignore 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  f " `` { klass } `` " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-24 13:03:28 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  resolve_type ( link_type :  str )  - >  str : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  link_type  in  state . classes : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  f " :ref:` { link_type } <class_ { sanitize_class_name ( link_type ) } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-24 13:03:28 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            print_error ( f ' { state . current_class } .xml: Unresolved type  " { link_type } " . ' ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  f " `` { link_type } `` " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  klass . endswith ( " [] " ) :   # Typed array, strip [] to link to contained type. 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-03 09:55:09 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  f " :ref:`Array<class_Array>` \\ [ { resolve_type ( klass [ :  - len ( ' [] ' ) ] ) } \\ ] " 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-24 13:03:28 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  klass . startswith ( " Dictionary[ " ) :   # Typed dictionary, split elements to link contained types. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        parts  =  klass [ len ( " Dictionary[ " )  :  - len ( " ] " ) ] . partition ( " ,  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        key  =  parts [ 0 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        value  =  parts [ 2 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  f " :ref:`Dictionary<class_Dictionary>` \\ [ { resolve_type ( key ) } ,  { resolve_type ( value ) } \\ ] " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  resolve_type ( klass ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-11-29 14:21:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_enum ( t :  str ,  is_bitfield :  bool ,  state :  State )  - >  str :  
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    p  =  t . rfind ( " . " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  p  > =  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        c  =  t [ 0 : p ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        e  =  t [ p  +  1  : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Variant enums live in GlobalScope but still use periods. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  c  ==  " Variant " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            c  =  " @GlobalScope " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            e  =  " Variant. "  +  e 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        c  =  state . current_class 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        e  =  t 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  c  in  state . classes  and  e  not  in  state . classes [ c ] . enums : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            c  =  " @GlobalScope " 
							 
						 
					
						
							
								
									
										
										
										
											2019-11-29 14:21:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  c  in  state . classes  and  e  in  state . classes [ c ] . enums : 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  is_bitfield : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  not  state . classes [ c ] . enums [ e ] . is_bitfield : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                print_error ( f ' { state . current_class } .xml: Enum  " { t } "  is not bitfield. ' ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  f " |bitfield| \\ [:ref:` { e } <enum_ { sanitize_class_name ( c ) } _ { e } >` \\ ] " 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  f " :ref:` { e } <enum_ { sanitize_class_name ( c ) } _ { e } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2019-11-29 14:21:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-22 14:03:21 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    print_error ( f ' { state . current_class } .xml: Unresolved enum  " { t } " . ' ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-11-29 14:21:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  t 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_method_signature (  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    class_def :  ClassDef ,  definition :  Union [ AnnotationDef ,  MethodDef ,  SignalDef ] ,  ref_type :  str ,  state :  State 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								)  - >  Tuple [ str ,  str ] :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ret_type  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-23 22:21:46 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  isinstance ( definition ,  MethodDef ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ret_type  =  definition . return_type . to_rst ( state ) 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    qualifiers  =  None 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-23 22:21:46 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  isinstance ( definition ,  ( MethodDef ,  AnnotationDef ) ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        qualifiers  =  definition . qualifiers 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    out  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-23 22:21:46 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  isinstance ( definition ,  MethodDef )  and  ref_type  !=  " " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ref_type  ==  " operator " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            op_name  =  definition . name . replace ( " < " ,  " \\ < " )   # So operator "<" gets correctly displayed. 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  f " :ref:` { op_name } <class_ { sanitize_class_name ( class_def . name ) } _ { ref_type } _ { sanitize_operator_name ( definition . name ,  state ) } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:41:44 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            for  parameter  in  definition . parameters : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                out  + =  f " _ { parameter . type_name . type_name } " 
							 
						 
					
						
							
								
									
										
										
										
											2024-05-21 15:14:59 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  " >` " 
							 
						 
					
						
							
								
									
										
										
										
											2023-11-08 15:16:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        elif  ref_type  ==  " method " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ref_type_qualifier  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  definition . name . startswith ( " _ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ref_type_qualifier  =  " private_ " 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  f " :ref:` { definition . name } <class_ { sanitize_class_name ( class_def . name ) } _ { ref_type_qualifier } { ref_type } _ { definition . name } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  f " :ref:` { definition . name } <class_ { sanitize_class_name ( class_def . name ) } _ { ref_type } _ { definition . name } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        out  + =  f " ** { definition . name } ** " 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    out  + =  " \\  ( " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  i ,  arg  in  enumerate ( definition . parameters ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  i  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            out  + =  " ,  " 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  " \\   " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        out  + =  f " { arg . name } \\ :  { arg . type_name . to_rst ( state ) } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  arg . default_value  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  f "  =  { arg . default_value } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  qualifiers  is  not  None  and  " vararg "  in  qualifiers : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  len ( definition . parameters )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            out  + =  " , ... " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  " \\  ... " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    out  + =  " \\  ) " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  qualifiers  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Use substitutions for abbreviations. This is used to display tooltips on hover. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # See `make_footer()` for descriptions. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  qualifier  in  qualifiers . split ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            out  + =  f "  | { qualifier } | " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  ret_type ,  out 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_setter_signature ( class_def :  ClassDef ,  property_def :  PropertyDef ,  state :  State )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  property_def . setter  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If setter is a method available as a method definition, we use that. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  property_def . setter  in  class_def . methods : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        setter  =  class_def . methods [ property_def . setter ] [ 0 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Otherwise we fake it with the information we have available. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        setter_params :  List [ ParameterDef ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        setter_params . append ( ParameterDef ( " value " ,  property_def . type_name ,  None ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        setter  =  MethodDef ( property_def . setter ,  TypeName ( " void " ) ,  setter_params ,  None ,  None ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ret_type ,  signature  =  make_method_signature ( class_def ,  setter ,  " " ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  f " { ret_type }   { signature } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  make_getter_signature ( class_def :  ClassDef ,  property_def :  PropertyDef ,  state :  State )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  property_def . getter  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If getter is a method available as a method definition, we use that. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  property_def . getter  in  class_def . methods : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        getter  =  class_def . methods [ property_def . getter ] [ 0 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Otherwise we fake it with the information we have available. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        getter_params :  List [ ParameterDef ]  =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        getter  =  MethodDef ( property_def . getter ,  property_def . type_name ,  getter_params ,  None ,  None ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ret_type ,  signature  =  make_method_signature ( class_def ,  getter ,  " " ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  f " { ret_type }   { signature } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_deprecated_experimental ( item :  DefinitionBase ,  state :  State )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    result  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  item . deprecated  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        deprecated_prefix  =  translate ( " Deprecated: " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  item . deprecated . strip ( )  ==  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            default_message  =  translate ( f " This  { item . definition_name }  may be changed or removed in future versions. " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            result  + =  f " ** { deprecated_prefix } **  { default_message } \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            result  + =  f " ** { deprecated_prefix } **  { format_text_block ( item . deprecated . strip ( ) ,  item ,  state ) } \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  item . experimental  is  not  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        experimental_prefix  =  translate ( " Experimental: " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  item . experimental . strip ( )  ==  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            default_message  =  translate ( f " This  { item . definition_name }  may be changed or removed in future versions. " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            result  + =  f " ** { experimental_prefix } **  { default_message } \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            result  + =  f " ** { experimental_prefix } **  { format_text_block ( item . experimental . strip ( ) ,  item ,  state ) } \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  result 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_heading ( title :  str ,  underline :  str ,  l10n :  bool  =  True )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  l10n : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        new_title  =  translate ( title ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  new_title  !=  title : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            title  =  new_title 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            underline  * =  2   # Double length to handle wide chars. 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  f " { title } \n { ( underline  *  len ( title ) ) } \n \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  make_footer ( )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Generate reusable abbreviation substitutions. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # This way, we avoid bloating the generated rST with duplicate abbreviations. 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    virtual_msg  =  translate ( " This method should typically be overridden by the user to have any effect. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2025-06-05 11:11:08 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    required_msg  =  translate ( " This method is required to be overridden when extending its base class. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    const_msg  =  translate ( " This method has no side effects. It doesn ' t modify any of the instance ' s member variables. " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    vararg_msg  =  translate ( " This method accepts any number of arguments after the ones described here. " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    constructor_msg  =  translate ( " This method is used to construct a type. " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    static_msg  =  translate ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " This method doesn ' t need an instance to be called, so it can be called directly using the class name. " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    operator_msg  =  translate ( " This method describes a valid operator to use with this type as left-hand operand. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    bitfield_msg  =  translate ( " This value is an integer composed as a bitmask of the following flags. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    void_msg  =  translate ( " No return value. " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f " .. |virtual| replace:: :abbr:`virtual ( { virtual_msg } )` \n " 
							 
						 
					
						
							
								
									
										
										
										
											2025-06-05 11:11:08 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f " .. |required| replace:: :abbr:`required ( { required_msg } )` \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f " .. |const| replace:: :abbr:`const ( { const_msg } )` \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f " .. |vararg| replace:: :abbr:`vararg ( { vararg_msg } )` \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f " .. |constructor| replace:: :abbr:`constructor ( { constructor_msg } )` \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f " .. |static| replace:: :abbr:`static ( { static_msg } )` \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f " .. |operator| replace:: :abbr:`operator ( { operator_msg } )` \n " 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f " .. |bitfield| replace:: :abbr:`BitField ( { bitfield_msg } )` \n " 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-19 20:02:17 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f " .. |void| replace:: :abbr:`void ( { void_msg } )` \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_separator ( section_level :  bool  =  False )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    separator_class  =  " item " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  section_level : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        separator_class  =  " section " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  f " .. rst-class:: classref- { separator_class } -separator \n \n ---- \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_link ( url :  str ,  title :  str )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    match  =  GODOT_DOCS_PATTERN . search ( url ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  match : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        groups  =  match . groups ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  match . lastindex  ==  2 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # Doc reference with fragment identifier: emit direct link to section with reference to page, for example: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # `#calling-javascript-from-script in Exporting For Web` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # Or use the title if provided. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  title  !=  " " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                return  f " ` { title }  <../ { groups [ 0 ] } .html { groups [ 1 ] } >`__ " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  f " ` { groups [ 1 ] }  <../ { groups [ 0 ] } .html { groups [ 1 ] } >`__ in :doc:`../ { groups [ 0 ] } ` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        elif  match . lastindex  ==  1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # Doc reference, for example: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # `Math` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  title  !=  " " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                return  f " :doc:` { title }  <../ { groups [ 0 ] } >` " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  f " :doc:`../ { groups [ 0 ] } ` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # External link, for example: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # `http://enet.bespin.org/usergroup0.html` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  title  !=  " " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  f " ` { title }  < { url } >`__ " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  f " ` { url }  < { url } >`__ " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  make_rst_index ( grouped_classes :  Dict [ str ,  List [ str ] ] ,  dry_run :  bool ,  output_dir :  str )  - >  None :  
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    with  open ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        os . devnull  if  dry_run  else  os . path . join ( output_dir ,  " index.rst " ) ,  " w " ,  encoding = " utf-8 " ,  newline = " \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    )  as  f : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Remove the "Edit on Github" button from the online docs page, and disallow user-contributed notes 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # on the index page. User-contributed notes are allowed on individual class pages. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( " :github_url: hide \n :allow_comments: False \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Warn contributors not to edit this file directly. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Also provide links to the source files for reference. 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        git_branch  =  get_git_branch ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        generator_github_url  =  f " https://github.com/godotengine/godot/tree/ { git_branch } /doc/tools/make_rst.py " 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f . write ( " .. DO NOT EDIT THIS FILE!!! \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( " .. Generated automatically from Godot engine sources. \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( f " .. Generator:  { generator_github_url } . \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f . write ( " .. _doc_class_reference: \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        f . write ( make_heading ( " All classes " ,  " = " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:47:53 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        for  group_name  in  CLASS_GROUPS : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  group_name  in  grouped_classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( make_heading ( CLASS_GROUPS [ group_name ] ,  " = " ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " .. toctree:: \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( "     :maxdepth: 1 \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( f "     :name: toc-class-ref- { group_name } s \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                f . write ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  group_name  in  CLASS_GROUPS_BASE : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f "     class_ { sanitize_class_name ( CLASS_GROUPS_BASE [ group_name ] ,  True ) } \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-18 15:47:53 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                for  class_name  in  grouped_classes [ group_name ] : 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  group_name  in  CLASS_GROUPS_BASE  and  sanitize_class_name ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        CLASS_GROUPS_BASE [ group_name ] ,  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    )  ==  sanitize_class_name ( class_name ,  True ) : 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        continue 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-24 21:06:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    f . write ( f "     class_ { sanitize_class_name ( class_name ,  True ) } \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-10 12:09:48 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                f . write ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-26 19:02:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Formatting helpers.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-07 19:32:08 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								RESERVED_FORMATTING_TAGS  =  [ " i " ,  " b " ,  " u " ,  " lb " ,  " rb " ,  " code " ,  " kbd " ,  " center " ,  " url " ,  " br " ]  
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								RESERVED_LAYOUT_TAGS  =  [ " codeblocks " ]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								RESERVED_CODEBLOCK_TAGS  =  [ " codeblock " ,  " gdscript " ,  " csharp " ]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								RESERVED_CROSSLINK_TAGS  =  [  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " method " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " constructor " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " operator " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " member " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " signal " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " constant " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " enum " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " annotation " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " theme_item " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    " param " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								]  
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  is_in_tagset ( tag_text :  str ,  tagset :  List [ str ] )  - >  bool :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  tag  in  tagset : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Complete match. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  tag_text  ==  tag : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Tag with arguments. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  tag_text . startswith ( tag  +  "   " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  True 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Tag with arguments, special case for [url], [color], and [font]. 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  tag_text . startswith ( tag  +  " = " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  True 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  False 
							 
						 
					
						
							
								
									
										
										
										
											2020-07-22 22:41:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  get_tag_and_args ( tag_text :  str )  - >  TagState :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    tag_name  =  tag_text 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    arguments :  str  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    delim_pos  =  - 1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    space_pos  =  tag_text . find ( "   " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  space_pos  > =  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        delim_pos  =  space_pos 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Special case for [url], [color], and [font]. 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    assign_pos  =  tag_text . find ( " = " ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  assign_pos  > =  0  and  ( delim_pos  <  0  or  assign_pos  <  delim_pos ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        delim_pos  =  assign_pos 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  delim_pos  > =  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        tag_name  =  tag_text [ : delim_pos ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        arguments  =  tag_text [ delim_pos  +  1  : ] . strip ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    closing  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  tag_name . startswith ( " / " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        tag_name  =  tag_name [ 1 : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        closing  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  TagState ( tag_text ,  tag_name ,  arguments ,  closing ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  parse_link_target ( link_target :  str ,  state :  State ,  context_name :  str )  - >  List [ str ] :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  link_target . find ( " . " )  !=  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  link_target . split ( " . " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  [ state . current_class ,  link_target ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  format_text_block (  
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    text :  str , 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    context :  DefinitionBase , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    state :  State , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								)  - >  str :  
						 
					
						
							
								
									
										
										
										
											2025-05-17 20:00:17 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    result  =  preformat_text_block ( text ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  result  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    text  =  result 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    next_brac_pos  =  text . find ( " [ " ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-11-29 14:21:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    text  =  escape_rst ( text ,  next_brac_pos ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    context_name  =  format_context_name ( context ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Handle [tags] 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-22 21:22:38 +07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    inside_code  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    inside_code_tag  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    inside_code_tabs  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ignore_code_warnings  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    code_warning_if_intended_string  =  " If this is intended, use [code skip-lint]...[/code]. " 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    has_codeblocks_gdscript  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    has_codeblocks_csharp  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pos  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    tag_depth  =  0 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    while  True : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        pos  =  text . find ( " [ " ,  pos ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        endq_pos  =  text . find ( " ] " ,  pos  +  1 ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  endq_pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pre_text  =  text [ : pos ] 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        post_text  =  text [ endq_pos  +  1  : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        tag_text  =  text [ pos  +  1  :  endq_pos ] 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        escape_pre  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2017-10-21 12:33:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        escape_post  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Tag is a reference to a class. 
							 
						 
					
						
							
								
									
										
										
										
											2022-12-05 22:58:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  tag_text  in  state . classes  and  not  inside_code : 
							 
						 
					
						
							
								
									
										
										
										
											2019-03-29 23:37:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  tag_text  ==  state . current_class : 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Don't create a link to the same class, format it as strong emphasis. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_text  =  f " ** { tag_text } ** " 
							 
						 
					
						
							
								
									
										
										
										
											2019-03-29 23:37:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_text  =  make_type ( tag_text ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            escape_pre  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2017-10-21 12:33:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Tag is a cross-reference or a formatting directive. 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            tag_state  =  get_tag_and_args ( tag_text ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            # Anything identified as a tag inside of a code block is valid, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # unless it's a matching closing tag. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  inside_code : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # Exiting codeblocks and inline code tags. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  tag_state . closing  and  tag_state . name  ==  inside_code_tag : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  is_in_tagset ( tag_state . name ,  RESERVED_CODEBLOCK_TAGS ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_text  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        tag_depth  - =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        inside_code  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ignore_code_warnings  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        # Strip newline if the tag was alone on one 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        if  pre_text [ - 1 ]  ==  " \n " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            pre_text  =  pre_text [ : - 1 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  is_in_tagset ( tag_state . name ,  [ " code " ] ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_text  =  " `` " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        tag_depth  - =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        inside_code  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ignore_code_warnings  =  False 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  not  ignore_code_warnings  and  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            f ' { state . current_class } .xml: Found a code string that looks like a closing tag  " [ { tag_state . raw } ] "  in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_text  =  f " [ { tag_text } ] " 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            # Entering codeblocks and inline code tags. 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " codeblocks " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  not  has_codeblocks_gdscript  or  not  has_codeblocks_csharp : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        state . script_language_parity_check . add_hit ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            state . current_class , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            context , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            " Only one script language sample found in [codeblocks] " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    has_codeblocks_gdscript  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    has_codeblocks_csharp  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_depth  - =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_text  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    inside_code_tabs  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_depth  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_text  =  " \n .. tabs:: " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    inside_code_tabs  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  is_in_tagset ( tag_state . name ,  RESERVED_CODEBLOCK_TAGS ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_depth  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  tag_state . name  ==  " gdscript " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  not  inside_code_tabs : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            f " { state . current_class } .xml: GDScript code block is used outside of [codeblocks] in  { context_name } . " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        has_codeblocks_gdscript  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_text  =  " \n  .. code-tab:: gdscript \n " 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                elif  tag_state . name  ==  " csharp " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  not  inside_code_tabs : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            f " { state . current_class } .xml: C# code block is used outside of [codeblocks] in  { context_name } . " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        has_codeblocks_csharp  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_text  =  " \n  .. code-tab:: csharp \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 14:08:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    state . script_language_parity_check . add_hit ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        state . current_class , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        context , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        " Code sample is formatted with [codeblock] where [codeblocks] should be used " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  " lang=text "  in  tag_state . arguments . split ( "   " ) : 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-11 10:24:09 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_text  =  " \n .. code:: text \n " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        tag_text  =  " \n :: \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                inside_code  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                inside_code_tag  =  tag_state . name 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                ignore_code_warnings  =  " skip-lint "  in  tag_state . arguments . split ( "   " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  is_in_tagset ( tag_state . name ,  [ " code " ] ) : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_text  =  " `` " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_depth  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                inside_code  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                inside_code_tag  =  " code " 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                ignore_code_warnings  =  " skip-lint "  in  tag_state . arguments . split ( "   " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                escape_pre  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  not  ignore_code_warnings : 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-26 21:36:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    endcode_pos  =  text . find ( " [/code] " ,  endq_pos  +  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  endcode_pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            f " { state . current_class } .xml: Tag depth mismatch for [code]: no closing [/code] in  { context_name } . " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    inside_code_text  =  text [ endq_pos  +  1  :  endcode_pos ] 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  inside_code_text . endswith ( " () " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        # It's formatted like a call for some reason, may still be a mistake. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        inside_code_text  =  inside_code_text [ : - 2 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  inside_code_text  in  state . classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches one of the known classes in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    target_class_name ,  target_name ,  * rest  =  parse_link_target ( inside_code_text ,  state ,  context_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  len ( rest )  ==  0  and  target_class_name  in  state . classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        class_def  =  state . classes [ target_class_name ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        if  target_name  in  class_def . methods : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  method in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . constructors : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  constructor in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . operators : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  operator in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . properties : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  member in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . signals : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  signal in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . annotations : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  annotation in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . theme_items : 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-26 21:36:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  theme property in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-26 21:36:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        elif  target_name  in  class_def . constants : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  constant in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            for  enum  in  class_def . enums . values ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  target_name  in  enum . values : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches the  { target_class_name } . { target_name }  enum value in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    valid_param_context  =  isinstance ( context ,  ( MethodDef ,  SignalDef ,  AnnotationDef ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  valid_param_context : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        context_params :  List [ ParameterDef ]  =  context . parameters   # type: ignore 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        for  param_def  in  context_params : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            if  param_def . name  ==  inside_code_text : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                print_warning ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-15 15:06:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    f ' { state . current_class } .xml: Found a code string  " { inside_code_text } "  that matches one of the parameters in  { context_name } .  { code_warning_if_intended_string } ' , 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                break 
							 
						 
					
						
							
								
									
										
										
										
											2023-04-26 21:36:04 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            # Cross-references to items in this or other class documentation pages. 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  is_in_tagset ( tag_state . name ,  RESERVED_CROSSLINK_TAGS ) : 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                link_target :  str  =  tag_state . arguments 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  link_target  ==  " " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        f ' { state . current_class } .xml: Empty cross-reference link  " [ { tag_state . raw } ] "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_text  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  ( 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_state . name  ==  " method " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " constructor " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " operator " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " member " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " signal " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " annotation " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " theme_item " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        or  tag_state . name  ==  " constant " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    ) : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        target_class_name ,  target_name ,  * rest  =  parse_link_target ( link_target ,  state ,  context_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        if  len ( rest )  >  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Bad reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        # Default to the tag command name. This works by default for most tags, 
							 
						 
					
						
							
								
									
										
										
										
											2023-11-08 15:16:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        # but method, member, and theme_item have special cases. 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        ref_type  =  " _ {} " . format ( tag_state . name ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        if  target_class_name  in  state . classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            class_def  =  state . classes [ target_class_name ] 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-08 15:16:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            if  tag_state . name  ==  " method " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  target_name . startswith ( " _ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    ref_type  =  " _private_method " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  target_name  not  in  class_def . methods : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                        f ' { state . current_class } .xml: Unresolved method reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " constructor "  and  target_name  not  in  class_def . constructors : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    f ' { state . current_class } .xml: Unresolved constructor reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " operator "  and  target_name  not  in  class_def . operators : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    f ' { state . current_class } .xml: Unresolved operator reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-08 15:16:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " member " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ref_type  =  " _property " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  target_name  not  in  class_def . properties : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                        f ' { state . current_class } .xml: Unresolved member reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " signal "  and  target_name  not  in  class_def . signals : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    f ' { state . current_class } .xml: Unresolved signal reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " annotation "  and  target_name  not  in  class_def . annotations : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    f ' { state . current_class } .xml: Unresolved annotation reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " theme_item " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  target_name  not  in  class_def . theme_items : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-12 16:55:02 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        f ' { state . current_class } .xml: Unresolved theme property reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-26 19:04:11 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    # Needs theme data type to be properly linked, which we cannot get without a class. 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    name  =  class_def . theme_items [ target_name ] . data_name 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    ref_type  =  f " _theme_ { name } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            elif  tag_state . name  ==  " constant " : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                found  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                # Search in the current class 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                search_class_defs  =  [ class_def ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  link_target . find ( " . " )  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    # Also search in @GlobalScope as a last resort if no class was specified 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    search_class_defs . append ( state . classes [ " @GlobalScope " ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                for  search_class_def  in  search_class_defs : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    if  target_name  in  search_class_def . constants : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                        target_class_name  =  search_class_def . name 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        found  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                        for  enum  in  search_class_def . enums . values ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                            if  target_name  in  enum . values : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                                target_class_name  =  search_class_def . name 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                                found  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                                break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  not  found : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        f ' { state . current_class } .xml: Unresolved constant reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Unresolved type reference  " { target_class_name } "  in method reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        repl_text  =  target_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        if  target_class_name  !=  state . current_class : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            repl_text  =  f " { target_class_name } . { target_name } " 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-07 15:36:25 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        if  tag_state . name  ==  " method " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            repl_text  =  f " { repl_text } () " 
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_text  =  f " :ref:` { repl_text } <class_ { sanitize_class_name ( target_class_name ) } { ref_type } _ { target_name } >` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        escape_pre  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        escape_post  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  tag_state . name  ==  " enum " : 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-15 17:06:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_text  =  make_enum ( link_target ,  False ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        escape_pre  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        escape_post  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    elif  tag_state . name  ==  " param " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        valid_param_context  =  isinstance ( context ,  ( MethodDef ,  SignalDef ,  AnnotationDef ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        if  not  valid_param_context : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                f ' { state . current_class } .xml: Argument reference  " { link_target } "  used outside of method, signal, or annotation context in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        else : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-23 22:21:46 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            context_params :  List [ ParameterDef ]  =  context . parameters   # type: ignore 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            found  =  False 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            for  param_def  in  context_params : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                if  param_def . name  ==  link_target : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    found  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            if  not  found : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    f ' { state . current_class } .xml: Unresolved argument reference  " { link_target } "  in  { context_name } . ' , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                                    state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        tag_text  =  f " `` { link_target } `` " 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-12 15:51:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        escape_pre  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # Formatting directives. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  is_in_tagset ( tag_state . name ,  [ " url " ] ) : 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 22:16:55 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                url_target  =  tag_state . arguments 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  url_target  ==  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f ' { state . current_class } .xml: Misformatted [url] tag  " [ { tag_state . raw } ] "  in  { context_name } . ' , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    # Unlike other tags, URLs are handled in full here, as we need to extract 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    # the optional link title to use `make_link`. 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    endurl_pos  =  text . find ( " [/url] " ,  endq_pos  +  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  endurl_pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            f " { state . current_class } .xml: Tag depth mismatch for [url]: no closing [/url] in  { context_name } . " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    link_title  =  text [ endq_pos  +  1  :  endurl_pos ] 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_text  =  make_link ( url_target ,  link_title ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-06 20:48:54 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    pre_text  =  text [ : pos ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    post_text  =  text [ endurl_pos  +  6  : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  pre_text  and  pre_text [ - 1 ]  not  in  MARKUP_ALLOWED_PRECEDENT : 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        pre_text  + =  " \\   " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    if  post_text  and  post_text [ 0 ]  not  in  MARKUP_ALLOWED_SUBSEQUENT : 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        post_text  =  " \\   "  +  post_text 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    text  =  pre_text  +  tag_text  +  post_text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    pos  =  len ( pre_text )  +  len ( tag_text ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    continue 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " br " : 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Make a new paragraph instead of a linebreak, rst is not so linebreak friendly 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_text  =  " \n \n " 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                # Strip potential leading spaces 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                while  post_text [ 0 ]  ==  "   " : 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    post_text  =  post_text [ 1 : ] 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " center " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_depth  - =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_depth  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_text  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " i " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_depth  - =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_depth  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    escape_pre  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_text  =  " * " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " b " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_depth  - =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_depth  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    escape_pre  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_text  =  " ** " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " u " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_depth  - =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_depth  + =  1 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    escape_pre  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_text  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-07 19:32:08 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " lb " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_text  =  " \\ [ " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " rb " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_text  =  " \\ ] " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  tag_state . name  ==  " kbd " : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-10 13:41:36 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                tag_text  =  " ` " 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_depth  - =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    escape_post  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_text  =  " :kbd: "  +  tag_text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_depth  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    escape_pre  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            # Invalid syntax. 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            else : 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  tag_state . closing : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f ' { state . current_class } .xml: Unrecognized closing tag  " [ { tag_state . raw } ] "  in  { context_name } . ' , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-02 20:11:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    tag_text  =  f " [ { tag_text } ] " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    print_error ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        f ' { state . current_class } .xml: Unrecognized opening tag  " [ { tag_state . raw } ] "  in  { context_name } . ' , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        state , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    tag_text  =  f " `` { tag_text } `` " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    escape_pre  =  True 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    escape_post  =  True 
							 
						 
					
						
							
								
									
										
										
										
											2017-10-21 12:33:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Properly escape things like `[Node]s` 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  escape_pre  and  pre_text  and  pre_text [ - 1 ]  not  in  MARKUP_ALLOWED_PRECEDENT : 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            pre_text  + =  " \\   " 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-21 16:35:47 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  escape_post  and  post_text  and  post_text [ 0 ]  not  in  MARKUP_ALLOWED_SUBSEQUENT : 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            post_text  =  " \\   "  +  post_text 
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        next_brac_pos  =  post_text . find ( " [ " ,  0 ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-02-16 02:24:05 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        iter_pos  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        while  not  inside_code : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            iter_pos  =  post_text . find ( " * " ,  iter_pos ,  next_brac_pos ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-02-16 02:24:05 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  iter_pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                break 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            post_text  =  f " { post_text [ : iter_pos ] } \\ * { post_text [ iter_pos  +  1  : ] } " 
							 
						 
					
						
							
								
									
										
										
										
											2018-02-16 02:24:05 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            iter_pos  + =  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        iter_pos  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        while  not  inside_code : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            iter_pos  =  post_text . find ( " _ " ,  iter_pos ,  next_brac_pos ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-02-16 02:24:05 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  iter_pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  not  post_text [ iter_pos  +  1 ] . isalnum ( ) :   # don't escape within a snake_case word 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                post_text  =  f " { post_text [ : iter_pos ] } \\ _ { post_text [ iter_pos  +  1  : ] } " 
							 
						 
					
						
							
								
									
										
										
										
											2018-02-16 02:24:05 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                iter_pos  + =  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                iter_pos  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        text  =  pre_text  +  tag_text  +  post_text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pos  =  len ( pre_text )  +  len ( tag_text ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  tag_depth  >  0 : 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-11 00:43:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        print_error ( 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            f " { state . current_class } .xml: Tag depth mismatch: too many (or too few) open/close tags in  { context_name } . " , 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            state , 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-11 00:43:44 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-12-28 00:37:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-10-30 18:44:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  text 
							 
						 
					
						
							
								
									
										
										
										
											2016-02-06 20:22:49 -03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-05-17 20:00:17 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  preformat_text_block ( text :  str ,  state :  State )  - >  Optional [ str ] :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    result  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    codeblock_tag  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    indent_level  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  line  in  text . splitlines ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        stripped_line  =  line . lstrip ( " \t " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        tab_count  =  len ( line )  -  len ( stripped_line ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  codeblock_tag : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  line  ==  " " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                result  + =  " \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  tab_count  <  indent_level : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                print_error ( f " { state . current_class } .xml: Invalid indentation. " ,  state ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  stripped_line . startswith ( " [/ "  +  codeblock_tag ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                result  + =  stripped_line 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                codeblock_tag  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # Remove extraneous tabs and replace remaining tabs with spaces. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                result  + =  " \n "  +  "      "  *  ( tab_count  -  indent_level  +  1 )  +  stripped_line 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                stripped_line . startswith ( " [codeblock] " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                or  stripped_line . startswith ( " [codeblock  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                or  stripped_line . startswith ( " [gdscript] " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                or  stripped_line . startswith ( " [gdscript  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                or  stripped_line . startswith ( " [csharp] " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                or  stripped_line . startswith ( " [csharp  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  result : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    result  + =  " \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                result  + =  stripped_line 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_text  =  stripped_line [ 1 : ] . split ( " ] " ,  1 ) [ 0 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                tag_state  =  get_tag_and_args ( tag_text ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                codeblock_tag  =  tag_state . name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                indent_level  =  tab_count 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # A line break in XML should become two line breaks (unless in a code block). 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  result : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    result  + =  " \n \n " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                result  + =  stripped_line 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  result 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  format_context_name ( context :  Union [ DefinitionBase ,  None ] )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    context_name :  str  =  " unknown context " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  context  is  not  None : 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        context_name  =  f ' { context . definition_name }   " { context . name } "  description ' 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  context_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  escape_rst ( text :  str ,  until_pos :  int  =  - 1 )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Escape \ character, otherwise it ends up as an escape character in rst 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    pos  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    while  True : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pos  =  text . find ( " \\ " ,  pos ,  until_pos ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            break 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        text  =  f " { text [ : pos ] } \\ \\ { text [ pos  +  1  : ] } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        pos  + =  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Escape * character to avoid interpreting it as emphasis 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    pos  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    while  True : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pos  =  text . find ( " * " ,  pos ,  until_pos ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            break 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        text  =  f " { text [ : pos ] } \\ * { text [ pos  +  1  : ] } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        pos  + =  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Escape _ character at the end of a word to avoid interpreting it as an inline hyperlink 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    pos  =  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    while  True : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pos  =  text . find ( " _ " ,  pos ,  until_pos ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  pos  ==  - 1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            break 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  not  text [ pos  +  1 ] . isalnum ( ) :   # don't escape within a snake_case word 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-06 11:51:41 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            text  =  f " { text [ : pos ] } \\ _ { text [ pos  +  1  : ] } " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-09 23:53:29 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            pos  + =  2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            pos  + =  1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  text 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  format_table ( f :  TextIO ,  data :  List [ Tuple [ Optional [ str ] ,  . . . ] ] ,  remove_empty_columns :  bool  =  False )  - >  None :  
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  len ( data )  ==  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    f . write ( " .. table:: \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    f . write ( "    :widths: auto \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Calculate the width of each column first, we will use this information 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # to properly format RST-style tables. 
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    column_sizes  =  [ 0 ]  *  len ( data [ 0 ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  row  in  data : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  i ,  text  in  enumerate ( row ) : 
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            text_length  =  len ( text  or  " " ) 
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  text_length  >  column_sizes [ i ] : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                column_sizes [ i ]  =  text_length 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Each table row is wrapped in two separators, consecutive rows share the same separator. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # All separators, or rather borders, have the same shape and content. We compose it once, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # then reuse it. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    sep  =  " " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  size  in  column_sizes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  size  ==  0  and  remove_empty_columns : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            continue 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        sep  + =  " + "  +  " - "  *  ( size  +  2 )   # Content of each cell is padded by 1 on each side. 
							 
						 
					
						
							
								
									
										
										
										
											2018-09-13 02:00:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    sep  + =  " + \n " 
							 
						 
					
						
							
								
									
										
										
										
											2019-10-24 19:06:09 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Draw the first separator. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    f . write ( f "     { sep } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Draw each row and close it with a separator. 
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  row  in  data : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        row_text  =  " | " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  i ,  text  in  enumerate ( row ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  column_sizes [ i ]  ==  0  and  remove_empty_columns : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                continue 
							 
						 
					
						
							
								
									
										
										
										
											2025-02-03 09:55:09 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            row_text  + =  f "   { ( text  or  ' ' ) . ljust ( column_sizes [ i ] ) }  | " 
							 
						 
					
						
							
								
									
										
										
										
											2019-06-01 16:42:22 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        row_text  + =  " \n " 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-30 16:34:42 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( f "     { row_text } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        f . write ( f "     { sep } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    f . write ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2018-09-13 02:00:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-11-30 11:48:14 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  sanitize_class_name ( dirty_name :  str ,  is_file_name = False )  - >  str :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  is_file_name : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  dirty_name . lower ( ) . replace ( ' " ' ,  " " ) . replace ( " / " ,  " -- " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  dirty_name . replace ( ' " ' ,  " " ) . replace ( " / " ,  " _ " ) . replace ( " . " ,  " _ " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-07-27 18:54:26 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  sanitize_operator_name ( dirty_name :  str ,  state :  State )  - >  str :  
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    clear_name  =  dirty_name . replace ( " operator  " ,  " " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  clear_name  ==  " != " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " neq " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " == " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " eq " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " < " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " lt " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " <= " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " lte " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " > " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " gt " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " >= " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " gte " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " + " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " sum " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " - " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " dif " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " * " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " mul " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " / " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " div " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " % " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " mod " 
							 
						 
					
						
							
								
									
										
										
										
											2022-03-07 20:25:21 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    elif  clear_name  ==  " ** " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " pow " 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " unary+ " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " unplus " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " unary- " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " unminus " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " << " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " bwsl " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " >> " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " bwsr " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " & " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " bwand " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " | " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " bwor " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " ^ " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " bwxor " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " ~ " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " bwnot " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  clear_name  ==  " [] " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " idx " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        clear_name  =  " xxx " 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-17 14:34:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        print_error ( f ' Unsupported operator type  " { dirty_name } " , please add the missing rule. ' ,  state ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-02 22:19:40 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  clear_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-03-30 08:28:32 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  __name__  ==  " __main__ " :  
						 
					
						
							
								
									
										
										
										
											2018-12-26 15:57:51 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    main ( )