#!/usr/bin/env bash ############################################################################ # tools/indent.sh # # Copyright (C) 2008, 2010, 2016 Gregory Nutt. All rights reserved. # Author: Gregory Nutt # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in # the documentation and/or other materials provided with the # distribution. # 3. Neither the name NuttX nor the names of its contributors may be # used to endorse or promote products derived from this software # without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS # OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE # POSSIBILITY OF SUCH DAMAGE. # ############################################################################ # # This script uses the Linux 'indent' utility to re-format C source files # to match the coding style that I use. It differs from the NuttX coding # style in that: # # 1. I normally put the trailing */ of a multi-line comment on a separate # line. If your C file already has properly formatted comments then # using -nfca instead of -fca eliminates that bad behavior # 2. I usually align things vertically (like '=' in assignments), # 3. indent.sh puts a bogus blank line at the top of the file, # 4. I don't like the way it handles nested conditional compilation # intermixed with code. I prefer the preprocessor conditiona tests # be all right justified in that case. # 5. I also indent brackets differently on structures than does this script. # 6. I normally use no spaces in casts. indent.sh adds spaces in casts like # "(FAR void *)&foo" becomes "(FAR void *) & foo". # 7. When used with header files, the initial idempotence conditional test # causes all preprecessor directives to be indented in the file. So for # header files, you will need to substitute "^# " with "#" in the # converted header file. # # You will manually need to check for the issues listed above after # performing the conversion. # Constants options="-nbad -bap -bbb -nbbo -nbc -bl -bl2 -bls -nbs -cbi2 -ncdw -nce -ci2 -cli0 -cp40 -ncs -nbfda -nbfde -di1 -nfc1 -fca -i2 -l80 -lp -ppi2 -lps -npcs -pmt -nprs -npsl -saf -sai -sbi2 -saw -sc -sob -nss -nut" advice="Try '$0 -h' for more information" # Parse inputs unset filelist unset outfile files=none mode=inplace while [ ! -z "${1}" ]; do case ${1} in -d ) set -x ;; -o ) shift outfile=${1} mode=copy ;; -h ) echo "$0 is a tool for generation of proper version files for the NuttX build" echo "" echo "USAGE:" echo " $0 [-d] -o " echo " $0 [-d] " echo " $0 [-d] -h" echo "" echo "Where:" echo " -" echo " A single, unformatted input file" echo " -" echo " A list of unformatted input files that will be reformatted in place." echo " -o " echo " Write the single, reformatted to . " echo " will not be modified." echo " -d" echo " Enable script debug" echo " -h" echo " Show this help message and exit" exit 0 ;; * ) if [ ! -r ${1} ]; then echo "Readable ${1} does not exist" echo ${advice} exit 1 fi if [ -z "${filelist}" ]; then filelist="${1}" files=single else filelist="${filelist} ${1}" files=multiple fi ;; esac shift done # Verify that at least one input file was provided if [ "X${files}" == "Xnone" ]; then echo "ERROR: Neither nor provided" echo ${advice} exit 1 fi # Perform the indentation if [ "X${mode}" == "Xcopy" ]; then if [ "X${files}" == "Xmultiple" ]; then echo "ERROR: Only a single can be used with the -o option" echo ${advice} exit 1 fi if [ -f $outfile ]; then echo "Removing old $outfile" rm $outfile || { echo "Failed to remove $outfile" ; exit 1 ; } fi indent $options $filelist -o $outfile else indent $options $filelist fi