From 6d0e38332157bad2ad3c3667cd80c214e47fb83a Mon Sep 17 00:00:00 2001 From: Tilghman Lesher Date: Thu, 30 Sep 2010 20:40:08 +0000 Subject: Merged revisions 289543,289581 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.8 ........ r289543 | tilghman | 2010-09-30 12:50:52 -0500 (Thu, 30 Sep 2010) | 2 lines More Solaris compatibility fixes ........ r289581 | tilghman | 2010-09-30 15:23:10 -0500 (Thu, 30 Sep 2010) | 2 lines Solaris fixes. ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@289588 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- funcs/func_env.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'funcs/func_env.c') diff --git a/funcs/func_env.c b/funcs/func_env.c index 6a3642a44..736095290 100644 --- a/funcs/func_env.c +++ b/funcs/func_env.c @@ -788,7 +788,7 @@ static int file_write(struct ast_channel *chan, const char *cmd, char *data, con fseeko(ff, offset, SEEK_SET); ast_debug(3, "offset=%s/%" PRId64 ", length=%s/%" PRId64 ", vlength=%" PRId64 ", flength=%" PRId64 "\n", - args.offset, offset, args.length, length, vlength, flength); + S_OR(args.offset, "(null)"), offset, S_OR(args.length, "(null)"), length, vlength, flength); if (length == vlength) { /* Simplest case, a straight replace */ @@ -821,6 +821,11 @@ static int file_write(struct ast_channel *chan, const char *cmd, char *data, con if (fwrite(fbuf, 1, sizeof(fbuf), ff) < sizeof(fbuf)) { ast_log(LOG_ERROR, "Short write?!!\n"); } + /* Seek to where we stopped reading */ + if (fseeko(ff, cur + sizeof(fbuf), SEEK_SET) < 0) { + /* Only reason for seek to fail is EOF */ + break; + } } fclose(ff); if (truncate(args.filename, flength - (length - vlength))) { -- cgit v1.2.3