<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<!DOCTYPE bugzilla SYSTEM "https://bugs.webkit.org/page.cgi?id=bugzilla.dtd">

<bugzilla version="5.0.4.1"
          urlbase="https://bugs.webkit.org/"
          
          maintainer="admin@webkit.org"
>

    <bug>
          <bug_id>126325</bug_id>
          
          <creation_ts>2013-12-30 21:15:24 -0800</creation_ts>
          <short_desc>[GTK] Use libc++ for C++11 on darwin</short_desc>
          <delta_ts>2014-01-06 00:52:57 -0800</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>1</classification_id>
          <classification>Unclassified</classification>
          <product>WebKit</product>
          <component>WebKitGTK</component>
          <version>528+ (Nightly build)</version>
          <rep_platform>Unspecified</rep_platform>
          <op_sys>Unspecified</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          <blocked>126492</blocked>
    
    <blocked>126431</blocked>
          <everconfirmed>1</everconfirmed>
          <reporter name="Jeremy Huddleston Sequoia">jeremyhu</reporter>
          <assigned_to name="Zan Dobersek">zan</assigned_to>
          <cc>cgarcia</cc>
    
    <cc>mcatanzaro</cc>
    
    <cc>zan</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>963448</commentid>
    <comment_count>0</comment_count>
    <who name="Jeremy Huddleston Sequoia">jeremyhu</who>
    <bug_when>2013-12-30 21:15:24 -0800</bug_when>
    <thetext>webkit-gtk tries to use libstdc++ for C++11 even though OS X&apos;s libstdc++ doesn&apos;t support C++11.

What is the point of this?  The comment makes it look intentional.

# Use the C++11 standard. Do not warn about C++11 incompatibilities.
CXXFLAGS=&quot;$CXXFLAGS -pthread -std=c++11 -Wno-c++11-compat&quot;

...

# libstdc++ is at the moment the only option as the C++ standard library when compiling with Clang.
# -Wno-c++11-extensions, currently only usable with Clang, suppresses warnings of C++11 extensions in use.
# Suppress unused arguments warnings for C++ files as well.
if test &quot;$cxx_compiler&quot; = &quot;clang++&quot;; then
   CXXFLAGS=&quot;$CXXFLAGS -stdlib=libstdc++ -Wno-c++11-extensions -Qunused-arguments&quot;
fi

---

/usr/bin/clang++ -DHAVE_CONFIG_H -I. -Wall -W -Wcast-align -Wchar-subscripts -Wreturn-type -Wformat -Wformat-security -Wno-format-y2k -Wundef -Wmissing-format-attribute -Wpointer-arith -Wwrite-strings -Wno-unused-parameter -Wno-parentheses -fno-exceptions -DBUILDING_CAIRO__ -DBUILDING_GTK__ -I./Source -I./Source/WTF -I./Source/WTF/wtf -DGTEST_USE_OWN_TR1_TUPLE=1 -fno-rtti -fstrict-aliasing -O3 -D_REENTRANT -I/opt/local/include/glib-2.0 -I/opt/local/lib/glib-2.0/include -I/opt/local/include -I/opt/local/include -pipe -Os -Wno-c++11-extensions -arch x86_64 -pthread -std=c++11 -Wno-c++11-compat -stdlib=libstdc++ -Wno-c++11-extensions -Qunused-arguments -O2 -MT Source/WTF/wtf/libWTF_la-Compression.lo -MD -MP -MF Source/WTF/wtf/.deps/libWTF_la-Compression.Tpo -c Source/WTF/wtf/Compression.cpp  -fno-common -DPIC -o Source/WTF/wtf/.libs/libWTF_la-Compression.o
In file included from Source/WTF/wtf/Compression.cpp:28:
In file included from ./Source/WTF/wtf/Compression.h:30:
In file included from ./Source/WTF/wtf/Vector.h:31:
In file included from ./Source/WTF/wtf/VectorTraits.h:26:
./Source/WTF/wtf/RefPtr.h:149:27: error: no member named &apos;move&apos; in namespace &apos;std&apos;
       RefPtr ptr = std::move(o);
                    ~~~~~^
