diff options
Diffstat (limited to 'src/doc.c')
| -rw-r--r-- | src/doc.c | 24 | 
1 files changed, 14 insertions, 10 deletions
| diff --git a/src/doc.c b/src/doc.c index 83e943c42b8..9fbeb0b5ed5 100644 --- a/src/doc.c +++ b/src/doc.c @@ -86,9 +86,11 @@ get_doc_string (Lisp_Object filepos, int unibyte, int definition)    register int fd;    register char *name;    register char *p, *p1; -  EMACS_INT minsize; -  EMACS_INT offset, position; +  ptrdiff_t minsize; +  int offset; +  EMACS_INT position;    Lisp_Object file, tem; +  USE_SAFE_ALLOCA;    if (INTEGERP (filepos))      { @@ -122,7 +124,7 @@ get_doc_string (Lisp_Object filepos, int unibyte, int definition)        /* sizeof ("../etc/") == 8 */        if (minsize < 8)  	minsize = 8; -      name = (char *) alloca (minsize + SCHARS (file) + 8); +      SAFE_ALLOCA (name, char *, minsize + SCHARS (file) + 8);        strcpy (name, SSDATA (Vdoc_directory));        strcat (name, SSDATA (file));      } @@ -153,13 +155,16 @@ get_doc_string (Lisp_Object filepos, int unibyte, int definition)    /* Make sure we read at least 1024 bytes before `position'       so we can check the leading text for consistency.  */    offset = min (position, max (1024, position % (8 * 1024))); -  if (0 > lseek (fd, position - offset, 0)) +  if (TYPE_MAXIMUM (off_t) < position +      || lseek (fd, position - offset, 0) < 0)      {        emacs_close (fd);        error ("Position %"pI"d out of range in doc string file \"%s\"",  	     position, name);      } +  SAFE_FREE (); +    /* Read the doc string into get_doc_string_buffer.       P points beyond the data just read.  */ @@ -277,7 +282,7 @@ Invalid data in documentation file -- %c followed by code %03o",    else      {        /* The data determines whether the string is multibyte.  */ -      EMACS_INT nchars = +      ptrdiff_t nchars =  	multibyte_chars_in_text (((unsigned char *) get_doc_string_buffer  				  + offset),  				 to - (get_doc_string_buffer + offset)); @@ -500,8 +505,7 @@ aren't strings.  */)  /* Scanning the DOC files and placing docstring offsets into functions.  */  static void -store_function_docstring (Lisp_Object fun, EMACS_INT offset) -/* Use EMACS_INT because we get offset from pointer subtraction.  */ +store_function_docstring (Lisp_Object fun, ptrdiff_t offset)  {    fun = indirect_function (fun); @@ -556,7 +560,7 @@ the same file name is found in the `doc-directory'.  */)  {    int fd;    char buf[1024 + 1]; -  register EMACS_INT filled; +  register int filled;    register EMACS_INT pos;    register char *p;    Lisp_Object sym; @@ -591,7 +595,7 @@ the same file name is found in the `doc-directory'.  */)      for (beg = buildobj; *beg; beg = end)        { -        EMACS_INT len; +        ptrdiff_t len;          while (*beg && isspace (*beg)) ++beg; @@ -639,7 +643,7 @@ the same file name is found in the `doc-directory'.  */)                if (end - p > 4 && end[-2] == '.'                    && (end[-1] == 'o' || end[-1] == 'c'))                  { -                  EMACS_INT len = end - p - 2; +                  ptrdiff_t len = end - p - 2;                    char *fromfile = alloca (len + 1);                    strncpy (fromfile, &p[2], len);                    fromfile[len] = 0; | 
