aboutsummaryrefslogtreecommitdiffstats
path: root/lib/sh/netopen.c
diff options
context:
space:
mode:
authorJari Aalto <jari.aalto@cante.net>2001-04-06 19:14:31 +0000
committerJari Aalto <jari.aalto@cante.net>2009-09-12 16:46:53 +0000
commit28ef6c316f1aff914bb95ac09787a3c83c1815fd (patch)
tree2812fe7ffc9beec4f99856906ddfcafda54cf16a /lib/sh/netopen.c
parentbb70624e964126b7ac4ff085ba163a9c35ffa18f (diff)
downloadandroid_external_bash-28ef6c316f1aff914bb95ac09787a3c83c1815fd.tar.gz
android_external_bash-28ef6c316f1aff914bb95ac09787a3c83c1815fd.tar.bz2
android_external_bash-28ef6c316f1aff914bb95ac09787a3c83c1815fd.zip
Imported from ../bash-2.05.tar.gz.
Diffstat (limited to 'lib/sh/netopen.c')
-rw-r--r--lib/sh/netopen.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/lib/sh/netopen.c b/lib/sh/netopen.c
index 789a9b3..f0b0b9b 100644
--- a/lib/sh/netopen.c
+++ b/lib/sh/netopen.c
@@ -97,8 +97,9 @@ _getaddr (host, ap)
/* Return 1 if SERV is a valid port number and stuff the converted value into
PP in network byte order. */
static int
-_getserv (serv, pp)
+_getserv (serv, proto, pp)
char *serv;
+ int proto;
unsigned short *pp;
{
long l;
@@ -115,7 +116,20 @@ _getserv (serv, pp)
return 1;
}
else
+#if defined (HAVE_GETSERVBYNAME)
+ {
+ struct servent *se;
+
+ se = getservbyname (serv, (proto == 't') ? "tcp" : "udp");
+ if (se == 0)
+ return 0;
+ if (pp)
+ *pp = se->s_port; /* ports returned in network byte order */
+ return 1;
+ }
+#else /* !HAVE_GETSERVBYNAME */
return 0;
+#endif /* !HAVE_GETSERVBYNAME */
}
static int
@@ -126,18 +140,20 @@ _netopen(host, serv, typ)
struct in_addr ina;
struct sockaddr_in sin;
unsigned short p;
- int s;
+ int s, e;
char **cp;
if (_getaddr(host, &ina) == 0)
{
internal_error ("%s: host unknown", host);
+ errno = EINVAL;
return -1;
}
- if (_getserv(serv, &p) == 0)
+ if (_getserv(serv, typ, &p) == 0)
{
internal_error("%s: invalid service", serv);
+ errno = EINVAL;
return -1;
}
@@ -155,8 +171,10 @@ _netopen(host, serv, typ)
if (connect (s, (struct sockaddr *)&sin, sizeof (sin)) < 0)
{
+ e = errno;
sys_error("connect");
close(s);
+ errno = e;
return (-1);
}