Fix ERROR message in injection_point.c
authorMichael Paquier <michael@paquier.xyz>
Tue, 23 Jan 2024 01:45:00 +0000 (10:45 +0900)
committerMichael Paquier <michael@paquier.xyz>
Tue, 23 Jan 2024 01:45:00 +0000 (10:45 +0900)
This commit fixes an error message that failed to show the correct
function and library names when a function cannot be loaded.

While on it, adjust the call to load_external_function() so as this
ERROR can be reached, by making load_external_function() return NULL
rather than fail if a function cannot be found for a given injection
point.

Thinkos in d86d20f0ba79.

src/backend/utils/misc/injection_point.c

index 4f52f198533639c3e14a78006465fae86a6c9d90..0cf4d51cac48cb03e966d8a1de7f70c75d86aa0e 100644 (file)
@@ -300,11 +300,11 @@ InjectionPointRun(const char *name)
                 path, name);
 
        injection_callback = (InjectionPointCallback)
-           load_external_function(path, entry_by_name->function, true, NULL);
+           load_external_function(path, entry_by_name->function, false, NULL);
 
        if (injection_callback == NULL)
            elog(ERROR, "could not find function \"%s\" in library \"%s\" for injection point \"%s\"",
-                name, entry_by_name->function, path);
+                entry_by_name->function, path, name);
 
        /* add it to the local cache when found */
        injection_point_cache_add(name, injection_callback);