/usr/share/gmt/tools/ncdeflate is in gmt-common 5.4.3+dfsg-1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 | #!/bin/bash
#
# $Id: ncdeflate 19521 2017-12-27 22:38:24Z pwessel $
#
# Copyright (c) 1991-2018 by P. Wessel, W. H. F. Smith, R. Scharroo,
# J. Luis, and F. Wobbe
# See LICENSE.TXT file for copying and redistribution conditions.
#
# Compresses all variables in the given netcdf files with the
# specified deflation level.
function usage () {
echo "usage: $(basename $0) [-d n] [-o dir] [-s] file [file ...]" >&2
echo " [-d n] set compression level (0=min, 9=max, default=3)" >&2
echo " [-o dir] output directory" >&2
echo " [-s] add shuffle option to deflation compression" >&2
echo " [-v] be verbose" >&2
echo " [-x s] add suffix \"s\" to output filename" >&2
exit 1
}
# set defaults
NC_DEFLATE=3
NC_SHUFFLE=
NC_SUFFIX=""
NC_VERBOSE=0
OUTDIR=""
# handle filenames with spaces
IFS=$'\n'
# test if nccopy in PATH
if ! which nccopy >/dev/null 2>&1; then
echo "$(basename $0): cannot find nccopy." >&2
exit 1
fi
# find compatible stat command
if stat -f%z "$0" >/dev/null 2>&1; then
# BSD
STAT=stat
STATOPT="-f%z"
elif stat -c%s "$0" >/dev/null 2>&1; then
# GNU
STAT=stat
STATOPT="-c%s"
elif gstat -c%s "$0" >/dev/null 2>&1; then
# GNU
STAT=gstat
else
echo "$(basename $0): no compatible stat command found." >&2
exit 1
fi
function file1_greater_file2 () {
# return TRUE if 1st file is larger than the 2nd
size1=$($STAT $STATOPT "$1")
size2=$($STAT $STATOPT "$2")
if [ "$size1" -gt "$size2" ]; then
# compression ratio
NC_RATIO=$((100 - ${size2} * 100 / ${size1}))
return 0
fi
NC_RATIO="NA"
return 1
}
# parse command line args
while getopts ":d:o:svx:" opt; do
case $opt in
d)
NC_DEFLATE="$OPTARG"
;;
o)
OUTDIR="$OPTARG"
;;
s)
NC_SHUFFLE="-s"
;;
v)
NC_VERBOSE=TRUE
;;
x)
NC_SUFFIX="$OPTARG"
;;
\?)
echo "Invalid option: -$OPTARG" >&2
usage
;;
:)
echo "Option -$OPTARG requires an argument." >&2
usage
;;
esac
done
# test if 0 <= NC_DEFLATE <= 9
test "$NC_DEFLATE" -ge 0 -a "$NC_DEFLATE" -le 9 || usage
# remove options from $@
shift $((OPTIND-1))
test -z "$1" && usage
for file in $@; do
if ! [ -f "$file" ]; then
echo "$file: not found" >&2
continue
fi
# set default chunking
NC_CHUNK="-c$(ncdump -h "$file" | awk '/^dimensions:/ { getline ; while (match($0,"^\t")) {printf "%s/128,", $1; getline } } END {print "/"}')"
# compress file
if [ "$NC_VERBOSE" = "TRUE" ]; then
echo -n "$(basename "${file}")... " >&2
fi
if [ "$NC_DEFLATE" -gt 0 ]; then
nccopy -k 3 -d $NC_DEFLATE $NC_SHUFFLE $NC_CHUNK "$file" "${file}.$$.tmp" || continue
else
# write classic
nccopy -k 1 "$file" "${file}.$$.tmp" || continue
fi
# check compressed file size
if [ "$NC_DEFLATE" -eq 0 ] || file1_greater_file2 "$file" "${file}.$$.tmp" ; then
# if no compression or if compressed file is smaller than original file:
# replace original file with compressed/decompressed file
if [ "${OUTDIR}" ]; then
mv -f "${file}.$$.tmp" "${OUTDIR}/$(basename ${file})${NC_SUFFIX}"
else
mv -f "${file}.$$.tmp" "${file}${NC_SUFFIX}"
fi
if [ "$NC_VERBOSE" = "TRUE" ]; then
if [ "$NC_DEFLATE" -eq 0 ]; then
echo "done." >&2
else
echo "ratio: ${NC_RATIO}%." >&2
fi
fi
else
# keep original file and remove compressed file
rm -f "${file}.$$.tmp"
# copy original file
if [ "${OUTDIR}" ]; then
cp -f "${file}" "${OUTDIR}/$(basename ${file})${NC_SUFFIX}"
fi
if [ "$NC_VERBOSE" = "TRUE" ]; then
echo "could not reduce file size. already compressed?" >&2
fi
fi
done
exit 0
|