More thorough error checking on library calls.
authorPeter Verthez <Peter.Verthez@advalvas.be>
Sun, 8 Sep 2002 19:12:17 +0000 (19:12 +0000)
committerPeter Verthez <Peter.Verthez@advalvas.be>
Sun, 8 Sep 2002 19:12:17 +0000 (19:12 +0000)
Function to generate memory error.

gedcom/message.c

index 68a7c852e3f6dc3980f91920d8e4ff9ca084d659..23d5c867a41abce99758334432e6997fabc77d30 100644 (file)
@@ -45,32 +45,39 @@ void init_mess_buffer()
 {
   if (mess_buffer == NULL) {
     mess_buffer = (char *)malloc(INITIAL_BUF_SIZE);
-    mess_buffer[0] = '\0';
-    bufsize = INITIAL_BUF_SIZE;
+    if (mess_buffer) {
+      mess_buffer[0] = '\0';
+      bufsize = INITIAL_BUF_SIZE;
+    }
+    else
+      fprintf(stderr, _("Could not allocate memory at %s, %d\n"),
+             __FILE__, __LINE__);
   }
 }
 
 int safe_buf_vappend(char *s, va_list ap)
 {
-  int res;
+  int res = 0;
   int len;
   init_mess_buffer();
-  len = strlen(mess_buffer);
-  while (1) {
-    char *buf_ptr = mess_buffer + len;
-    int rest_size = bufsize - len;
-    
-    res = vsnprintf(buf_ptr, rest_size, s, ap);
-    
-    if (res > -1 && res < rest_size) {
-      break;
-    }
-    else  {
-      bufsize *= 2;
-      mess_buffer = realloc(mess_buffer, bufsize);
+  if (mess_buffer) {
+    len = strlen(mess_buffer);
+    while (1) {
+      char *buf_ptr = mess_buffer + len;
+      int rest_size = bufsize - len;
+      
+      res = vsnprintf(buf_ptr, rest_size, s, ap);
+      
+      if (res > -1 && res < rest_size) {
+       break;
+      }
+      else  {
+       bufsize *= 2;
+       mess_buffer = realloc(mess_buffer, bufsize);
+      }
     }
   }
-  return res;  
+  return res;
 }
 
 int safe_buf_append(char *s, ...)
@@ -130,3 +137,8 @@ int gedcom_error(char* s, ...)
   
   return res;
 }
+
+void gedcom_mem_error(char *filename, int line)
+{
+  gedcom_error(_("Could not allocate memory at %s, %d"), filename, line);
+}