./Source/WTF/wtf/RefPtr.h:156:27: error: no member named &apos;move&apos; in namespace &apos;std&apos;
       RefPtr ptr = std::move(o);
                    ~~~~~^
2 errors generated.

$ sudo /usr/bin/clang++ -DHAVE_CONFIG_H -I. -Wall -W -Wcast-align -Wchar-subscripts -Wreturn-type -Wformat -Wformat-security -Wno-format-y2k -Wundef -Wmissing-format-attribute -Wpointer-arith -Wwrite-strings -Wno-unused-parameter -Wno-parentheses -fno-exceptions -DBUILDING_CAIRO__ -DBUILDING_GTK__ -I./Source -I./Source/WTF -I./Source/WTF/wtf -DGTEST_USE_OWN_TR1_TUPLE=1 -fno-rtti -fstrict-aliasing -O3 -D_REENTRANT -I/opt/local/include/glib-2.0 -I/opt/local/lib/glib-2.0/include -I/opt/local/include -I/opt/local/include -pipe -Os -Wno-c++11-extensions -arch x86_64 -pthread -std=c++11 -Wno-c++11-compat -stdlib=libc++ -Wno-c++11-extensions -Qunused-arguments -O2 -MT Source/WTF/wtf/libWTF_la-Compression.lo -MD -MP -MF Source/WTF/wtf/.deps/libWTF_la-Compression.Tpo -c Source/WTF/wtf/Compression.cpp  -fno-common -DPIC -o Source/WTF/wtf/.libs/libWTF_la-Compression.o

---

We&apos;re using libc++ for webkit-gtk-2.2.x in MacPorts without any issues reported.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>963494</commentid>
    <comment_count>1</comment_count>
    <who name="Zan Dobersek">zan</who>
    <bug_when>2013-12-31 01:22:20 -0800</bug_when>
    <thetext>I think we can switch to libc++ on all platforms when compiling with Clang.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>963528</commentid>
    <comment_count>2</comment_count>
    <who name="Michael Catanzaro">mcatanzaro</who>
    <bug_when>2013-12-31 08:38:42 -0800</bug_when>
    <thetext>Some distributions (e.g. Fedora) ship Clang but not libc++.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964161</commentid>
    <comment_count>3</comment_count>
    <who name="Jeremy Huddleston Sequoia">jeremyhu</who>
    <bug_when>2014-01-03 10:28:32 -0800</bug_when>
    <thetext>Related to https://bugs.webkit.org/show_bug.cgi?id=126431</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964476</commentid>
    <comment_count>4</comment_count>
    <who name="Zan Dobersek">zan</who>
    <bug_when>2014-01-05 01:24:07 -0800</bug_when>
    <thetext>I think we could default to libc++ on Darwin and stop passing the -stdlib option to the Clang compiler on other platforms. The option could still be enforced manually through the CXXFLAGS env.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964477</commentid>
    <comment_count>5</comment_count>
      <attachid>220392</attachid>
    <who name="Zan Dobersek">zan</who>
    <bug_when>2014-01-05 01:39:54 -0800</bug_when>
    <thetext>Created attachment 220392
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964491</commentid>
    <comment_count>6</comment_count>
    <who name="Jeremy Huddleston Sequoia">jeremyhu</who>
    <bug_when>2014-01-05 03:03:58 -0800</bug_when>
    <thetext>My one suggestion is that you don&apos;t add -stdlib=libc++ if CXXFLAGS already contains &quot;-stdlib=&quot;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964495</commentid>
    <comment_count>7</comment_count>
      <attachid>220396</attachid>
    <who name="Zan Dobersek">zan</who>
    <bug_when>2014-01-05 05:07:21 -0800</bug_when>
    <thetext>Created attachment 220396
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964503</commentid>
    <comment_count>8</comment_count>
      <attachid>220396</attachid>
    <who name="Martin Robinson">mrobinson</who>
    <bug_when>2014-01-05 09:58:12 -0800</bug_when>
    <thetext>Comment on attachment 220396
Patch

