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