apps/nshlib: truncate command will now use ftruncate (vs. truncate) if it had to create the file with creat().

This commit is contained in:
Gregory Nutt 2018-01-10 07:24:24 -06:00
parent 8ecf618a4d
commit 99512b90db

View File

@ -1834,26 +1834,44 @@ int cmd_truncate(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
{
nsh_output(vtbl, g_fmtcmdfailed, argv[0], "stat", NSH_ERRNO);
ret = ERROR;
goto errout_with_fullpath;
}
else
{
/* We successfully performed the create and now have a zero-
* length file. Perform the truncation to extend the allocation
* (unless we really wanted a zero-length file).
*/
ret = OK;
if (length > 0)
{
/* Extend the file to length */
ret = ftruncate(fd, length);
if (ret < 0)
{
nsh_output(vtbl, g_fmtcmdfailed, argv[0], "ftruncate",
NSH_ERRNO);
}
}
close(fd);
}
}
else
{
nsh_output(vtbl, g_fmtcmdfailed, argv[0], "stat",
NSH_ERRNO_OF(errval));
ret = ERROR;
goto errout_with_fullpath;
}
}
else if (!S_ISREG(buf.st_mode))
{
nsh_output(vtbl, g_fmtarginvalid, argv[0]);
ret = ERROR;
goto errout_with_fullpath;
}
else
{
/* Everything looks good... perform the truncation */
ret = truncate(fullpath, length);
@ -1861,8 +1879,8 @@ int cmd_truncate(FAR struct nsh_vtbl_s *vtbl, int argc, char **argv)
{
nsh_output(vtbl, g_fmtcmdfailed, argv[0], "truncate", NSH_ERRNO);
}
}
errout_with_fullpath:
nsh_freefullpath(fullpath);
return ret;
}