X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Ffileblocks.c;h=4024d1ef24ff1b690e242862e37720141fe79918;hb=c5ce79f4c514b37b5756e85530112d778cff302a;hp=0cfebb5413c6015be421e5a1867676e8cd0fef28;hpb=6d8337bfc808cddc275899c03482eceb6aff8547;p=gnulib.git diff --git a/lib/fileblocks.c b/lib/fileblocks.c index 0cfebb541..4024d1ef2 100644 --- a/lib/fileblocks.c +++ b/lib/fileblocks.c @@ -1,5 +1,7 @@ /* Convert file size to number of blocks on System V-like machines. - Copyright (C) 1990 Free Software Foundation, Inc. + + Copyright (C) 1990, 1997, 1998, 1999, 2004, 2005, 2006 Free Software + Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -13,27 +15,31 @@ You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, - Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ /* Written by Brian L. Matthews, blm@6sceng.UUCP. */ - -#ifdef HAVE_CONFIG_H -# include -#endif -#if !defined (HAVE_ST_BLOCKS) && !defined(_POSIX_VERSION) -# include +#include + +#include + +#if HAVE_SYS_PARAM_H # include +#endif + +#if !HAVE_STRUCT_STAT_ST_BLOCKS && !defined _POSIX_SOURCE && defined BSIZE + +# include # ifndef NINDIR -/* Some SysV's, like Irix, seem to lack these. Hope they're correct. */ -/* Size of a indirect block, in bytes. */ -# ifndef BSIZE -# define BSIZE 1024 + +# if defined __DJGPP__ +typedef long daddr_t; /* for disk address */ # endif +/* Some SysV's, like Irix, seem to lack this. Hope it's correct. */ /* Number of inode pointers per indirect block. */ -# define NINDIR (BSIZE/sizeof(daddr_t)) +# define NINDIR (BSIZE / sizeof (daddr_t)) # endif /* !NINDIR */ /* Number of direct block addresses in an inode. */ @@ -41,12 +47,11 @@ /* Return the number of 512-byte blocks in a file of SIZE bytes. */ -long -st_blocks (size) - long size; +off_t +st_blocks (off_t size) { - long datablks = (size + 512 - 1) / 512; - long indrblks = 0; + off_t datablks = size / 512 + (size % 512 != 0); + off_t indrblks = 0; if (datablks > NDIR) { @@ -66,5 +71,5 @@ st_blocks (size) #else /* This declaration is solely to ensure that after preprocessing this file is never empty. */ -extern int textutils_fileblocks_unused; +typedef int textutils_fileblocks_unused; #endif