mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-31 00:03:57 -04:00 
			
		
		
		
	Remove extremely old, incomplete, broken example code.
Per my proposal a few days ago.
This commit is contained in:
		
							parent
							
								
									7868590c61
								
							
						
					
					
						commit
						ff0ac57db9
					
				| @ -1,78 +0,0 @@ | |||||||
| /*-------------------------------------------------------------------------
 |  | ||||||
|  * |  | ||||||
|  * beard.c |  | ||||||
|  *	  sample routines to use large objects |  | ||||||
|  * |  | ||||||
|  * Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group |  | ||||||
|  * Portions Copyright (c) 1994, Regents of the University of California |  | ||||||
|  * |  | ||||||
|  * |  | ||||||
|  * IDENTIFICATION |  | ||||||
|  *	  $PostgreSQL: pgsql/src/tutorial/beard.c,v 1.15 2006/03/05 15:59:11 momjian Exp $ |  | ||||||
|  * |  | ||||||
|  *------------------------------------------------------------------------- |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| typedef struct ImageHdr |  | ||||||
| { |  | ||||||
| 	int			size; |  | ||||||
| }	ImageHdr; |  | ||||||
| 
 |  | ||||||
| #define BUFSIZE 10 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * beard - |  | ||||||
|  *	 clips lower 1/3 of picture and return as large object |  | ||||||
|  */ |  | ||||||
| Oid |  | ||||||
| beard(Oid picture) |  | ||||||
| { |  | ||||||
| 	Oid			beard; |  | ||||||
| 	int			pic_fd, |  | ||||||
| 				beard_fd; |  | ||||||
| 	ImageHdr	ihdr; |  | ||||||
| 	char		buf[BUFSIZE]; |  | ||||||
| 	int			cc; |  | ||||||
| 
 |  | ||||||
| 	pic_fd = DatumGetInt32(DirectFunctionCall2(lo_open, |  | ||||||
| 											   ObjectIdGetDatum(picture), |  | ||||||
| 											   Int32GetDatum(INV_READ))); |  | ||||||
| 	if (pic_fd < 0) |  | ||||||
| 		elog(ERROR, "could not access picture large object"); |  | ||||||
| 
 |  | ||||||
| 	if (lo_read(pic_fd, (char *) &ihdr, sizeof(ihdr)) != sizeof(ihdr)) |  | ||||||
| 		elog(ERROR, "picture large object corrupted"); |  | ||||||
| 
 |  | ||||||
| 	beardOffset = (ihdr.size / 3) * 2; |  | ||||||
| 
 |  | ||||||
| 	/*
 |  | ||||||
| 	 * new large object |  | ||||||
| 	 */ |  | ||||||
| 	beard = DatumGetObjectId(DirectFunctionCall1(lo_creat, |  | ||||||
| 												 Int32GetDatum(INV_MD))); |  | ||||||
| 	if (beard == InvalidOid) |  | ||||||
| 		elog(ERROR, "could not create new large object"); |  | ||||||
| 
 |  | ||||||
| 	beard_fd = DatumGetInt32(DirectFunctionCall2(lo_open, |  | ||||||
| 												 ObjectIdGetDatum(beard), |  | ||||||
| 												 Int32GetDatum(INV_WRITE))); |  | ||||||
| 	if (beard_fd < 0) |  | ||||||
| 		elog(ERROR, "could not access beard large object"); |  | ||||||
| 
 |  | ||||||
| 	if (DatumGetInt32(DirectFunctionCall3(lo_lseek, |  | ||||||
| 										  Int32GetDatum(pic_fd), |  | ||||||
| 										  Int32GetDatum(beardOffset), |  | ||||||
| 										  Int32GetDatum(SEEK_SET))) < 0) |  | ||||||
| 		elog(ERROR, "could not seek in picture large object"); |  | ||||||
| 
 |  | ||||||
| 	while ((cc = lo_read(pic_fd, buf, BUFSIZE)) > 0) |  | ||||||
| 	{ |  | ||||||
| 		if (lo_write(beard_fd, buf, cc) != cc) |  | ||||||
| 			elog(ERROR, "error while writing large object"); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	DirectFunctionCall1(lo_close, Int32GetDatum(pic_fd)); |  | ||||||
| 	DirectFunctionCall1(lo_close, Int32GetDatum(beard_fd)); |  | ||||||
| 
 |  | ||||||
| 	return beard; |  | ||||||
| } |  | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user