lin
2025-01-04 be45768b193281917003531c55e9ebda9d2c2f99
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
 
#include "utils.h"
 
static __inline__ u_int16_t dn_htons(u_int16_t addr)
{
        union {
                u_int8_t byte[2];
                u_int16_t word;
        } u;
 
        u.word = addr;
        return ((u_int16_t)u.byte[0]) | (((u_int16_t)u.byte[1]) << 8);
}
 
 
static int dnet_num(const char *src, u_int16_t * dst)
{
   int rv = 0;
   int tmp;
   *dst = 0;
 
   while ((tmp = *src++) != 0) {
       tmp -= '0';
       if ((tmp < 0) || (tmp > 9))
           return rv;
 
       rv++;
       (*dst) *= 10;
       (*dst) += tmp;
   }
 
   return rv;
}
 
static int dnet_pton1(const char *src, struct dn_naddr *dna)
{
   u_int16_t addr;
   u_int16_t area = 0;
   u_int16_t node = 0;
   int pos;
 
   pos = dnet_num(src, &area);
   if ((pos == 0) || (area > 63) || (*(src + pos) != '.'))
       return 0;
   pos = dnet_num(src + pos + 1, &node);
   if ((pos == 0) || (node > 1023))
       return 0;
   dna->a_len = 2;
   addr = dn_htons((area << 10) | node);
   memcpy(dna->a_addr, &addr, sizeof(addr));
 
   return 1;
}
 
int dnet_pton(int af, const char *src, void *addr)
{
   int err;
 
   switch (af) {
   case AF_DECnet:
       errno = 0;
       err = dnet_pton1(src, (struct dn_naddr *)addr);
       break;
   default:
       errno = EAFNOSUPPORT;
       err = -1;
   }
 
   return err;
}