I&apos;m actually a bit surprised we need the standard library.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964570</commentid>
    <comment_count>9</comment_count>
      <attachid>220396</attachid>
    <who name="Zan Dobersek">zan</who>
    <bug_when>2014-01-06 00:52:51 -0800</bug_when>
    <thetext>Comment on attachment 220396
Patch

Clearing flags on attachment: 220396

Committed r161333: &lt;http://trac.webkit.org/changeset/161333&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>964571</commentid>
    <comment_count>10</comment_count>
    <who name="Zan Dobersek">zan</who>
    <bug_when>2014-01-06 00:52:57 -0800</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="1"
              ispatch="1"
              isprivate="0"
          >
            <attachid>220392</attachid>
            <date>2014-01-05 01:39:54 -0800</date>
            <delta_ts>2014-01-05 05:07:16 -0800</delta_ts>
            <desc>Patch</desc>
            <filename>bug-126325-20140105103951.patch</filename>
            <type>text/plain</type>
            <size>1786</size>
            <attacher name="Zan Dobersek">zan</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMTYxMzIwCmRpZmYgLS1naXQgYS9Tb3VyY2UvYXV0b3Rvb2xz
L1NldHVwQ29tcGlsZXJGbGFncy5tNCBiL1NvdXJjZS9hdXRvdG9vbHMvU2V0dXBDb21waWxlckZs
YWdzLm00CmluZGV4IDNhMGRlZThhZjVjYzBmOGJhOTAyNjNlNmVhMDc1MmUzZDQ2Mjk1MGQuLmQ2
NmZiOTcyZTM5ZTk0MjJhYzg1NWQ4ZDA5ZTU3YmFjNWY5NGJkOTUgMTAwNjQ0Ci0tLSBhL1NvdXJj
ZS9hdXRvdG9vbHMvU2V0dXBDb21waWxlckZsYWdzLm00CisrKyBiL1NvdXJjZS9hdXRvdG9vbHMv
U2V0dXBDb21waWxlckZsYWdzLm00CkBAIC04LDEwICs4LDE0IEBAIGlmIHRlc3QgIiRjX2NvbXBp
bGVyIiA9ICJjbGFuZyI7IHRoZW4KICAgICBDRkxBR1M9IiRDRkxBR1MgLVF1bnVzZWQtYXJndW1l
bnRzIgogZmkKIAotIyBsaWJzdGRjKysgaXMgYXQgdGhlIG1vbWVudCB0aGUgb25seSBvcHRpb24g
YXMgdGhlIEMrKyBzdGFuZGFyZCBsaWJyYXJ5IHdoZW4gY29tcGlsaW5nIHdpdGggQ2xhbmcuCiAj
IFN1cHByZXNzIHVudXNlZCBhcmd1bWVudHMgd2FybmluZ3MgZm9yIEMrKyBmaWxlcyBhcyB3ZWxs
LgogaWYgdGVzdCAiJGN4eF9jb21waWxlciIgPSAiY2xhbmcrKyI7IHRoZW4KLSAgICBDWFhGTEFH
Uz0iJENYWEZMQUdTIC1zdGRsaWI9bGlic3RkYysrIC1RdW51c2VkLWFyZ3VtZW50cyIKKyAgICBD
WFhGTEFHUz0iJENYWEZMQUdTIC1RdW51c2VkLWFyZ3VtZW50cyIKKworICAgICMgRGVmYXVsdCB0
byBsaWJjKysgYXMgdGhlIHN0YW5kYXJkIGxpYnJhcnkgb24gRGFyd2luLgorICAgIGlmIHRlc3Qg
IiRvc19kYXJ3aW4iID0gInllcyI7IHRoZW4KKyAgICAgICAgQ1hYRkxBR1M9IiRDWFhGTEFHUyAt
c3RkbGliPWxpYmMrKyIKKyAgICBmaQogZmkKIAogaWYgdGVzdCAiJGhvc3RfY3B1IiA9ICJzaDQi
OyB0aGVuCmRpZmYgLS1naXQgYS9DaGFuZ2VMb2cgYi9DaGFuZ2VMb2cKaW5kZXggOGQ5YmQzMmQ1
Mjc4NGNlMTdkMjAzMWYzYjk4ODNkZWFkMzM4NTAwMC4uNzgxMDM3YTczNWQxMDZmN2VjNGFlZjc1
ZWFjMTYyYWJjYTlhNGMxMiAxMDA2NDQKLS0tIGEvQ2hhbmdlTG9nCisrKyBiL0NoYW5nZUxvZwpA
QCAtMSwzICsxLDE1IEBACisyMDE0LTAxLTA1ICBaYW4gRG9iZXJzZWsgIDx6ZG9iZXJzZWtAaWdh
bGlhLmNvbT4KKworICAgICAgICBbR1RLXSBVc2UgbGliYysrIGZvciBDKysxMSBvbiBkYXJ3aW4K
KyAgICAgICAgaHR0cHM6Ly9idWdzLndlYmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTEyNjMyNQor
CisgICAgICAgIFJldmlld2VkIGJ5IE5PQk9EWSAoT09QUyEpLgorCisgICAgICAgICogU291cmNl
L2F1dG90b29scy9TZXR1cENvbXBpbGVyRmxhZ3MubTQ6IERvbid0IGRlZmF1bHQgdG8gbGlic3Rk
YysrIHdoZW4gY29tcGlsaW5nIHdpdGggQ2xhbmcuCisgICAgICAgIEluc3RlYWQsIHRoZSBjb21w
aWxlciBzaG91bGQgZGV0ZXJtaW5lIGl0c2VsZiB3aGF0IHN0YW5kYXJkIGxpYnJhcnkgdG8gdXNl
LCBleGNlcHQgb24gRGFyd2luLAorICAgICAgICB3aGVyZSBsaWJjKysgc2hvdWxkIGJlIGVuZm9y
Y2VkLiBUaGUgc3RhbmRhcmQgbGlicmFyeSBvZiB1c2VyJ3MgY2hvb3NpbmcgY2FuIHN0aWxsIGJl
IGVuZm9yY2VkCisgICAgICAgIHRocm91Z2ggdGhlIENYWEZMQUdTIGVudmlyb25tZW50IHZhcmlh
YmxlLgorCiAyMDE0LTAxLTA0ICBNYXJ0aW4gUm9iaW5zb24gIDxtcm9iaW5zb25AaWdhbGlhLmNv
bT4KIAogICAgICAgICBbR1RLXSBbQ01ha2VdIEltcHJvdmUgdGhlIHdheSB3ZSBsb2NhdGUgZ29i
amVjdC1pbnRyb3NwZWN0aW9uCg==
</data>

          </attachment>
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>220396</attachid>
            <date>2014-01-05 05:07:21 -0800</date>
            <delta_ts>2014-01-06 00:52:50 -0800</delta_ts>
            <desc>Patch</desc>
            <filename>bug-126325-20140105050720.patch</filename>
            <type>text/plain</type>
            <size>1769</size>
            <attacher name="Zan Dobersek">zan</attacher>
            
              <data encoding="base64">SW5kZXg6IENoYW5nZUxvZwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBDaGFuZ2VMb2cJKHJldmlzaW9uIDE2MTMy
