summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhendersonHDF <jhenderson@hdfgroup.org>2023-04-13 16:14:00 (GMT)
committerGitHub <noreply@github.com>2023-04-13 16:14:00 (GMT)
commit8d9e964b644fc13dd223b1e115ad8c79fc84d840 (patch)
tree77995d56a691563f79d2960bf7f58d77c349a8fd
parente9604656ebbd969c84f17efc2236ddfbbbc9473c (diff)
downloadhdf5-8d9e964b644fc13dd223b1e115ad8c79fc84d840.zip
hdf5-8d9e964b644fc13dd223b1e115ad8c79fc84d840.tar.gz
hdf5-8d9e964b644fc13dd223b1e115ad8c79fc84d840.tar.bz2
Avoid suppressing error output for non-tentative file opens (#2632) (#2670)
* Avoid suppressing error output for non-tentative file opens * Update comment about tentative file opens
-rw-r--r--src/H5Fint.c52
1 files changed, 41 insertions, 11 deletions
diff --git a/src/H5Fint.c b/src/H5Fint.c
index 7ad35fc..ee35bdd 100644
--- a/src/H5Fint.c
+++ b/src/H5Fint.c
@@ -1798,22 +1798,52 @@ H5F_open(const char *name, unsigned flags, hid_t fcpl_id, hid_t fapl_id)
else
tent_flags = flags;
- H5E_BEGIN_TRY
- {
- lf = H5FD_open(name, tent_flags, fapl_id, HADDR_UNDEF);
+ /*
+ * When performing a tentative open of a file where we have stripped away
+ * flags such as H5F_ACC_CREAT from the specified file access flags, the
+ * H5E_BEGIN/END_TRY macros are used to suppress error output since there
+ * is an expectation that the tentative open might fail. Even though we
+ * explicitly clear the error stack after such a failure, the underlying
+ * file driver might maintain its own error stack and choose whether to
+ * display errors based on whether the library has disabled error reporting.
+ * Since we wish to suppress that error output as well for the case of
+ * tentative file opens, surrounding the file open call with the
+ * H5E_BEGIN/END_TRY macros is an explicit instruction to the file driver
+ * not to display errors. If the tentative file open call fails, another
+ * attempt at opening the file will be made without error output being
+ * suppressed.
+ *
+ * However, if stripping away the H5F_ACC_CREAT flag and others left us
+ * with the same file access flags as before, then we will skip this
+ * tentative file open and only make a single attempt at opening the file.
+ * In this case, we don't want to suppress error output since the underlying
+ * file driver might provide more details on why the file open failed.
+ */
+ if (tent_flags != flags) {
+ /* Make tentative attempt to open file */
+ H5E_BEGIN_TRY
+ {
+ lf = H5FD_open(name, tent_flags, fapl_id, HADDR_UNDEF);
+ }
+ H5E_END_TRY;
}
- H5E_END_TRY;
- if (NULL == lf) {
- if (tent_flags == flags)
- HGOTO_ERROR(H5E_FILE, H5E_CANTOPENFILE, NULL, "unable to open file: name = '%s', tent_flags = %x",
- name, tent_flags)
- H5E_clear_stack(NULL);
- tent_flags = flags;
+ /*
+ * If a tentative attempt to open the file wasn't necessary, attempt
+ * to open the file now. Otherwise, if the tentative open failed, clear
+ * the error stack and reset the file access flags, then make another
+ * attempt at opening the file.
+ */
+ if ((tent_flags == flags) || (lf == NULL)) {
+ if (tent_flags != flags) {
+ H5E_clear_stack(NULL);
+ tent_flags = flags;
+ }
+
if (NULL == (lf = H5FD_open(name, tent_flags, fapl_id, HADDR_UNDEF)))
HGOTO_ERROR(H5E_FILE, H5E_CANTOPENFILE, NULL, "unable to open file: name = '%s', tent_flags = %x",
name, tent_flags)
- } /* end if */
+ }
/* Is the file already open? */
if ((shared = H5F__sfile_search(lf)) != NULL) {