mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Switch to 2.1 version of pg_bsd_indent. This formats multiline function declarations "correctly", that is with additional lines of parameter declarations indented to match where the first line's left parenthesis is. Discussion: https://postgr.es/m/CAEepm=0P3FeTXRcU5B2W3jv3PgRVZ-kGUXLGfd42FFhUROO3ug@mail.gmail.com
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*-------------------------------------------------------------------------
 | |
|  *
 | |
|  * worker_internal.h
 | |
|  *	  Internal headers shared by logical replication workers.
 | |
|  *
 | |
|  * Portions Copyright (c) 2016-2019, PostgreSQL Global Development Group
 | |
|  *
 | |
|  * src/include/replication/worker_internal.h
 | |
|  *
 | |
|  *-------------------------------------------------------------------------
 | |
|  */
 | |
| #ifndef WORKER_INTERNAL_H
 | |
| #define WORKER_INTERNAL_H
 | |
| 
 | |
| #include <signal.h>
 | |
| 
 | |
| #include "access/xlogdefs.h"
 | |
| #include "catalog/pg_subscription.h"
 | |
| #include "datatype/timestamp.h"
 | |
| #include "storage/lock.h"
 | |
| 
 | |
| typedef struct LogicalRepWorker
 | |
| {
 | |
| 	/* Time at which this worker was launched. */
 | |
| 	TimestampTz launch_time;
 | |
| 
 | |
| 	/* Indicates if this slot is used or free. */
 | |
| 	bool		in_use;
 | |
| 
 | |
| 	/* Increased every time the slot is taken by new worker. */
 | |
| 	uint16		generation;
 | |
| 
 | |
| 	/* Pointer to proc array. NULL if not running. */
 | |
| 	PGPROC	   *proc;
 | |
| 
 | |
| 	/* Database id to connect to. */
 | |
| 	Oid			dbid;
 | |
| 
 | |
| 	/* User to use for connection (will be same as owner of subscription). */
 | |
| 	Oid			userid;
 | |
| 
 | |
| 	/* Subscription id for the worker. */
 | |
| 	Oid			subid;
 | |
| 
 | |
| 	/* Used for initial table synchronization. */
 | |
| 	Oid			relid;
 | |
| 	char		relstate;
 | |
| 	XLogRecPtr	relstate_lsn;
 | |
| 	slock_t		relmutex;
 | |
| 
 | |
| 	/* Stats. */
 | |
| 	XLogRecPtr	last_lsn;
 | |
| 	TimestampTz last_send_time;
 | |
| 	TimestampTz last_recv_time;
 | |
| 	XLogRecPtr	reply_lsn;
 | |
| 	TimestampTz reply_time;
 | |
| } LogicalRepWorker;
 | |
| 
 | |
| /* Main memory context for apply worker. Permanent during worker lifetime. */
 | |
| extern MemoryContext ApplyContext;
 | |
| 
 | |
| /* libpqreceiver connection */
 | |
| extern struct WalReceiverConn *wrconn;
 | |
| 
 | |
| /* Worker and subscription objects. */
 | |
| extern Subscription *MySubscription;
 | |
| extern LogicalRepWorker *MyLogicalRepWorker;
 | |
| 
 | |
| extern bool in_remote_transaction;
 | |
| 
 | |
| extern void logicalrep_worker_attach(int slot);
 | |
| extern LogicalRepWorker *logicalrep_worker_find(Oid subid, Oid relid,
 | |
| 												bool only_running);
 | |
| extern List *logicalrep_workers_find(Oid subid, bool only_running);
 | |
| extern void logicalrep_worker_launch(Oid dbid, Oid subid, const char *subname,
 | |
| 									 Oid userid, Oid relid);
 | |
| extern void logicalrep_worker_stop(Oid subid, Oid relid);
 | |
| extern void logicalrep_worker_stop_at_commit(Oid subid, Oid relid);
 | |
| extern void logicalrep_worker_wakeup(Oid subid, Oid relid);
 | |
| extern void logicalrep_worker_wakeup_ptr(LogicalRepWorker *worker);
 | |
| 
 | |
| extern int	logicalrep_sync_worker_count(Oid subid);
 | |
| 
 | |
| extern char *LogicalRepSyncTableStart(XLogRecPtr *origin_startpos);
 | |
| void		process_syncing_tables(XLogRecPtr current_lsn);
 | |
| void		invalidate_syncing_table_states(Datum arg, int cacheid,
 | |
| 											uint32 hashvalue);
 | |
| 
 | |
| static inline bool
 | |
| am_tablesync_worker(void)
 | |
| {
 | |
| 	return OidIsValid(MyLogicalRepWorker->relid);
 | |
| }
 | |
| 
 | |
| #endif							/* WORKER_INTERNAL_H */
 |