From 93d8f3a3504c1e92333524aa6aeca169c103166a Mon Sep 17 00:00:00 2001 From: Even Rouault Date: Tue, 18 Dec 2018 20:58:28 +0100 Subject: cpp conversion: fix One-Definition-Rule violations Defining struct pj_opaque with different definitions is a violation of the C++ One-Definition-Rule. When using link-time optimizations, this could break badly. The solution adopted here is to wrap those structures into a C++ anonymous namespace so they are considered different --- src/PJ_goode.cpp | 2 ++ 1 file changed, 2 insertions(+) (limited to 'src/PJ_goode.cpp') diff --git a/src/PJ_goode.cpp b/src/PJ_goode.cpp index 3f5a4f8c..14c78439 100644 --- a/src/PJ_goode.cpp +++ b/src/PJ_goode.cpp @@ -13,10 +13,12 @@ PROJ_HEAD(goode, "Goode Homolosine") "\n\tPCyl, Sph"; C_NAMESPACE PJ *pj_sinu(PJ *), *pj_moll(PJ *); +namespace { // anonymous namespace struct pj_opaque { PJ *sinu; PJ *moll; }; +} // anonymous namespace static XY s_forward (LP lp, PJ *P) { /* Spheroidal, forward */ -- cgit v1.2.3