mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Move pgkill out into /port so pg_ctl can use it on Win32.
This commit is contained in:
		
							
								
								
									
										1
									
								
								configure
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								configure
									
									
									
									
										vendored
									
									
								
							| @@ -12014,6 +12014,7 @@ esac | |||||||
| case $host_os in mingw*) | case $host_os in mingw*) | ||||||
| LIBOBJS="$LIBOBJS copydir.$ac_objext" | LIBOBJS="$LIBOBJS copydir.$ac_objext" | ||||||
| LIBOBJS="$LIBOBJS gettimeofday.$ac_objext" | LIBOBJS="$LIBOBJS gettimeofday.$ac_objext" | ||||||
|  | LIBOBJS="$LIBOBJS kill.$ac_objext" | ||||||
| LIBOBJS="$LIBOBJS open.$ac_objext" | LIBOBJS="$LIBOBJS open.$ac_objext" | ||||||
| LIBOBJS="$LIBOBJS rand.$ac_objext" ;; | LIBOBJS="$LIBOBJS rand.$ac_objext" ;; | ||||||
| esac | esac | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| dnl Process this file with autoconf to produce a configure script. | dnl Process this file with autoconf to produce a configure script. | ||||||
| dnl $PostgreSQL: pgsql/configure.in,v 1.358 2004/05/22 00:34:49 tgl Exp $ | dnl $PostgreSQL: pgsql/configure.in,v 1.359 2004/05/27 13:08:48 momjian Exp $ | ||||||
| dnl | dnl | ||||||
| dnl Developers, please strive to achieve this order: | dnl Developers, please strive to achieve this order: | ||||||
| dnl | dnl | ||||||
| @@ -891,6 +891,7 @@ esac | |||||||
| case $host_os in mingw*) | case $host_os in mingw*) | ||||||
| AC_LIBOBJ(copydir) | AC_LIBOBJ(copydir) | ||||||
| AC_LIBOBJ(gettimeofday) | AC_LIBOBJ(gettimeofday) | ||||||
|  | AC_LIBOBJ(kill) | ||||||
| AC_LIBOBJ(open) | AC_LIBOBJ(open) | ||||||
| AC_LIBOBJ(rand) ;; | AC_LIBOBJ(rand) ;; | ||||||
| esac | esac | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group |  * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $PostgreSQL: pgsql/src/backend/port/win32/signal.c,v 1.1 2004/04/12 16:19:18 momjian Exp $ |  *	  $PostgreSQL: pgsql/src/backend/port/win32/signal.c,v 1.2 2004/05/27 13:08:50 momjian Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -152,46 +152,6 @@ pqsignal(int signum, pqsigfunc handler) | |||||||
| 	return prevfunc; | 	return prevfunc; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* signal sending */ |  | ||||||
| int |  | ||||||
| pqkill(int pid, int sig) |  | ||||||
| { |  | ||||||
| 	char		pipename[128]; |  | ||||||
| 	BYTE		sigData = sig; |  | ||||||
| 	BYTE		sigRet = 0; |  | ||||||
| 	DWORD		bytes; |  | ||||||
|  |  | ||||||
| 	if (sig >= PG_SIGNAL_COUNT || sig <= 0) |  | ||||||
| 	{ |  | ||||||
| 		errno = EINVAL; |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	if (pid <= 0) |  | ||||||
| 	{ |  | ||||||
| 		/* No support for process groups */ |  | ||||||
| 		errno = EINVAL; |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	wsprintf(pipename, "\\\\.\\pipe\\pgsignal_%i", pid); |  | ||||||
| 	if (!CallNamedPipe(pipename, &sigData, 1, &sigRet, 1, &bytes, 1000)) |  | ||||||
| 	{ |  | ||||||
| 		if (GetLastError() == ERROR_FILE_NOT_FOUND) |  | ||||||
| 			errno = ESRCH; |  | ||||||
| 		else if (GetLastError() == ERROR_ACCESS_DENIED) |  | ||||||
| 			errno = EPERM; |  | ||||||
| 		else |  | ||||||
| 			errno = EINVAL; |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	if (bytes != 1 || sigRet != sig) |  | ||||||
| 	{ |  | ||||||
| 		errno = ESRCH; |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * All functions below execute on the signal handler thread |  * All functions below execute on the signal handler thread | ||||||
|  * and must be synchronized as such! |  * and must be synchronized as such! | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /* $PostgreSQL: pgsql/src/include/port/win32.h,v 1.23 2004/04/22 03:51:24 momjian Exp $ */ | /* $PostgreSQL: pgsql/src/include/port/win32.h,v 1.24 2004/05/27 13:08:54 momjian Exp $ */ | ||||||
|  |  | ||||||
| /* undefine and redefine after #include */ | /* undefine and redefine after #include */ | ||||||
| #undef mkdir | #undef mkdir | ||||||
| @@ -116,10 +116,10 @@ void pg_queue_signal(int signum); | |||||||
| #define SIG_ERR ((pqsigfunc)-1) | #define SIG_ERR ((pqsigfunc)-1) | ||||||
| #define SIG_IGN ((pqsigfunc)1) | #define SIG_IGN ((pqsigfunc)1) | ||||||
|  |  | ||||||
| #ifndef FRONTEND | #define kill(pid,sig)   pgkill(pid,sig) | ||||||
| #define kill(pid,sig)   pqkill(pid,sig) | extern int pgkill(int pid, int sig); | ||||||
| extern int pqkill(int pid, int sig); |  | ||||||
|  |  | ||||||
|  | #ifndef FRONTEND | ||||||
| #define pg_usleep(t) pgwin32_backend_usleep(t) | #define pg_usleep(t) pgwin32_backend_usleep(t) | ||||||
| void pgwin32_backend_usleep(long microsec); | void pgwin32_backend_usleep(long microsec); | ||||||
| #endif | #endif | ||||||
|   | |||||||
							
								
								
									
										59
									
								
								src/port/kill.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								src/port/kill.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | |||||||
|  | /*------------------------------------------------------------------------- | ||||||
|  |  * | ||||||
|  |  * kill.c | ||||||
|  |  *	  kill() | ||||||
|  |  * | ||||||
|  |  * Copyright (c) 1996-2003, PostgreSQL Global Development Group | ||||||
|  |  * | ||||||
|  |  *	This is a replacement version of kill for Win32 which sends | ||||||
|  |  *	signals that the backend can recognize. | ||||||
|  |  * | ||||||
|  |  * IDENTIFICATION | ||||||
|  |  *	  $PostgreSQL: pgsql/src/port/kill.c,v 1.1 2004/05/27 13:08:57 momjian Exp $ | ||||||
|  |  * | ||||||
|  |  *------------------------------------------------------------------------- | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include "postgres.h" | ||||||
|  |  | ||||||
|  | #ifdef WIN32 | ||||||
|  | /* signal sending */ | ||||||
|  | int | ||||||
|  | pgkill(int pid, int sig) | ||||||
|  | { | ||||||
|  | 	char		pipename[128]; | ||||||
|  | 	BYTE		sigData = sig; | ||||||
|  | 	BYTE		sigRet = 0; | ||||||
|  | 	DWORD		bytes; | ||||||
|  |  | ||||||
|  | 	if (sig >= PG_SIGNAL_COUNT || sig <= 0) | ||||||
|  | 	{ | ||||||
|  | 		errno = EINVAL; | ||||||
|  | 		return -1; | ||||||
|  | 	} | ||||||
|  | 	if (pid <= 0) | ||||||
|  | 	{ | ||||||
|  | 		/* No support for process groups */ | ||||||
|  | 		errno = EINVAL; | ||||||
|  | 		return -1; | ||||||
|  | 	} | ||||||
|  | 	wsprintf(pipename, "\\\\.\\pipe\\pgsignal_%i", pid); | ||||||
|  | 	if (!CallNamedPipe(pipename, &sigData, 1, &sigRet, 1, &bytes, 1000)) | ||||||
|  | 	{ | ||||||
|  | 		if (GetLastError() == ERROR_FILE_NOT_FOUND) | ||||||
|  | 			errno = ESRCH; | ||||||
|  | 		else if (GetLastError() == ERROR_ACCESS_DENIED) | ||||||
|  | 			errno = EPERM; | ||||||
|  | 		else | ||||||
|  | 			errno = EINVAL; | ||||||
|  | 		return -1; | ||||||
|  | 	} | ||||||
|  | 	if (bytes != 1 || sigRet != sig) | ||||||
|  | 	{ | ||||||
|  | 		errno = ESRCH; | ||||||
|  | 		return -1; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return 0; | ||||||
|  | } | ||||||
|  | #endif | ||||||
		Reference in New Issue
	
	Block a user