You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@trafficserver.apache.org by "James Peach (JIRA)" <ji...@apache.org> on 2013/05/03 05:58:16 UTC

[jira] [Assigned] (TS-1680) build system (and code) have inconsistent checking for C++11 (library) features

     [ https://issues.apache.org/jira/browse/TS-1680?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

James Peach reassigned TS-1680:
-------------------------------

    Assignee: James Peach
    
> build system (and code) have inconsistent checking for C++11 (library) features
> -------------------------------------------------------------------------------
>
>                 Key: TS-1680
>                 URL: https://issues.apache.org/jira/browse/TS-1680
>             Project: Traffic Server
>          Issue Type: Bug
>          Components: Build
>            Reporter: Igor Galić
>            Assignee: James Peach
>             Fix For: 3.3.3
>
>
> Compilers on different Operating systems can use different standard libraries. Just knowing the compilers name and version, or the OS isn't enough.
> This is beautifully examplified by our C++11 code in {{proxy/logstats.cc}}. Despite the 30~ lines of code to do various checks this still doesn't work with all combinations of compilers:
> {noformat}
> c++ -DHAVE_CONFIG_H -I. -I/home/igalic/src/asf/trafficserver/proxy -I../lib/ts  -I/home/igalic/src/asf/trafficserver/iocore/eventsystem -I/home/igalic/src/asf/trafficserver/iocore/net -I/home/igalic/src/asf/trafficserver/iocore/aio -I/home/igalic/src/asf/trafficserver/iocore/hostdb -I/home/igalic/src/asf/trafficserver/iocore/cache -I/home/igalic/src/asf/trafficserver/iocore/cluster -I/home/igalic/src/asf/trafficserver/iocore/utils -I/home/igalic/src/asf/trafficserver/iocore/dns -I/home/igalic/src/asf/trafficserver/lib/records -I/home/igalic/src/asf/trafficserver/lib/ts -I/home/igalic/src/asf/trafficserver/proxy/http -I/home/igalic/src/asf/trafficserver/proxy/logging -I/home/igalic/src/asf/trafficserver/proxy/http/remap -I/home/igalic/src/asf/trafficserver/proxy/hdrs -I/home/igalic/src/asf/trafficserver/mgmt -I/home/igalic/src/asf/trafficserver/mgmt/preparse -I/home/igalic/src/asf/trafficserver/mgmt/utils -I/home/igalic/src/asf/trafficserver/proxy/api/ts -I. -I./api/ts -I/home/igalic/src/asf/trafficserver/lib -D_LARGEFILE64_SOURCE=1 -D_COMPILE64BIT_SOURCE=1 -D_GNU_SOURCE -D_REENTRANT -Dfreebsd -DDEBUG -D_DEBUG -I/usr/local/include -I/usr/local/include/tcl8.5  -std=c++11 -ggdb3 -pipe -Wall -Werror -Wno-invalid-offsetof -MT logstats.o -MD -MP -MF .deps/logstats.Tpo -c -o logstats.o /home/igalic/src/asf/trafficserver/proxy/logstats.cc
> /home/igalic/src/asf/trafficserver/proxy/logstats.cc:79:12: error: no member named 'hash' in namespace 'std'
> using std::hash;
>       ~~~~~^
> /home/igalic/src/asf/trafficserver/proxy/logstats.cc:364:48: error: no template named 'hash'; did you mean '__gnu_cxx::hash'?
> typedef hash_map <const char *, OriginStats *, hash <const char *>, eqstr> OriginStorage;
>                                                ^~~~
>                                                __gnu_cxx::hash
> /usr/include/c++/4.2/ext/hash_fun.h:71:12: note: '__gnu_cxx::hash' declared here
>     struct hash { };
>            ^
> /home/igalic/src/asf/trafficserver/proxy/logstats.cc:365:33: error: no template named 'hash'; did you mean '__gnu_cxx::hash'?
> typedef hash_set <const char *, hash <const char *>, eqstr> OriginSet;
>                                 ^~~~
>                                 __gnu_cxx::hash
> /usr/include/c++/4.2/ext/hash_fun.h:71:12: note: '__gnu_cxx::hash' declared here
>     struct hash { };
>            ^
> /home/igalic/src/asf/trafficserver/proxy/logstats.cc:374:54: error: no template named 'hash'; did you mean '__gnu_cxx::hash'?
>   typedef hash_map<const char *, LruStack::iterator, hash <const char *>, eqstr> LruHash;
>                                                      ^~~~
>                                                      __gnu_cxx::hash
> /usr/include/c++/4.2/ext/hash_fun.h:71:12: note: '__gnu_cxx::hash' declared here
>     struct hash { };
>            ^
> 4 errors generated.
> gmake: *** [logstats.o] Error 1
> {noformat}
> vs:
> {noformat}
> clang++ -DHAVE_CONFIG_H -I. -I/home/igalic/src/asf/trafficserver/proxy -I../lib/ts  -I/home/igalic/src/asf/trafficserver/iocore/eventsystem -I/home/igalic/src/asf/trafficserver/iocore/net -I/home/igalic/src/asf/trafficserver/iocore/aio -I/home/igalic/src/asf/trafficserver/iocore/hostdb -I/home/igalic/src/asf/trafficserver/iocore/cache -I/home/igalic/src/asf/trafficserver/iocore/cluster -I/home/igalic/src/asf/trafficserver/iocore/utils -I/home/igalic/src/asf/trafficserver/iocore/dns -I/home/igalic/src/asf/trafficserver/lib/records -I/home/igalic/src/asf/trafficserver/lib/ts -I/home/igalic/src/asf/trafficserver/proxy/http -I/home/igalic/src/asf/trafficserver/proxy/logging -I/home/igalic/src/asf/trafficserver/proxy/http/remap -I/home/igalic/src/asf/trafficserver/proxy/hdrs -I/home/igalic/src/asf/trafficserver/mgmt -I/home/igalic/src/asf/trafficserver/mgmt/preparse -I/home/igalic/src/asf/trafficserver/mgmt/utils -I/home/igalic/src/asf/trafficserver/proxy/api/ts -I. -I./api/ts -I/home/igalic/src/asf/trafficserver/lib -D_LARGEFILE64_SOURCE=1 -D_COMPILE64BIT_SOURCE=1 -D_GNU_SOURCE -D_REENTRANT -Dfreebsd -DDEBUG -D_DEBUG -I/usr/local/include -I/usr/local/include/tcl8.5  --stdlib=libc++ -std=c++11 -ggdb3 -pipe -Wall -Werror -Qunused-arguments -Wno-invalid-offsetof -MT logstats.o -MD -MP -MF .deps/logstats.Tpo -c -o logstats.o /home/igalic/src/asf/trafficserver/proxy/logstats.cc
> In file included from /home/igalic/src/asf/trafficserver/proxy/logstats.cc:58:
> /usr/include/c++/v1/ext/hash_map:209:2: error: Use of the header <ext/hash_map> is deprecated. Migrate to <unordered_map> [-Werror,-W#warnings]
> #warning Use of the header <ext/hash_map> is deprecated.  Migrate to <unordered_map>
>  ^
> In file included from /home/igalic/src/asf/trafficserver/proxy/logstats.cc:59:
> /usr/include/c++/v1/ext/hash_set:202:2: error: Use of the header <ext/hash_set> is deprecated. Migrate to <unordered_set> [-Werror,-W#warnings]
> #warning Use of the header <ext/hash_set> is deprecated.  Migrate to <unordered_set>
>  ^
> 2 errors generated.
> gmake: *** [logstats.o] Error 1
> {noformat}
> (With --stdlib=libc++)
> An other example can be found in {{libc++11api}} itself (This error is produced by running {{ci/regression}} on FreeBSD 10):
> {noformat}
> gmake[2]: Leaving directory `/tmp/org.apache.trafficserver.17293/obj/lib/wccp'
> Making all in cpp11api
> gmake[2]: Entering directory `/tmp/org.apache.trafficserver.17293/obj/lib/cpp11api'
>   CXX      cpp11api.lo
> In file included from /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:24:
> /home/igalic/src/asf/trafficserver/lib/cpp11api/ts-cpp11.h:56:14: error: no type named 'function' in namespace 'std'
> typedef std::function<NextState(Transaction &)> GlobalHookCallback;
>         ~~~~~^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/ts-cpp11.h:56:22: error: expected unqualified-id
> typedef std::function<NextState(Transaction &)> GlobalHookCallback;
>                      ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/ts-cpp11.h:61:33: error: unknown type name 'GlobalHookCallback'
> void CreateGlobalHook(HookType, GlobalHookCallback);
>                                 ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/ts-cpp11.h:62:53: error: unknown type name 'GlobalHookCallback'
> void CreateTransactionHook(Transaction &, HookType, GlobalHookCallback);
>                                                     ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:33:3: error: unknown type name 'GlobalHookCallback'
>   GlobalHookCallback callback;
>   ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:115:36: error: member access into incomplete type 'const struct sockaddr_in'
>   inet_ntop(AF_INET, &s_sockaddr_in->sin_addr, res, INET_ADDRSTRLEN);
>                                    ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:111:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * s_sockaddr_in =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:432:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:74:37: note: expanded from macro '__bswap16'
>         ((__uint16_t)(__builtin_constant_p(x) ? \
>                                            ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:428:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:432:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:75:33: note: expanded from macro '__bswap16'
>             __bswap16_gen((__uint16_t)(x)) : __bswap16_var(x)))
>                                        ^
> /usr/include/x86/endian.h:66:40: note: expanded from macro '__bswap16_gen'
> #define __bswap16_gen(x)        (__uint16_t)((x) << 8 | (x) >> 8)
>                                               ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:428:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:432:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:75:33: note: expanded from macro '__bswap16'
>             __bswap16_gen((__uint16_t)(x)) : __bswap16_var(x)))
>                                        ^
> /usr/include/x86/endian.h:66:51: note: expanded from macro '__bswap16_gen'
> #define __bswap16_gen(x)        (__uint16_t)((x) << 8 | (x) >> 8)
>                                                          ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:428:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:432:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:75:53: note: expanded from macro '__bswap16'
>             __bswap16_gen((__uint16_t)(x)) : __bswap16_var(x)))
>                                                            ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:428:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:444:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:74:37: note: expanded from macro '__bswap16'
>         ((__uint16_t)(__builtin_constant_p(x) ? \
>                                            ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:440:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:444:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:75:33: note: expanded from macro '__bswap16'
>             __bswap16_gen((__uint16_t)(x)) : __bswap16_var(x)))
>                                        ^
> /usr/include/x86/endian.h:66:40: note: expanded from macro '__bswap16_gen'
> #define __bswap16_gen(x)        (__uint16_t)((x) << 8 | (x) >> 8)
>                                               ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:440:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:444:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:75:33: note: expanded from macro '__bswap16'
>             __bswap16_gen((__uint16_t)(x)) : __bswap16_var(x)))
>                                        ^
> /usr/include/x86/endian.h:66:51: note: expanded from macro '__bswap16_gen'
> #define __bswap16_gen(x)        (__uint16_t)((x) << 8 | (x) >> 8)
>                                                          ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:440:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:444:57: error: member access into incomplete type 'const struct sockaddr_in'
>   return static_cast<unsigned int>(ntohs(client_sockaddr->sin_port));
>                                                         ^
> /usr/include/arpa/inet.h:173:26: note: expanded from macro 'ntohs'
> #define ntohs(x)        __ntohs(x)
>                                 ^
> /usr/include/x86/endian.h:129:30: note: expanded from macro '__ntohs'
> #define __ntohs(x)      __bswap16(x)
>                                   ^
> /usr/include/x86/endian.h:75:53: note: expanded from macro '__bswap16'
>             __bswap16_gen((__uint16_t)(x)) : __bswap16_var(x)))
>                                                            ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:440:16: note: forward declaration of 'sockaddr_in'
>   const struct sockaddr_in * client_sockaddr =
>                ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:527:5: error: unknown type name 'GlobalHookCallback'
>     GlobalHookCallback callback) {
>     ^
> /home/igalic/src/asf/trafficserver/lib/cpp11api/cpp11api.cc:544:48: error: unknown type name 'GlobalHookCallback'
> void ats::api::CreateGlobalHook(HookType hook, GlobalHookCallback callback) {
>                                                ^
> 16 errors generated.
> gmake[2]: *** [cpp11api.lo] Error 1
> gmake[2]: Leaving directory `/tmp/org.apache.trafficserver.17293/obj/lib/cpp11api'
> gmake[1]: *** [all-recursive] Error 1
> gmake[1]: Leaving directory `/tmp/org.apache.trafficserver.17293/obj/lib'
> gmake: *** [all-recursive] Error 1
> {noformat}
> One simple way to check for {{libc++}} is demonstrated here:
> {noformat}
> #include <ciso646>
> #if defined( _LIBCPP_VERSION )
> using std::hash;
> #else
> #include <tr1/unordered_map>
> using std::tr1::hash;
> #endif
> {noformat}

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira