Make the use of gedcom_init mandatory.
authorPeter Verthez <Peter.Verthez@advalvas.be>
Wed, 27 Mar 2002 20:06:46 +0000 (20:06 +0000)
committerPeter Verthez <Peter.Verthez@advalvas.be>
Wed, 27 Mar 2002 20:06:46 +0000 (20:06 +0000)
gedcom/multilex.c

index 727c17959cb8f7aa03a6c9040ecf415e91d0cedf..96af2952b714d022462e171c199b6b58b170d0bf 100644 (file)
@@ -105,8 +105,11 @@ int determine_encoding(FILE* f)
   }
 }
 
+static int init_called = 0;
+
 void gedcom_init()
 {
+  init_called = 1;
   update_gconv_search_path();
 }
 
@@ -123,24 +126,29 @@ int gedcom_parse_file(char* file_name)
   bind_textdomain_codeset(PACKAGE, INTERNAL_ENCODING);
   textdomain(PACKAGE);
 
-  line_no = 1;
-  file = fopen(file_name, "r");
-  if (!file) {
-    gedcom_error(_("Could not open file '%s'"), file_name);
+  if (!init_called) {
+    gedcom_error(_("Internal error: GEDCOM parser not initialized"));
   }
   else {
-    init_encodings();
-    enc = determine_encoding(file);
-    
-    if (lexer_init(enc, file)) {
-      line_no = 1;
-      make_xref_table();
-      result = gedcom_parse();
-      if (result == 0)
-       result = check_xref_table();
+    line_no = 1;
+    file = fopen(file_name, "r");
+    if (!file) {
+      gedcom_error(_("Could not open file '%s'"), file_name);
+    }
+    else {
+      init_encodings();
+      enc = determine_encoding(file);
+      
+      if (lexer_init(enc, file)) {
+       line_no = 1;
+       make_xref_table();
+       result = gedcom_parse();
+       if (result == 0)
+         result = check_xref_table();
+      }
+      lexer_close();
+      fclose(file);
     }
-    lexer_close();
-    fclose(file);
   }
 
   textdomain(save_textdom);