mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 06:00:36 +00:00 
			
		
		
		
	Return trunk to a state where it compiles under Darwin. The byte order stuff is ugly, if anyone wants to clean it up... by all means do so.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@55763 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		
							
								
								
									
										24
									
								
								main/dns.c
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								main/dns.c
									
									
									
									
									
								
							| @@ -48,9 +48,21 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") | ||||
|  | ||||
| #define MAX_SIZE 4096 | ||||
|  | ||||
| #ifdef __PDP_ENDIAN | ||||
| #if __BYTE_ORDER == __PDP_ENDIAN | ||||
| #define DETERMINED_BYTE_ORDER __LITTLE_ENDIAN | ||||
| #endif | ||||
| #endif | ||||
| #if __BYTE_ORDER == __BIG_ENDIAN | ||||
| #define DETERMINED_BYTE_ORDER __BIG_ENDIAN | ||||
| #endif | ||||
| #if __BYTE_ORDER == __LITTLE_ENDIAN | ||||
| #define DETERMINED_BYTE_ORDER __LITTLE_ENDIAN | ||||
| #endif | ||||
|  | ||||
| typedef struct { | ||||
| 	unsigned	id:16;          /*!< query identification number */ | ||||
| #if __BYTE_ORDER == __BIG_ENDIAN | ||||
| #if DETERMINED_BYTE_ORDER == __BIG_ENDIAN | ||||
| 			/* fields in third byte */ | ||||
| 	unsigned	qr:1;           /*!< response flag */ | ||||
| 	unsigned	opcode:4;       /*!< purpose of message */ | ||||
| @@ -64,7 +76,7 @@ typedef struct { | ||||
| 	unsigned	cd:1;           /*!< checking disabled by resolver */ | ||||
| 	unsigned	rcode:4;        /*!< response code */ | ||||
| #endif | ||||
| #if __BYTE_ORDER == __LITTLE_ENDIAN || __BYTE_ORDER == __PDP_ENDIAN | ||||
| #if DETERMINED_BYTE_ORDER == __LITTLE_ENDIAN | ||||
| 			/* fields in third byte */ | ||||
| 	unsigned	rd:1;           /*!< recursion desired */ | ||||
| 	unsigned	tc:1;           /*!< truncated message */ | ||||
| @@ -178,7 +190,7 @@ static int dns_parse_answer(void *context, | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| #if !HAVE_RES_NINIT | ||||
| #ifndef HAVE_RES_NINIT | ||||
| AST_MUTEX_DEFINE_STATIC(res_lock); | ||||
| #endif | ||||
|  | ||||
| @@ -190,13 +202,13 @@ int ast_search_dns(void *context, | ||||
| 	   const char *dname, int class, int type, | ||||
| 	   int (*callback)(void *context, unsigned char *answer, int len, unsigned char *fullanswer)) | ||||
| { | ||||
| #if HAVE_RES_NINIT | ||||
| #ifdef HAVE_RES_NINIT | ||||
| 	struct __res_state dnsstate; | ||||
| #endif | ||||
| 	unsigned char answer[MAX_SIZE]; | ||||
| 	int res, ret = -1; | ||||
|  | ||||
| #if HAVE_RES_NINIT | ||||
| #ifdef HAVE_RES_NINIT | ||||
| 	res_ninit(&dnsstate); | ||||
| 	res = res_nsearch(&dnsstate, dname, class, type, answer, sizeof(answer)); | ||||
| #else | ||||
| @@ -217,7 +229,7 @@ int ast_search_dns(void *context, | ||||
| 		else | ||||
| 			ret = 1; | ||||
| 	} | ||||
| #if HAVE_RES_NINIT | ||||
| #ifdef HAVE_RES_NINIT | ||||
| 	res_nclose(&dnsstate); | ||||
| #else | ||||
| #ifndef __APPLE__ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user