summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author/C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org </C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org>2008-01-15 12:59:27 +0000
committer/C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org </C=EU/ST=EU/CN=Pablo Neira Ayuso/emailAddress=pablo@netfilter.org>2008-01-15 12:59:27 +0000
commit4ddee9e2555817bd94521677e808caed665c3393 (patch)
tree307d1ad079b8a9359acd9d0ea0d10ef7bc92fc74
parentf66ce57358db77bdc50b055325ac103f7c38d5fa (diff)
downloadconntrack-tools-4ddee9e2555817bd94521677e808caed665c3393.tar.gz
conntrack-tools-4ddee9e2555817bd94521677e808caed665c3393.zip
Max Kellermann <max@duempel.org>:
yacc generates a function with a return value, and the conntrackd code uses "return;" to ignore a value. this is not legal. convert all of these to "break;" which might be what the author intended to do.
-rw-r--r--ChangeLog1
-rw-r--r--src/read_config_yy.y18
2 files changed, 10 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index 97ac77e..8da214c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -49,6 +49,7 @@ o enable gcc warnings, including -Werror
o use list_for_each_entry() instead of list_for_each()
o use const when possible
o remove prefetch in slist.h since it confuses gcc
+o fix illegal use of return in the yacc code, use break instead
version 0.9.5 (2007/07/29)
------------------------------
diff --git a/src/read_config_yy.y b/src/read_config_yy.y
index bbc5115..be484fe 100644
--- a/src/read_config_yy.y
+++ b/src/read_config_yy.y
@@ -121,7 +121,7 @@ syslog_facility : T_SYSLOG T_STRING
else {
fprintf(stderr, "'%s' is not a known syslog facility, "
"ignoring.\n", $2);
- return;
+ break;
}
if (conf.stats.syslog_facility != -1 &&
@@ -187,7 +187,7 @@ ignore_traffic_option : T_IPV4_ADDR T_IP
if (!family) {
fprintf(stderr, "%s is not a valid IP, ignoring", $2);
- return;
+ break;
}
if (!STATE(ignore_pool)) {
@@ -216,14 +216,14 @@ multicast_option : T_IPV4_ADDR T_IP
{
if (!inet_aton($2, &conf.mcast.in)) {
fprintf(stderr, "%s is not a valid IPv4 address\n");
- return;
+ break;
}
if (conf.mcast.ipproto == AF_INET6) {
fprintf(stderr, "Your multicast address is IPv4 but "
"is binded to an IPv6 interface? Surely "
"this is not what you want\n");
- return;
+ break;
}
conf.mcast.ipproto = AF_INET;
@@ -240,7 +240,7 @@ multicast_option : T_IPV6_ADDR T_IP
fprintf(stderr, "Your multicast address is IPv6 but "
"is binded to an IPv4 interface? Surely "
"this is not what you want\n");
- return;
+ break;
}
conf.mcast.ipproto = AF_INET6;
@@ -250,14 +250,14 @@ multicast_option : T_IPV4_IFACE T_IP
{
if (!inet_aton($2, &conf.mcast.ifa)) {
fprintf(stderr, "%s is not a valid IPv4 address\n");
- return;
+ break;
}
if (conf.mcast.ipproto == AF_INET6) {
fprintf(stderr, "Your multicast interface is IPv4 but "
"is binded to an IPv6 interface? Surely "
"this is not what you want\n");
- return;
+ break;
}
conf.mcast.ipproto = AF_INET;
@@ -274,7 +274,7 @@ multicast_option : T_IPV6_IFACE T_IP
fprintf(stderr, "Your multicast interface is IPv6 but "
"is binded to an IPv4 interface? Surely "
"this is not what you want\n");
- return;
+ break;
}
conf.mcast.ipproto = AF_INET6;
@@ -630,7 +630,7 @@ stat_syslog_facility : T_SYSLOG T_STRING
else {
fprintf(stderr, "'%s' is not a known syslog facility, "
"ignoring.\n", $2);
- return;
+ break;
}
if (conf.syslog_facility != -1 &&