diff options
| author | Karl DeBisschop <kdebisschop@users.sourceforge.net> | 2004-01-21 12:49:12 +0000 |
|---|---|---|
| committer | Karl DeBisschop <kdebisschop@users.sourceforge.net> | 2004-01-21 12:49:12 +0000 |
| commit | 9b5b447fcae3a1e3dcd5c00734eed34b0dc91857 (patch) | |
| tree | 90b9b352f8a7120886642513932a2f6a72ece35a /plugins | |
| parent | f152e45257451d5b898373db6dfad6ee123199b1 (diff) | |
| download | monitoring-plugins-9b5b447fcae3a1e3dcd5c00734eed34b0dc91857.tar.gz | |
=fix segfault on malloc of server_expect for multibyte chars (David Croft)
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@796 f882894a-f735-0410-b71e-b25c423dba1c
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/check_tcp.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/plugins/check_tcp.c b/plugins/check_tcp.c index c105c6ae..7bd48d1a 100644 --- a/plugins/check_tcp.c +++ b/plugins/check_tcp.c | |||
| @@ -189,9 +189,9 @@ main (int argc, char **argv) | |||
| 189 | SERVICE = strdup ("NNTP"); | 189 | SERVICE = strdup ("NNTP"); |
| 190 | SEND = NULL; | 190 | SEND = NULL; |
| 191 | EXPECT = NULL; | 191 | EXPECT = NULL; |
| 192 | server_expect = realloc (server_expect, ++server_expect_count); | 192 | server_expect = realloc (server_expect, sizeof (char *) * (++server_expect_count)); |
| 193 | asprintf (&server_expect[server_expect_count - 1], "200"); | 193 | asprintf (&server_expect[server_expect_count - 1], "200"); |
| 194 | server_expect = realloc (server_expect, ++server_expect_count); | 194 | server_expect = realloc (server_expect, sizeof (char *) * (++server_expect_count)); |
| 195 | asprintf (&server_expect[server_expect_count - 1], "201"); | 195 | asprintf (&server_expect[server_expect_count - 1], "201"); |
| 196 | asprintf (&QUIT, "QUIT\r\n"); | 196 | asprintf (&QUIT, "QUIT\r\n"); |
| 197 | PROTOCOL = TCP_PROTOCOL; | 197 | PROTOCOL = TCP_PROTOCOL; |
| @@ -212,7 +212,7 @@ main (int argc, char **argv) | |||
| 212 | 212 | ||
| 213 | /* use default expect if none listed in process_arguments() */ | 213 | /* use default expect if none listed in process_arguments() */ |
| 214 | if (EXPECT && server_expect_count == 0) { | 214 | if (EXPECT && server_expect_count == 0) { |
| 215 | server_expect = malloc (++server_expect_count); | 215 | server_expect = malloc (sizeof (char *) * (++server_expect_count)); |
| 216 | server_expect[server_expect_count - 1] = EXPECT; | 216 | server_expect[server_expect_count - 1] = EXPECT; |
| 217 | } | 217 | } |
| 218 | 218 | ||
| @@ -470,9 +470,9 @@ process_arguments (int argc, char **argv) | |||
| 470 | case 'e': /* expect string (may be repeated) */ | 470 | case 'e': /* expect string (may be repeated) */ |
| 471 | EXPECT = NULL; | 471 | EXPECT = NULL; |
| 472 | if (server_expect_count == 0) | 472 | if (server_expect_count == 0) |
| 473 | server_expect = malloc (++server_expect_count); | 473 | server_expect = malloc (sizeof (char *) * (++server_expect_count)); |
| 474 | else | 474 | else |
| 475 | server_expect = realloc (server_expect, ++server_expect_count); | 475 | server_expect = realloc (server_expect, sizeof (char *) * (++server_expect_count)); |
| 476 | server_expect[server_expect_count - 1] = optarg; | 476 | server_expect[server_expect_count - 1] = optarg; |
| 477 | break; | 477 | break; |
| 478 | case 'm': | 478 | case 'm': |
