]> granicus.if.org Git - postgresql/commitdiff
Add pg_string_endswith as the start of a string helper library in src/common.
authorAndres Freund <andres@anarazel.de>
Sat, 3 Jan 2015 19:51:52 +0000 (20:51 +0100)
committerAndres Freund <andres@anarazel.de>
Sat, 3 Jan 2015 19:54:13 +0000 (20:54 +0100)
Backpatch to 9.3 where src/common was introduce, because a bugfix that
needs to be backpatched, requires the function. Earlier branches will
have to duplicate the code.

src/backend/replication/slot.c
src/common/Makefile
src/common/string.c [new file with mode: 0644]
src/include/common/string.h [new file with mode: 0644]
src/tools/msvc/Mkvcbuild.pm

index 29191ffb951d306a98b086b15e54d1bd2b98e298..7b5e0a89bfb3ba468505d6577edd3055af2e099d 100644 (file)
@@ -40,6 +40,7 @@
 #include <sys/stat.h>
 
 #include "access/transam.h"
+#include "common/string.h"
 #include "miscadmin.h"
 #include "replication/slot.h"
 #include "storage/fd.h"
@@ -779,24 +780,6 @@ CheckSlotRequirements(void)
                                 errmsg("replication slots can only be used if wal_level >= archive")));
 }
 
-/*
- * Returns whether the string `str' has the postfix `end'.
- */
-static bool
-string_endswith(const char *str, const char *end)
-{
-       size_t          slen = strlen(str);
-       size_t          elen = strlen(end);
-
-       /* can't be a postfix if longer */
-       if (elen > slen)
-               return false;
-
-       /* compare the end of the strings */
-       str += slen - elen;
-       return strcmp(str, end) == 0;
-}
-
 /*
  * Flush all replication slots to disk.
  *
@@ -864,7 +847,7 @@ StartupReplicationSlots(void)
                        continue;
 
                /* we crashed while a slot was being setup or deleted, clean up */
-               if (string_endswith(replication_de->d_name, ".tmp"))
+               if (pg_str_endswith(replication_de->d_name, ".tmp"))
                {
                        if (!rmtree(path, true))
                        {
index 7edbaaa2c1a707f59cbf6b9c137838c201f28cb8..e5c345d7def312fbb99a3115785a62ebe112803b 100644 (file)
@@ -23,7 +23,7 @@ include $(top_builddir)/src/Makefile.global
 override CPPFLAGS := -DFRONTEND $(CPPFLAGS)
 LIBS += $(PTHREAD_LIBS)
 
-OBJS_COMMON = exec.o pgfnames.o psprintf.o relpath.o rmtree.o username.o wait_error.o
+OBJS_COMMON = exec.o pgfnames.o psprintf.o relpath.o rmtree.o string.o username.o wait_error.o
 
 OBJS_FRONTEND = $(OBJS_COMMON) fe_memutils.o
 
diff --git a/src/common/string.c b/src/common/string.c
new file mode 100644 (file)
index 0000000..27e0743
--- /dev/null
@@ -0,0 +1,43 @@
+/*-------------------------------------------------------------------------
+ *
+ * string.c
+ *             string handling helpers
+ *
+ *
+ * Portions Copyright (c) 1996-2015, PostgreSQL Global Development Group
+ * Portions Copyright (c) 1994, Regents of the University of California
+ *
+ *
+ * IDENTIFICATION
+ *       src/common/string.c
+ *
+ *-------------------------------------------------------------------------
+ */
+
+
+#ifndef FRONTEND
+#include "postgres.h"
+#else
+#include "postgres_fe.h"
+#endif
+
+#include "common/string.h"
+
+
+/*
+ * Returns whether the string `str' has the postfix `end'.
+ */
+bool
+pg_str_endswith(const char *str, const char *end)
+{
+       size_t          slen = strlen(str);
+       size_t          elen = strlen(end);
+
+       /* can't be a postfix if longer */
+       if (elen > slen)
+               return false;
+
+       /* compare the end of the strings */
+       str += slen - elen;
+       return strcmp(str, end) == 0;
+}
diff --git a/src/include/common/string.h b/src/include/common/string.h
new file mode 100644 (file)
index 0000000..0233858
--- /dev/null
@@ -0,0 +1,15 @@
+/*
+ *     string.h
+ *             string handling helpers
+ *
+ *  Portions Copyright (c) 1996-2015, PostgreSQL Global Development Group
+ *  Portions Copyright (c) 1994, Regents of the University of California
+ *
+ *     src/include/common/string.h
+ */
+#ifndef COMMON_STRING_H
+#define COMMON_STRING_H
+
+extern bool pg_str_endswith(const char *str, const char *end);
+
+#endif   /* COMMON_STRING_H */
index 0532a90b7c0b9191f714cd3f86ce3475ed804e01..ca0876868d02c82065790224d727a54d550efa19 100644 (file)
@@ -76,7 +76,7 @@ sub mkvcbuild
        push(@pgportfiles, 'rint.c') if ($vsVersion < '12.00');
 
        our @pgcommonallfiles = qw(
-         exec.c pgfnames.c psprintf.c relpath.c rmtree.c username.c wait_error.c);
+         exec.c pgfnames.c psprintf.c relpath.c rmtree.c string.c username.c wait_error.c);
 
        our @pgcommonfrontendfiles = (@pgcommonallfiles, qw(fe_memutils.c));