mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Generate automatically code and documentation related to wait events
The documentation and the code is generated automatically from a new file called wait_event_names.txt, formatted in sections dedicated to each wait event class (Timeout, Lock, IO, etc.) with three tab-separated fields: - C symbol in enums - Format in the system views - Description in the docs Using this approach has several advantages, as we have proved to be rather bad in maintaining this area of the tree across the years: - The order of each item in the documentation and the code, which should be alphabetical, has become incorrect multiple times, and the script generating the code and documentation has a few rules to enforce that, making the maintenance a no-brainer. - Some wait events were added to the code, but not documented, so this cannot be missed now. - The order of the tables for each wait event class is enforced in the documentation (the input .txt file does so as well for clarity, though this is not mandatory). - Less code, shaving 1.2k lines from the tree, with 1/3 of the savings coming from the code, the rest from the documentation. The wait event types "Lock" and "LWLock" still have their own code path for their code, hence only the documentation is created for them. These classes are listed with a special marker called WAIT_EVENT_DOCONLY in the input file. Adding a new wait event now requires only an update of wait_event_names.txt, with "Lock" and "LWLock" treated as exceptions. This commit has been tested with configure/Makefile, the CI and VPATH build. clean, distclean and maintainer-clean were working fine. Author: Bertrand Drouvot, Michael Paquier Discussion: https://postgr.es/m/77a86b3a-c4a8-5f5d-69b9-d70bbf2e9b98@gmail.com
This commit is contained in:
		
							
								
								
									
										1
									
								
								doc/src/sgml/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								doc/src/sgml/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -17,6 +17,7 @@ | ||||
| /errcodes-table.sgml | ||||
| /keywords-table.sgml | ||||
| /version.sgml | ||||
| /wait_event_types.sgml | ||||
| # Assorted byproducts from building the above | ||||
| /postgres-full.xml | ||||
| /INSTALL.html | ||||
|   | ||||
| @@ -58,7 +58,7 @@ override XSLTPROCFLAGS += --stringparam pg.version '$(VERSION)' | ||||
|  | ||||
| GENERATED_SGML = version.sgml \ | ||||
| 	features-supported.sgml features-unsupported.sgml errcodes-table.sgml \ | ||||
| 	keywords-table.sgml | ||||
| 	keywords-table.sgml wait_event_types.sgml | ||||
|  | ||||
| ALLSGML := $(wildcard $(srcdir)/*.sgml $(srcdir)/ref/*.sgml) $(GENERATED_SGML) | ||||
|  | ||||
| @@ -111,6 +111,8 @@ errcodes-table.sgml: $(top_srcdir)/src/backend/utils/errcodes.txt generate-errco | ||||
| keywords-table.sgml: $(top_srcdir)/src/include/parser/kwlist.h $(wildcard $(srcdir)/keywords/sql*.txt) generate-keywords-table.pl | ||||
| 	$(PERL) $(srcdir)/generate-keywords-table.pl $(srcdir) > $@ | ||||
|  | ||||
| wait_event_types.sgml: $(top_srcdir)/src/backend/utils/activity/wait_event_names.txt $(top_srcdir)/src/backend/utils/activity/generate-wait_event_types.pl | ||||
| 	$(PERL) $(top_srcdir)/src/backend/utils/activity/generate-wait_event_types.pl --docs $< | ||||
|  | ||||
| ## | ||||
| ## Generation of some text files. | ||||
|   | ||||
| @@ -42,6 +42,7 @@ | ||||
| <!ENTITY maintenance   SYSTEM "maintenance.sgml"> | ||||
| <!ENTITY manage-ag     SYSTEM "manage-ag.sgml"> | ||||
| <!ENTITY monitoring    SYSTEM "monitoring.sgml"> | ||||
| <!ENTITY wait_event_types    SYSTEM "wait_event_types.sgml"> | ||||
| <!ENTITY regress       SYSTEM "regress.sgml"> | ||||
| <!ENTITY runtime       SYSTEM "runtime.sgml"> | ||||
| <!ENTITY config        SYSTEM "config.sgml"> | ||||
|   | ||||
| @@ -46,6 +46,18 @@ doc_generated += custom_target('errcodes-table.sgml', | ||||
|   capture: true, | ||||
| ) | ||||
|  | ||||
| doc_generated += custom_target('wait_event_types.sgml', | ||||
|   input: files( | ||||
|     '../../../src/backend/utils/activity/wait_event_names.txt'), | ||||
|   output: 'wait_event_types.sgml', | ||||
|   command: [perl, | ||||
|     files('../../../src/backend/utils/activity/generate-wait_event_types.pl'), | ||||
|     '--outdir', '@OUTDIR@', '--docs', '@INPUT@'], | ||||
|   build_by_default: false, | ||||
|   install: false, | ||||
|   capture: false, | ||||
| ) | ||||
|  | ||||
| # FIXME: this actually has further inputs, adding depfile support to | ||||
| # generate-keywords-table.pl is probably the best way to address that | ||||
| # robustly. | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user