aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/udp.c
diff options
context:
space:
mode:
authorLuca Abeni <lucabe72@email.it>2007-11-14 08:16:51 +0000
committerLuca Abeni <lucabe72@email.it>2007-11-14 08:16:51 +0000
commitd05cb726bdd50286a72fa23554bb3257ba23cae4 (patch)
treefb8b080d2bf352b233a6bd3c3c45171863447913 /libavformat/udp.c
parent4c7d5764a03edc11583a4dc0d73a26612c3250cd (diff)
downloadffmpeg-d05cb726bdd50286a72fa23554bb3257ba23cae4.tar.gz
Simplify set_remote_url(), and remove some code duplication
Originally committed as revision 11016 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/udp.c')
-rw-r--r--libavformat/udp.c40
1 files changed, 24 insertions, 16 deletions
diff --git a/libavformat/udp.c b/libavformat/udp.c
index 2c40415a1c..c1ff2b181e 100644
--- a/libavformat/udp.c
+++ b/libavformat/udp.c
@@ -145,18 +145,17 @@ static struct addrinfo* udp_ipv6_resolve_host(const char *hostname, int port, in
return res;
}
-static int udp_ipv6_set_remote_url(URLContext *h, const char *uri) {
- UDPContext *s = h->priv_data;
- char hostname[256];
- int port;
+static int udp_set_url(struct sockaddr_storage *addr, const char *hostname, int port) {
struct addrinfo *res0;
- url_split(NULL, 0, NULL, 0, hostname, sizeof(hostname), &port, NULL, 0, uri);
+ int addr_len;
+
res0 = udp_ipv6_resolve_host(hostname, port, SOCK_DGRAM, AF_UNSPEC, 0);
if (res0 == 0) return AVERROR(EIO);
- memcpy(&s->dest_addr, res0->ai_addr, res0->ai_addrlen);
- s->dest_addr_len = res0->ai_addrlen;
+ memcpy(addr, res0->ai_addr, res0->ai_addrlen);
+ addr_len = res0->ai_addrlen;
freeaddrinfo(res0);
- return 0;
+
+ return addr_len;
}
static int udp_ipv6_set_local(URLContext *h) {
@@ -213,6 +212,19 @@ static int udp_ipv6_set_local(URLContext *h) {
return -1;
}
+#else
+
+static int udp_set_url(struct sockaddr_in *addr, const char *hostname, int port)
+{
+ /* set the destination address */
+ if (resolve_host(&addr->sin_addr, hostname) < 0)
+ return AVERROR(EIO);
+ addr->sin_family = AF_INET;
+ addr->sin_port = htons(port);
+
+ return sizeof(struct sockaddr_in);
+}
+
#endif /* CONFIG_IPV6 */
@@ -234,9 +246,6 @@ static int udp_ipv6_set_local(URLContext *h) {
*/
int udp_set_remote_url(URLContext *h, const char *uri)
{
-#ifdef CONFIG_IPV6
- return udp_ipv6_set_remote_url(h, uri);
-#else
UDPContext *s = h->priv_data;
char hostname[256];
int port;
@@ -244,13 +253,12 @@ int udp_set_remote_url(URLContext *h, const char *uri)
url_split(NULL, 0, NULL, 0, hostname, sizeof(hostname), &port, NULL, 0, uri);
/* set the destination address */
- if (resolve_host(&s->dest_addr.sin_addr, hostname) < 0)
+ s->dest_addr_len = udp_set_url(&s->dest_addr, hostname, port);
+ if (s->dest_addr_len < 0) {
return AVERROR(EIO);
- s->dest_addr.sin_family = AF_INET;
- s->dest_addr.sin_port = htons(port);
- s->dest_addr_len = sizeof(s->dest_addr);
+ }
+
return 0;
-#endif
}
/**