aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authortilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2010-07-20 16:54:20 +0000
committertilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b>2010-07-20 16:54:20 +0000
commit92a6af8e056b973b391d10da3706dfa8e935024c (patch)
tree867d21b85bc2ff2382e553bdf861b79aab6cb9e9
parent217c56898ca7b7a1f41dba61a1e7e26004aafc51 (diff)
Merged revisions 278024 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk ................ r278024 | tilghman | 2010-07-20 11:50:11 -0500 (Tue, 20 Jul 2010) | 14 lines Merged revisions 278023 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r278023 | tilghman | 2010-07-20 11:37:18 -0500 (Tue, 20 Jul 2010) | 7 lines Off-by-one error (closes issue #16506) Reported by: nik600 Patches: 20100629__issue16506.diff.txt uploaded by tilghman (license 14) ........ ................ git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.2@278025 f38db490-d61c-443f-a65b-d21fe96a405b
-rw-r--r--main/manager.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/main/manager.c b/main/manager.c
index a5b1b1938..d13672653 100644
--- a/main/manager.c
+++ b/main/manager.c
@@ -3983,17 +3983,18 @@ static struct ast_str *generic_http_callback(enum output_format format,
if (s.f != NULL) { /* have temporary output */
char *buf;
size_t l;
-
- /* Ensure buffer is NULL-terminated */
- fprintf(s.f, "%c", 0);
if ((l = ftell(s.f))) {
- if ((buf = mmap(NULL, l, PROT_READ | PROT_WRITE, MAP_SHARED, s.fd, 0))) {
- if (format == FORMAT_XML || format == FORMAT_HTML)
+ if (MAP_FAILED == (buf = mmap(NULL, l + 1, PROT_READ | PROT_WRITE, MAP_PRIVATE, s.fd, 0))) {
+ ast_log(LOG_WARNING, "mmap failed. Manager output was not processed\n");
+ } else {
+ buf[l] = '\0';
+ if (format == FORMAT_XML || format == FORMAT_HTML) {
xml_translate(&out, buf, params, format);
- else
+ } else {
ast_str_append(&out, 0, "%s", buf);
- munmap(buf, l);
+ }
+ munmap(buf, l + 1);
}
} else if (format == FORMAT_XML || format == FORMAT_HTML) {
xml_translate(&out, "", params, format);