Rely on system prototypes if we #define our os funcs.
authorPhil Pennock <pdp@exim.org>
Sat, 26 Mar 2011 04:32:44 +0000 (00:32 -0400)
committerPhil Pennock <pdp@exim.org>
Sat, 26 Mar 2011 04:32:44 +0000 (00:32 -0400)
The const-ness updates broke systems where `os_strsignal()` gets mapped
to `strsignal()`, which does *not* return `const char *` but `char *`.

If we #define away, then there should be a prototype from the system
headers.

src/src/osfunctions.h

index 19b5808607023f77b20ac0234e78baf1893273a6..14111d383b68e3cad8ca336cbd4360a10f3eae2a 100644 (file)
@@ -14,10 +14,25 @@ that uses a type that isn't defined for them. */
 extern ip_address_item *os_common_find_running_interfaces(void);
 #endif
 
+/* If these exist as a macro, then they're overriden away from us and we
+rely upon the system headers to provide prototype declarations for us.
+Notably, strsignal() is not in the Single Unix Specification (v3) and
+predicting constness is awkward. */
+
+#ifndef os_getloadavg
 extern int           os_getloadavg(void);
+#endif
+#ifndef os_restarting_signal
 extern void          os_restarting_signal(int, void (*)(int));
+#endif
+#ifndef os_non_restarting_signal
 extern void          os_non_restarting_signal(int, void (*)(int));
+#endif
+#ifndef os_strexit
 extern const char   *os_strexit(int);     /* char to match os_strsignal */
+#endif
+#ifndef os_strsignal
 extern const char   *os_strsignal(int);   /* char to match strsignal in some OS */
+#endif
 
 /* End of osfunctions.h */