* lib/tempname.h: Specify extern "C" linkage with C++. (try_tempname): Rename `try' to `tryfunc'. * lib/tempname.c (__try_tempname, __gen_tempname): Rename `try' to `tryfunc' for consistency. --- ChangeLog | 8 ++++++++ lib/tempname.c | 14 +++++++------- lib/tempname.h | 14 +++++++++++--- 3 files changed, 26 insertions(+), 10 deletions(-)
diff --git a/ChangeLog b/ChangeLog index 5083e95..aa17a64 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2015-02-17 Mike Miller <mtmil...@ieee.org> + + tempname: allow compilation with C++ + * lib/tempname.h: Specify extern "C" linkage with C++. + (try_tempname): Rename `try' to `tryfunc'. + * lib/tempname.c (__try_tempname, __gen_tempname): Rename `try' to + `tryfunc' for consistency. + 2015-02-16 Paul Eggert <egg...@cs.ucla.edu> getdtablesize, dup2, fcntl: port to Android diff --git a/lib/tempname.c b/lib/tempname.c index 49c7df1..8e6d26c 100644 --- a/lib/tempname.c +++ b/lib/tempname.c @@ -179,7 +179,7 @@ static const char letters[] = int __try_tempname (char *tmpl, int suffixlen, void *args, - int (*try) (char *, void *)) + int (*tryfunc) (char *, void *)) { int len; char *XXXXXX; @@ -244,7 +244,7 @@ __try_tempname (char *tmpl, int suffixlen, void *args, v /= 62; XXXXXX[5] = letters[v % 62]; - fd = try (tmpl, args); + fd = tryfunc (tmpl, args); if (fd >= 0) { __set_errno (save_errno); @@ -300,25 +300,25 @@ try_nocreate (char *tmpl, void *flags) int __gen_tempname (char *tmpl, int suffixlen, int flags, int kind) { - int (*try) (char *, void *); + int (*tryfunc) (char *, void *); switch (kind) { case __GT_FILE: - try = try_file; + tryfunc = try_file; break; case __GT_DIR: - try = try_dir; + tryfunc = try_dir; break; case __GT_NOCREATE: - try = try_nocreate; + tryfunc = try_nocreate; break; default: assert (! "invalid KIND in __gen_tempname"); abort (); } - return __try_tempname (tmpl, suffixlen, &flags, try); + return __try_tempname (tmpl, suffixlen, &flags, tryfunc); } diff --git a/lib/tempname.h b/lib/tempname.h index 0df4381..e609360 100644 --- a/lib/tempname.h +++ b/lib/tempname.h @@ -32,6 +32,10 @@ # define GT_NOCREATE 2 # endif +#ifdef __cplusplus +extern "C" { +#endif + /* Generate a temporary file name based on TMPL. TMPL must match the rules for mk[s]temp (i.e. end in "XXXXXX", possibly with a suffix). The name constructed does not exist at the time of the call to @@ -47,11 +51,15 @@ We use a clever algorithm to get hard-to-predict names. */ extern int gen_tempname (char *tmpl, int suffixlen, int flags, int kind); -/* Similar to gen_tempname, but TRY is called for each temporary - name to try. If TRY returns a non-negative number, TRY_GEN_TEMPNAME +/* Similar to gen_tempname, but TRYFUNC is called for each temporary + name to try. If TRYFUNC returns a non-negative number, TRY_GEN_TEMPNAME returns with this value. Otherwise, if errno is set to EEXIST, another name is tried, or else TRY_GEN_TEMPNAME returns -1. */ extern int try_tempname (char *tmpl, int suffixlen, void *args, - int (*try) (char *, void *)); + int (*tryfunc) (char *, void *)); + +#ifdef __cplusplus +} +#endif #endif /* GL_TEMPNAME_H */ -- 2.1.4