View Issue Details [ Jump to Notes ] | [ Print ] | ||||||||
ID | Project | Category | View Status | Date Submitted | Last Update | ||||
0013251 | CMake | CMake | public | 2012-05-27 07:37 | 2014-10-06 10:32 | ||||
Reporter | sigma | ||||||||
Assigned To | Brad King | ||||||||
Priority | normal | Severity | major | Reproducibility | always | ||||
Status | closed | Resolution | fixed | ||||||
Platform | x64 | OS | Windows | OS Version | 7 | ||||
Product Version | CMake 2.8.8 | ||||||||
Target Version | CMake 3.0 | Fixed in Version | CMake 3.0 | ||||||
Summary | 0013251: cmake -E tar <file> fails to extract some files correctly | ||||||||
Description | On certain tar.gz files cmake fails to extract them properly. I suspect this has to do with tar.gz files that have unix symlinks and are extracted on windows. One such file can be obtained from: http://openssl.org/source/openssl-1.0.1c.tar.gz [^] When I try: cmake -E tar xf openssl-1.0.1c.tar.gz it fails on some files: CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:openssl-1.0.1c/apps/md4.c CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:openssl-1.0.1c/include/openssl/aes.h CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:openssl-1.0.1c/include/openssl/asn1.h CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:openssl-1.0.1c/include/openssl/asn1_mac.h CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:openssl-1.0.1c/include/openssl/asn1t.h CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:openssl-1.0.1c/include/openssl/bio.h CMake Error: Problem with archive_write_header(): Can't create '\' Using other extraction tools, e.g. cygwin or 7zip, this works without any problems. | ||||||||
Tags | No tags attached. | ||||||||
Attached Files | cmake-tar-test.tar.gz [^] (51,092 bytes) 2012-05-27 10:48 0001-cmSystemTools-Re-order-extract_tar-logic.patch [^] (2,707 bytes) 2013-07-03 09:25 [Show Content] 0002-cmake-Avoid-E-tar-failure-to-extract-symlinks-Window.patch [^] (1,263 bytes) 2013-07-03 09:25 [Show Content] | ||||||||
Relationships | ||||||||||||||||||||||||||
|
Relationships |
Notes | |
(0029571) Eric NOULARD (developer) 2012-05-27 07:56 |
I can extract this archive with CMake 2.8.8 on Linux (Debian Squeeze) without trouble... |
(0029572) Eric NOULARD (developer) 2012-05-27 07:58 |
You are right those files are symlinks. How do other tools like 7-zip handles those symlink on Windows? Do they create plain files which are a copy of the symlink target? Do they handle symlink in some way? |
(0029573) sigma (reporter) 2012-05-27 10:48 |
I created a test tar.gz with various file types to see what happens. Compress it on a linux box with tar (GNU tar) 1.26: tar -cpvzf cmake-tar-test.tar.gz cmake-tar-test/ The archive contains: cmake-tar-test/: total 12 drwxr-xr-x 2 root root 4096 May 27 16:44 bin drwxr-xr-x 2 root root 4096 May 27 17:23 links drwxr-xr-x 2 root root 4096 May 27 16:44 src cmake-tar-test/bin: total 100 -rwxr--r-- 1 root root 99328 May 27 16:43 main.exe cmake-tar-test/links: total 0 lrwxrwxrwx 1 root root 6 May 27 16:46 dir-link -> ../src lrwxrwxrwx 1 root root 15 May 27 16:45 main.cpp -> ../src/main.cpp lrwxrwxrwx 1 root root 15 May 27 16:45 main.exe -> ../bin/main.exe lrwxrwxrwx 1 root root 13 May 27 16:45 main.h -> ../src/main.h cmake-tar-test/src: total 8 -rwxr--r-- 1 root root 127 May 27 16:42 main.cpp -rwxr--r-- 1 root root 19 May 27 16:42 main.h So there is a mixture of symlinks to various filetypes and directories. main.exe was compiled on win7 and is a valid executable. I moved the files back to the Win7 machine to see how the different programs (7-zip, cygwin, cmake) behave. cmake log is here: ---------------------------------------------------------------------------------------- cmake -E tar xvfz cmake-tar-test.tar.gz x cmake-tar-test/ x cmake-tar-test/links/ x cmake-tar-test/links/main.cppCMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:cmake-tar-test/links/main.cpp x cmake-tar-test/links/main.exeCMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:cmake-tar-test/links/main.exe x cmake-tar-test/links/main.hCMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:cmake-tar-test/links/main.h x cmake-tar-test/links/dir-linkCMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:cmake-tar-test/links/dir-link x cmake-tar-test/src/ x cmake-tar-test/src/main.cpp x cmake-tar-test/src/main.h x cmake-tar-test/bin/ x cmake-tar-test/bin/main.exe ---------------------------------------------------------------------------------------- Here is what each program does: original | 7zip ---------------------------------------------------------------------------------------- links/main.cpp | just contains the text ../src/main.cpp (NOT the contents of) links/main.exe | just contains the text ../bin/main.exe (NOT the contents of) links/main.h | just contains the text ../src/main.h (NOT the contents of) links/dir-link | just contains the text ../src ---------------------------------------------------------------------------------------- original | cygwin ---------------------------------------------------------------------------------------- links/main.cpp | binary - contains "!<symlink>ÿþ....." (most likely a posix link?) links/main.exe | binary - contains "!<symlink>ÿþ....." links/main.h | binary - contains "!<symlink>ÿþ....." links/dir-link | binary - contains "!<symlink>ÿþ....." ---------------------------------------------------------------------------------------- original | cmake ---------------------------------------------------------------------------------------- links/main.cpp | link missing links/main.exe | link missing links/main.h | link missing links/dir-link | link missing ---------------------------------------------------------------------------------------- I think there is no simple answer, since the output of all is typically not useful. I didn't look closely, but the openssl package does compile and test fine both if extracted with cygwin and 7zip, but it doesn't work with cmake, because it doesn't extract the links at all. |
(0029577) Brad King (manager) 2012-05-28 09:49 |
Possibly related upstream libarchive issue: http://code.google.com/p/libarchive/issues/detail?id=259 [^] |
(0029578) Brad King (manager) 2012-05-28 09:51 |
A quick experiment tells me that GNU tar on Windows (MinGW/MSYS) extracts a copy of the content from the linked file, at least if the symlink points to another entry in the tarball. In my understanding the "symlink" generated by GNU tar under Cygwin is just a file that Cygwin's runtime library recognizes and treats as a symlink for the purposes of its POSIX emulation. |
(0029592) sigma (reporter) 2012-05-31 18:47 |
Actually, just copying the contents of the pointed file would most likely enable source packages to function properly most of the times afterwards, at the expense of space. It is better than failing, like it does now. Right now, I use ExternalProject to download and build openssl on windows as a dependency for another project, this fails of course, as EP uses the internal tar by default. I haven't done it yet, but I remember there is a way to specify the command to use to extract it, so one can skip the internal tar. I need to look into it, but it would be greatly appreciated if you could make it copy the files. |
(0029593) sigma (reporter) 2012-05-31 20:55 |
I spend some time debugging cmake and it seems this is purely because of the failure of libarchive to handle symlinks. |
(0029594) Eric NOULARD (developer) 2012-06-01 02:56 edited on: 2012-06-01 02:57 |
Hi, Have a look at bug 0010162 you'll find that libarchive *is* handling symlinks but only on supported platforms and/or archive format. See the libarchive isssue reference pointed by Brad as well. In fact we do some tuning/verification when creating archive with libarchive see cmArchiveWrite.[h|cxx] but we do minimal error checking when extracting see cmSystemTools.cxx A) We could (theoretically) check, when extracting, whether if the entry is a symlink and we are on Windows platform, in order to create a plain file out of the symlink found in libarchive. This could be seen as workaround of the inability of libarchive to do it but it could be done. B) Another option would be to error out when symlink is found in archive when extracting on Windows. C) Or put some work in order to make this fixed upstream. I personnally think B) is not satisfactory, so that we should do A) and possibly suppress it when C) is ready. My 2 cents, I won't have time to work on this anyway. |
(0030431) David Cole (manager) 2012-08-11 21:42 |
Sending old, never assigned issues to the backlog. (The age of the bug, plus the fact that it's never been assigned to anyone means that nobody is actively working on it...) If an issue you care about is sent to the backlog when you feel it should have been addressed in a different manner, please bring it up on the CMake mailing list for discussion. Sign up for the mailing list here, if you're not already on it: http://www.cmake.org/mailman/listinfo/cmake [^] It's easy to re-activate a bug here if you can find a CMake developer who has the bandwidth to take it on, and ferry a fix through to our 'next' branch for dashboard testing. |
(0031848) Kevin Burge (reporter) 2012-12-07 09:15 |
I am seeing this same problem with the same package (openssl) with 2.8.10.2. I agree that making the extract copy of the file is better than failing. My options are: extract and repackage the gz with these links either removed altogether or manually replaced with the original file. It seems that 2.8.10.2 is even worse than 2.8.8. At least it allowed you to continue building. Now it fails and stops. Please address this. |
(0032172) frank watson song (reporter) 2013-01-29 06:52 |
I met the same problem when I use ExternalProject_Add work with openssl on windows platform. I use the blew script to build openssl automaticly on windows platform: ExternalProject_Add(openssl URL http://www.openssl.org/source/openssl-1.0.1c.tar.gz [^] URL_MD5 ae412727c8c15b67880aef7bd2999b2e DOWNLOAD_DIR ${CMAKE_CURRENT_SOURCE_DIR} BUILD_IN_SOURCE 1 CONFIGURE_COMMAND perl Configure VC-WIN32 no-asm --prefix=${CMAKE_INSTALL_PREFIX} & ms\\do_ms & "${VCVARSALL_BATCH}" BUILD_COMMAND "${NMAKE_EXECUTABLE}" -f ms\\ntdll.mak INSTALL_COMMAND "${NMAKE_EXECUTABLE}" -f ms\\ntdll.mak install ) And I met the logs: 2> Creating directories for 'openssl' 2> Performing download step (verify and extract) for 'openssl' 2> -- verifying file... 2> file='I:/gotest/arkWorkspace/thirdparty/project/openssl/openssl-1.0.1c.tar.gz' 2> -- verifying file... done 2> -- extracting... 2> src='I:/gotest/arkWorkspace/thirdparty/project/openssl/openssl-1.0.1c.tar.gz' 2> dst='I:/gotest/arkWorkspace/thirdparty/MSVC-17.0.50727.1-build/openssl/openssl-prefix/src/openssl' 2> -- extracting... [tar xfz] 2>CUSTOMBUILD : CMake error : Problem with archive_write_header(): Can't create '\' 2>CUSTOMBUILD : CMake error : Current file:openssl-1.0.1c/apps/md4.c 2>CUSTOMBUILD : CMake error : Problem extracting tar: I:/gotest/arkWorkspace/thirdparty/project/openssl/openssl-1.0.1c.tar.gz 2> -- extracting... [error clean up] 2> CMake Error at openssl-stamp/extract-openssl.cmake:33 (message): 2>CUSTOMBUILD : error : extract of 2> 'I:/gotest/arkWorkspace/thirdparty/project/openssl/openssl-1.0.1c.tar.gz' 2> failed I hope this bug can be fixed, it can appear easyly. I use cmake command line tool to decompression openssl package met the same problem. |
(0033092) Mitmischer (reporter) 2013-05-17 14:59 |
I can confirm this bug with the NMake-generator. ExternalProject_Add( SFML PREFIX ${TMPDIR} URL http://github.com/LaurentGomila/SFML/archive/2.0.tar.gz [^] CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=${SFML_INSTALL_PREFIX}) `nmake SFML` fails like this: Scanning dependencies of target SFML [ 2%] Creating directories for 'SFML' [ 4%] Performing download step (download, verify and extract) for 'SFML' -- downloading... src='http://github.com/LaurentGomila/SFML/archive/2.0.tar.gz' [^] dst='C:/Windows/Temp/src/2.0.tar.gz' timeout='none' -- [download 0% complete] -- [download 100% complete] -- [download 0% complete] -- [download 2% complete] -- [download 5% complete] -- [download 11% complete] -- [download 17% complete] -- [download 23% complete] -- [download 30% complete] -- [download 39% complete] -- [download 50% complete] -- [download 64% complete] -- [download 79% complete] -- [download 90% complete] -- [download 100% complete] -- downloading... done -- verifying file... file='C:/Windows/Temp/src/2.0.tar.gz' -- verifying file... warning: did not verify file - no URL_HASH specified? -- extracting... src='C:/Windows/Temp/src/2.0.tar.gz' dst='C:/Windows/Temp/src/SFML' -- extracting... [tar xfz] CMake Error: Problem with archive_write_header(): Can't create '\' CMake Error: Current file:SFML-2.0/extlibs/libs-osx/Frameworks/freetype.framewor k/Resources CMake Error: Problem extracting tar: C:/Windows/Temp/src/2.0.tar.gz -- extracting... [error clean up] CMake Error at SFML-stamp/extract-SFML.cmake:33 (message): error: extract of 'C:/Windows/Temp/src/2.0.tar.gz' failed NMAKE : fatal error U1077: "echo": Rückgabe-Code "0x1" Stop. NMAKE : fatal error U1077: ""C:\Program Files (x86)\Microsoft Visual Studio 11.0 \VC\BIN\nmake.exe"": Rückgabe-Code "0x2" Stop. NMAKE : fatal error U1077: ""C:\Program Files (x86)\Microsoft Visual Studio 11.0 \VC\BIN\nmake.exe"": Rückgabe-Code "0x2" Stop. NMAKE : fatal error U1077: ""C:\Program Files (x86)\Microsoft Visual Studio 11.0 \VC\BIN\nmake.exe"": Rückgabe-Code "0x2" Stop. |
(0033459) Pau Garcia i Quiles (reporter) 2013-07-03 06:08 |
Is this going to be fixed any time soon? It's been over a year with this issue and it's breaking ExternalProject badly :-( |
(0033460) Brad King (manager) 2013-07-03 08:07 |
Re 0013251:0033459: AFAIK the status is as follows: * No one is actively working on this issue. * The work around is to publish one's own openssl tarball with the symlinks replaced as desired. * It has been raised in libarchive upstream: http://code.google.com/p/libarchive/issues/detail?id=259 [^] * Upstream libarchive developers raised concerns about defining semantics for both creating and extracting archives with symlinks on Windows * No one has investigated whether it is possible to handle such archive entries in client code rather than libarchive itself IMO cross-platform source tarballs should not be released with symbolic links in them because any tool extracting them on Windows can at best guess what semantics the source tree wants (copy, text link, NTFS symlink requiring admin privileges, etc.). |
(0033461) Pau Garcia i Quiles (reporter) 2013-07-03 08:22 |
Brad, My workaround for now is downloading OpenSSL from GitHub: https://github.com/openssl/openssl/archive/OpenSSL_1_0_1e.zip [^] but this is far from optimal. Granted, cross-platform source tarballs should not be released with symbolic links. But a solution is needed and that solution is not going to be telling every project out there to not tarball with symlinks. IMHO 7-zip's is good enough: it works with no privileges. |
(0033464) Brad King (manager) 2013-07-03 09:26 |
Try attached patches 0001-cmSystemTools-Re-order-extract_tar-logic.patch 0002-cmake-Avoid-E-tar-failure-to-extract-symlinks-Window.patch on top of 2.8.11. |
(0034326) Brad King (manager) 2013-11-02 10:52 |
Re 0013251:0033464: Well I didn't get any feedback from the patches but they work for me so I've applied them: cmSystemTools: Re-order extract_tar logic http://cmake.org/gitweb?p=cmake.git;a=commitdiff;h=0d8552c4 [^] cmake: Avoid '-E tar' failure to extract symlinks on Windows http://cmake.org/gitweb?p=cmake.git;a=commitdiff;h=4c383b52 [^] |
(0036941) Robert Maynard (manager) 2014-10-06 10:32 |
Closing resolved issues that have not been updated in more than 4 months. |
Notes |
Issue History | |||
Date Modified | Username | Field | Change |
2012-05-27 07:37 | sigma | New Issue | |
2012-05-27 07:52 | Eric NOULARD | Relationship added | related to 0011766 |
2012-05-27 07:52 | Eric NOULARD | Relationship added | related to 0011176 |
2012-05-27 07:52 | Eric NOULARD | Relationship deleted | related to 0011766 |
2012-05-27 07:53 | Eric NOULARD | Relationship added | parent of 0011766 |
2012-05-27 07:56 | Eric NOULARD | Note Added: 0029571 | |
2012-05-27 07:58 | Eric NOULARD | Note Added: 0029572 | |
2012-05-27 10:48 | sigma | File Added: cmake-tar-test.tar.gz | |
2012-05-27 10:48 | sigma | Note Added: 0029573 | |
2012-05-28 09:49 | Brad King | Note Added: 0029577 | |
2012-05-28 09:51 | Brad King | Note Added: 0029578 | |
2012-05-31 18:47 | sigma | Note Added: 0029592 | |
2012-05-31 20:55 | sigma | Note Added: 0029593 | |
2012-06-01 02:39 | Eric NOULARD | Relationship added | related to 0010162 |
2012-06-01 02:56 | Eric NOULARD | Note Added: 0029594 | |
2012-06-01 02:57 | Eric NOULARD | Note Edited: 0029594 | |
2012-08-11 21:42 | David Cole | Status | new => backlog |
2012-08-11 21:42 | David Cole | Note Added: 0030431 | |
2012-12-07 09:15 | Kevin Burge | Note Added: 0031848 | |
2012-12-07 11:11 | David Cole | Assigned To | => David Cole |
2012-12-07 11:11 | David Cole | Status | backlog => assigned |
2012-12-07 11:12 | David Cole | Assigned To | David Cole => |
2012-12-07 11:12 | David Cole | Status | assigned => new |
2012-12-07 11:13 | David Cole | Target Version | => CMake 2.8.11 |
2013-01-29 06:52 | frank watson song | Note Added: 0032172 | |
2013-05-17 09:33 | Robert Maynard | Target Version | CMake 2.8.11 => CMake 2.8.12 |
2013-05-17 14:59 | Mitmischer | Note Added: 0033092 | |
2013-07-03 06:08 | Pau Garcia i Quiles | Note Added: 0033459 | |
2013-07-03 08:07 | Brad King | Note Added: 0033460 | |
2013-07-03 08:22 | Pau Garcia i Quiles | Note Added: 0033461 | |
2013-07-03 09:25 | Brad King | File Added: 0001-cmSystemTools-Re-order-extract_tar-logic.patch | |
2013-07-03 09:25 | Brad King | File Added: 0002-cmake-Avoid-E-tar-failure-to-extract-symlinks-Window.patch | |
2013-07-03 09:26 | Brad King | Note Added: 0033464 | |
2013-09-15 15:58 | Eric NOULARD | Relationship added | related to 0012376 |
2013-11-02 10:52 | Brad King | Note Added: 0034326 | |
2013-11-02 10:53 | Brad King | Assigned To | => Brad King |
2013-11-02 10:53 | Brad King | Status | new => resolved |
2013-11-02 10:53 | Brad King | Resolution | open => fixed |
2013-11-02 10:53 | Brad King | Fixed in Version | => CMake 3.0 |
2013-11-02 10:53 | Brad King | Target Version | CMake 2.8.12 => CMake 3.0 |
2014-03-14 08:30 | Brad King | Relationship added | has duplicate 0014805 |
2014-10-06 10:32 | Robert Maynard | Note Added: 0036941 | |
2014-10-06 10:32 | Robert Maynard | Status | resolved => closed |
Issue History |
Copyright © 2000 - 2018 MantisBT Team |