mirror of
https://github.com/llvm-mirror/libcxx.git
synced 2025-10-22 07:51:39 +08:00
Fix creating __generated_config on Windows
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@290853 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -35,8 +35,13 @@ if (LIBCXX_INSTALL_HEADERS)
|
|||||||
# Generate and install a custom __config header. The new header is created
|
# Generate and install a custom __config header. The new header is created
|
||||||
# by prepending __config_site to the current __config header.
|
# by prepending __config_site to the current __config header.
|
||||||
add_custom_command(OUTPUT ${LIBCXX_BINARY_DIR}/__generated_config
|
add_custom_command(OUTPUT ${LIBCXX_BINARY_DIR}/__generated_config
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy ${LIBCXX_BINARY_DIR}/__config_site ${LIBCXX_BINARY_DIR}/__generated_config
|
COMMAND ${CMAKE_COMMAND} -E copy
|
||||||
COMMAND ${UNIX_CAT} ${LIBCXX_SOURCE_DIR}/include/__config >> ${LIBCXX_BINARY_DIR}/__generated_config
|
${LIBCXX_BINARY_DIR}/__config_site
|
||||||
|
${LIBCXX_BINARY_DIR}/__generated_config
|
||||||
|
COMMAND ${PYTHON_EXECUTABLE} ${LIBCXX_SOURCE_DIR}/utils/cat_files.py
|
||||||
|
${LIBCXX_BINARY_DIR}/__generated_config
|
||||||
|
${LIBCXX_SOURCE_DIR}/include/__config
|
||||||
|
-o ${LIBCXX_BINARY_DIR}/__generated_config
|
||||||
DEPENDS ${LIBCXX_SOURCE_DIR}/include/__config
|
DEPENDS ${LIBCXX_SOURCE_DIR}/include/__config
|
||||||
${LIBCXX_BINARY_DIR}/__config_site
|
${LIBCXX_BINARY_DIR}/__config_site
|
||||||
)
|
)
|
||||||
|
46
utils/cat_files.py
Executable file
46
utils/cat_files.py
Executable file
@@ -0,0 +1,46 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
#===----------------------------------------------------------------------===##
|
||||||
|
#
|
||||||
|
# The LLVM Compiler Infrastructure
|
||||||
|
#
|
||||||
|
# This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
# Source Licenses. See LICENSE.TXT for details.
|
||||||
|
#
|
||||||
|
#===----------------------------------------------------------------------===##
|
||||||
|
|
||||||
|
from argparse import ArgumentParser
|
||||||
|
import sys
|
||||||
|
|
||||||
|
def print_and_exit(msg):
|
||||||
|
sys.stderr.write(msg + '\n')
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
def main():
|
||||||
|
parser = ArgumentParser(
|
||||||
|
description="Concatenate two files into a single file")
|
||||||
|
parser.add_argument(
|
||||||
|
'-o', '--output', dest='output', required=True,
|
||||||
|
help='The output file. stdout is used if not given',
|
||||||
|
type=str, action='store')
|
||||||
|
parser.add_argument(
|
||||||
|
'files', metavar='files', nargs='+',
|
||||||
|
help='The files to concatenate')
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
if len(args.files) < 2:
|
||||||
|
print_and_exit('fewer than 2 inputs provided')
|
||||||
|
data = ''
|
||||||
|
for filename in args.files:
|
||||||
|
with open(filename, 'r') as f:
|
||||||
|
data += f.read()
|
||||||
|
if len(data) != 0 and data[-1] != '\n':
|
||||||
|
data += '\n'
|
||||||
|
assert len(data) > 0 and "cannot cat empty files"
|
||||||
|
with open(args.output, 'w') as f:
|
||||||
|
f.write(data)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
|
sys.exit(0)
|
Reference in New Issue
Block a user