No empty .Rs/.Re
[netbsd-mini2440.git] / gnu / dist / gettext / gettext-tools / src / open-po.c
blobdf63bb929d6f6bc31d8b4e56210eb4b7d8fcb71a
1 /* open-po - search for .po file along search path list and open for reading
2 Copyright (C) 1995-1996, 2000-2003 Free Software Foundation, Inc.
3 Written by Ulrich Drepper <drepper@gnu.ai.mit.edu>, April 1995.
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2, or (at your option)
8 any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software Foundation,
17 Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
19 #ifdef HAVE_CONFIG_H
20 # include <config.h>
21 #endif
23 /* Specification. */
24 #include "open-po.h"
26 #include <errno.h>
27 #include <stdbool.h>
28 #include <stdio.h>
29 #include <stdlib.h>
30 #include <string.h>
32 #include "dir-list.h"
33 #include "pathname.h"
34 #include "xalloc.h"
35 #include "error.h"
36 #include "gettext.h"
38 #define _(str) gettext (str)
40 /* This macro is used to determine the number of elements in an erray. */
41 #define SIZEOF(a) (sizeof(a)/sizeof(a[0]))
43 static FILE *
44 try_open_po_file (const char *input_name, char **real_file_name_p)
46 static const char *extension[] = { "", ".po", ".pot", };
47 char *file_name;
48 FILE *ret_val;
49 int j;
50 size_t k;
51 const char *dir;
53 if (strcmp (input_name, "-") == 0 || strcmp (input_name, "/dev/stdin") == 0)
55 *real_file_name_p = xstrdup (_("<stdin>"));
56 return stdin;
59 /* We have a real name for the input file. If the name is absolute,
60 try the various extensions, but ignore the directory search list. */
61 if (IS_ABSOLUTE_PATH (input_name))
63 for (k = 0; k < SIZEOF (extension); ++k)
65 file_name = concatenated_pathname ("", input_name, extension[k]);
67 ret_val = fopen (file_name, "r");
68 if (ret_val != NULL || errno != ENOENT)
70 /* We found the file. */
71 *real_file_name_p = file_name;
72 return ret_val;
75 free (file_name);
78 else
80 /* For relative file names, look through the directory search list,
81 trying the various extensions. If no directory search list is
82 specified, the current directory is used. */
83 for (j = 0; (dir = dir_list_nth (j)) != NULL; ++j)
84 for (k = 0; k < SIZEOF (extension); ++k)
86 file_name = concatenated_pathname (dir, input_name, extension[k]);
88 ret_val = fopen (file_name, "r");
89 if (ret_val != NULL || errno != ENOENT)
91 *real_file_name_p = file_name;
92 return ret_val;
95 free (file_name);
99 /* File does not exist. */
100 *real_file_name_p = xstrdup (input_name);
101 errno = ENOENT;
102 return NULL;
105 /* Open the input file with the name INPUT_NAME. The ending .po is added
106 if necessary. If INPUT_NAME is not an absolute file name and the file is
107 not found, the list of directories in "dir-list.h" is searched. The
108 file's pathname is returned in *REAL_FILE_NAME_P, for error message
109 purposes. */
110 FILE *
111 open_po_file (const char *input_name, char **real_file_name_p,
112 bool exit_on_error)
114 FILE *fp = try_open_po_file (input_name, real_file_name_p);
116 if (fp == NULL && exit_on_error)
117 error (EXIT_FAILURE, errno,
118 _("error while opening \"%s\" for reading"), *real_file_name_p);
120 return fp;