Index: apps/app_voicemail.c =================================================================== RCS file: /usr/cvsroot/asterisk/apps/app_voicemail.c,v retrieving revision 1.198 diff -u -r1.198 app_voicemail.c --- apps/app_voicemail.c 25 Jan 2005 06:10:19 -0000 1.198 +++ apps/app_voicemail.c 15 Feb 2005 23:08:22 -0000 @@ -743,23 +743,17 @@ goto yuck; } if (!strcmp(coltitle, "recording")) { + char *np = 0; + res = SQLGetData(stmt, x + 1, SQL_BINARY, np, 0, &colsize); fdlen = colsize; fd = open(full_fn, O_RDWR | O_TRUNC | O_CREAT, 0770); if (fd > -1) { - /* Ugh, gotta fill it so we can mmap */ - char tmp[1024]=""; - size_t left = 0, bytes = 0; - left = fdlen; - while(left) { - bytes = left; - if (bytes > sizeof(tmp)) - bytes = sizeof(tmp); - if (write(fd, tmp, bytes) != bytes) { - close(fd); - fd = -1; - break; - } - left -= bytes; + char tmp[1]=""; + size_t bytes = 1; + lseek(fd, fdlen, SEEK_SET); + if (write(fd, tmp, bytes) != bytes) { + close(fd); + fd = -1; } if (fd > -1) fdm = mmap(NULL, fdlen, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); @@ -772,8 +766,6 @@ SQLFreeHandle (SQL_HANDLE_STMT, stmt); goto yuck; } - fdlen = colsize; - ftruncate(fd, fdlen); } } else { res = SQLGetData(stmt, x + 1, SQL_CHAR, rowdata, sizeof(rowdata), NULL);