MykKKysrIENoYW5nZUxvZwkod29ya2luZyBjb3B5KQpAQCAtMSwzICsxLDE1IEBACisyMDE0LTAx
LTA1ICBaYW4gRG9iZXJzZWsgIDx6ZG9iZXJzZWtAaWdhbGlhLmNvbT4KKworICAgICAgICBbR1RL
XSBVc2UgbGliYysrIGZvciBDKysxMSBvbiBkYXJ3aW4KKyAgICAgICAgaHR0cHM6Ly9idWdzLndl
YmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTEyNjMyNQorCisgICAgICAgIFJldmlld2VkIGJ5IE5P
Qk9EWSAoT09QUyEpLgorCisgICAgICAgICogU291cmNlL2F1dG90b29scy9TZXR1cENvbXBpbGVy
RmxhZ3MubTQ6IERvbid0IGRlZmF1bHQgdG8gbGlic3RkYysrIHdoZW4gY29tcGlsaW5nIHdpdGgg
Q2xhbmcuCisgICAgICAgIEluc3RlYWQsIHRoZSBjb21waWxlciBzaG91bGQgZGV0ZXJtaW5lIGl0
c2VsZiB3aGF0IHN0YW5kYXJkIGxpYnJhcnkgdG8gdXNlLCBleGNlcHQgb24gRGFyd2luLAorICAg
ICAgICB3aGVyZSBsaWJjKysgc2hvdWxkIGJlIGVuZm9yY2VkLiBUaGUgc3RhbmRhcmQgbGlicmFy
eSBvZiB1c2VyJ3MgY2hvb3NpbmcgY2FuIHN0aWxsIGJlIGVuZm9yY2VkCisgICAgICAgIHRocm91
Z2ggdGhlIENYWEZMQUdTIGVudmlyb25tZW50IHZhcmlhYmxlLgorCiAyMDE0LTAxLTA1ICBDYXJs
b3MgR2FyY2lhIENhbXBvcyAgPGNnYXJjaWFAaWdhbGlhLmNvbT4KIAogICAgICAgICBbR1RLXSBT
dG9wIGluc3RhbGxpbmcgV2ViS2l0MiBDIEFQSSBoZWFkZXJzCkluZGV4OiBTb3VyY2UvYXV0b3Rv
b2xzL1NldHVwQ29tcGlsZXJGbGFncy5tNAo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBTb3VyY2UvYXV0b3Rvb2xz
L1NldHVwQ29tcGlsZXJGbGFncy5tNAkocmV2aXNpb24gMTYxMzIzKQorKysgU291cmNlL2F1dG90
b29scy9TZXR1cENvbXBpbGVyRmxhZ3MubTQJKHdvcmtpbmcgY29weSkKQEAgLTgsMTAgKzgsMTQg
QEAgaWYgdGVzdCAiJGNfY29tcGlsZXIiID0gImNsYW5nIjsgdGhlbgogICAgIENGTEFHUz0iJENG
TEFHUyAtUXVudXNlZC1hcmd1bWVudHMiCiBmaQogCi0jIGxpYnN0ZGMrKyBpcyBhdCB0aGUgbW9t
ZW50IHRoZSBvbmx5IG9wdGlvbiBhcyB0aGUgQysrIHN0YW5kYXJkIGxpYnJhcnkgd2hlbiBjb21w
aWxpbmcgd2l0aCBDbGFuZy4KICMgU3VwcHJlc3MgdW51c2VkIGFyZ3VtZW50cyB3YXJuaW5ncyBm
b3IgQysrIGZpbGVzIGFzIHdlbGwuCiBpZiB0ZXN0ICIkY3h4X2NvbXBpbGVyIiA9ICJjbGFuZysr
IjsgdGhlbgotICAgIENYWEZMQUdTPSIkQ1hYRkxBR1MgLXN0ZGxpYj1saWJzdGRjKysgLVF1bnVz
ZWQtYXJndW1lbnRzIgorICAgIENYWEZMQUdTPSIkQ1hYRkxBR1MgLVF1bnVzZWQtYXJndW1lbnRz
IgorCisgICAgIyBEZWZhdWx0IHRvIGxpYmMrKyBhcyB0aGUgc3RhbmRhcmQgbGlicmFyeSBvbiBE
YXJ3aW4sIGlmIGl0IGlzbid0IGFscmVhZHkgZW5mb3JjZWQgdGhyb3VnaCBDWFhGTEFHUy4KKyAg
ICBpZiB0ZXN0ICIkb3NfZGFyd2luIiA9ICJ5ZXMiOyB0aGVuCisgICAgICAgIEFTX0NBU0UoWyRD
WFhGTEFHU10sIFsqLXN0ZGxpYj0qXSwgW10sIFtDWFhGTEFHUz0iJENYWEZMQUdTIC1zdGRsaWI9
bGliYysrIl0pCisgICAgZmkKIGZpCiAKIGlmIHRlc3QgIiRob3N0X2NwdSIgPSAic2g0IjsgdGhl
bgo=
</data>

          </attachment>
      

    </bug>

</bugzilla>