mirror of
https://github.com/apache/nuttx.git
synced 2025-01-12 23:18:36 +08:00
c9eef2d697
Most tools used for compliance and SBOM generation use SPDX identifiers This change brings us a step closer to an easy SBOM generation. Signed-off-by: Alin Jerpelea <alin.jerpelea@sony.com>
87 lines
2.8 KiB
Bash
Executable file
87 lines
2.8 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
############################################################################
|
|
# tools/copydir.sh
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
# contributor license agreements. See the NOTICE file distributed with
|
|
# this work for additional information regarding copyright ownership. The
|
|
# ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
# "License"); you may not use this file except in compliance with the
|
|
# License. You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
#
|
|
############################################################################
|
|
#
|
|
# NuttX uses symbolic links to configure platform-specific directories into
|
|
# the build system. This works great except for when a Windows native
|
|
# toolchain is used in a Cygwin environment. In that case, symbolic
|
|
# links do not work correctly when accessed from the Windows native toolchain;
|
|
# rather, just look link files with the extension .lnk
|
|
#
|
|
# In this environment, the build system will work around this using this script
|
|
# as a replacement for the 'ln' command. This scrpt will simply copy the
|
|
# directory into the expected positiion.
|
|
#
|
|
#set -x
|
|
|
|
src=$1
|
|
dest=$2
|
|
|
|
# Verify that arguments were provided
|
|
|
|
if [ -z "${src}" -o -z "${dest}" ]; then
|
|
echo "Missing src and/or dest arguments"
|
|
exit 1
|
|
fi
|
|
|
|
# Check if something already exists at the destination path replace it with
|
|
# the new link (which might be different). Note that we check for the
|
|
# the link (-h) before we check for existence (-e) because a bad link will
|
|
# report that it does not exist.
|
|
|
|
if [ -h "${dest}" ]; then
|
|
rm -f "${dest}"
|
|
else
|
|
|
|
# If the path exists and is a directory that contains the "fake link"
|
|
# mark, then treat it like a soft link (i.e., remove the directory)
|
|
|
|
if [ -d "${dest}" -a -f "${dest}/.fakelnk" ]; then
|
|
rm -rf "${dest}"
|
|
else
|
|
|
|
# Does anything exist at the destination path?
|
|
|
|
if [ -e "${dest}" ]; then
|
|
|
|
# It is something else (like a file) or directory that does
|
|
# not contain the "fake link" mark
|
|
|
|
echo "${dest} already exists but is not a symbolic link"
|
|
exit 1
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
# Verify that a directory exists at the source path
|
|
|
|
if [ ! -d "${src}" ]; then
|
|
echo "No directory at ${src}"
|
|
exit 1
|
|
fi
|
|
|
|
# Copy the directory
|
|
|
|
cp -a "${src}" "${dest}" || \
|
|
{ echo "Failed to create link: $dest" ; rm -rf ${dest} ; exit 1 ; }
|
|
touch "${dest}/.fakelnk" || \
|
|
{ echo "Failed to touch ${dest}/.fakelnk" ; rm -rf ${dest} ; exit 1 ; }
|