Subversion Repositories duke3d_hrp

Rev

Rev 324 | Rev 330 | Go to most recent revision | Only display areas with differences | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 324 Rev 325
1
#!/bin/sh
1
#!/bin/sh
2
 
2
 
3
# Duke Nukem 3D High Resolution Pack Extractor  v0.2  2012-03-17
3
# Duke Nukem 3D High Resolution Pack Extractor  v0.2  2012-03-17
4
#
4
#
5
# Author: LeoD
5
# Author: LeoD
6
# License: ISC license : http://opensource.org/licenses/isc-license.txt
6
# License: ISC license : http://opensource.org/licenses/isc-license.txt
7
#
7
#
8
# This script extracts a PolyMER or PolyMOST only HRP from your working copy of
8
# This script extracts a PolyMER or PolyMOST only HRP from your working copy of
9
# the Duke Nukem 3D High Resolution Pack's Subversion repository.
9
# the Duke Nukem 3D High Resolution Pack's Subversion repository.
10
# On Windows you need MSYS' zip to create package files.
10
# On Windows you need MSYS' zip to create package files.
11
# ("mingw-get install msys-zip")
11
# ("mingw-get install msys-zip")
12
# MinGW/MSYS performance is horrible, better go Linux. Even my virtual Debian
12
# MinGW/MSYS performance is horrible, better go Linux. Even my virtual Debian
13
# machine accessing the Windows drive is 5 to 10 times faster.
13
# machine accessing the Windows drive is 5 to 10 times faster.
14
# But it still sucks. This needs to become a Perl script one day.
14
# But it still sucks. This needs to become a Perl script one day.
15
# Or maybe MSYS bash gets finally updated to 4.* and I'll use its regex engine.
15
# Or maybe MSYS bash gets finally updated to 4.* and I'll use its regex engine.
16
 
16
 
17
SET_VERSION=YES # [YES|NO]
17
SET_VERSION=YES # [YES|NO]
18
EXTRACT_COMMENTED_FILES=NO # [YES|NO]
18
EXTRACT_COMMENTED_FILES=NO # [YES|NO]
19
DUKEPLUS_POLYMOST_COMPATIBILTY_APPROACH=none # [none|polymost|polymer|mixed]
19
DUKEPLUS_POLYMOST_COMPATIBILTY_APPROACH=none # [none|polymost|polymer|mixed]
20
 
20
 
21
ask()
21
ask()
22
{
22
{
23
  echo -n "$@" '[y/N] ' ; read ans
23
  echo -n "$@" '[y/N] ' ; read ans
24
  case "$ans" in
24
  case "$ans" in
25
    y*|Y*) return 0 ;;
25
    y*|Y*) return 0 ;;
26
    *)     return 1 ;;
26
    *)     return 1 ;;
27
  esac
27
  esac
28
} # ask
28
} # ask
29
 
29
 
30
 
30
 
31
copy_folders()
31
copy_folders()
32
{
32
{
33
  mkdir ${EXTRACTDIR}
33
  mkdir ${EXTRACTDIR}
34
  for HRPDIR in . ; do
34
  for HRPDIR in . ; do
35
    if [ -d "${HRPDIR}" ] ; then
35
    if [ -d "${HRPDIR}" ] ; then
36
      DIRLIST=./HRP_DIRECTORIES.lst
36
      DIRLIST=./HRP_DIRECTORIES.lst
37
      find "${HRPDIR}" -type d > ${DIRLIST}
37
      find "${HRPDIR}" -type d > ${DIRLIST}
38
      cat ${DIRLIST} | while read DIR; do
38
      cat ${DIRLIST} | while read DIR; do
39
        if [ ! -d "${EXTRACTDIR}/${DIR}" ] ; then
39
        if [ ! -d "${EXTRACTDIR}/${DIR}" ] ; then
40
          mkdir "${EXTRACTDIR}/${DIR}"
40
          mkdir "${EXTRACTDIR}/${DIR}"
41
        fi
41
        fi
42
      done
42
      done
43
      rm     ${DIRLIST}
43
      rm     ${DIRLIST}
44
    else
44
    else
45
      echo "${HRPDIR} : no HRP."
45
      echo "${HRPDIR} : no HRP."
46
    fi
46
    fi
47
  done
47
  done
48
} # copy_folders()
48
} # copy_folders()
49
 
49
 
50
 
50
 
51
copy_set_version()
51
copy_set_version()
52
{
52
{
53
  VER_FILE="$1"
53
  VER_FILE="$1"
54
  TARGET_FILE="$2"
54
  TARGET_FILE="$2"
55
  V_DATE=`date +%F`
55
  V_DATE=`date +%F`
56
  if [ "${VERSION}" = "" ] ; then
56
  if [ "${VERSION}" = "" ] ; then
57
    if [ -f VERSION ] ; then
57
    if [ -f VERSION ] ; then
58
      VERSION=`grep -owE "[0-9\\.]*" VERSION`
58
      VERSION=`grep -owE "[0-9\\.]*" VERSION`
59
    fi
59
    fi
60
  fi
60
  fi
61
 
61
 
62
  echo "copy_set_version ${VER_FILE} -> ${TARGET_FILE}"
62
  echo "copy_set_version ${VER_FILE} -> ${TARGET_FILE}"
63
 
63
 
64
  case "${VER_FILE}" in
64
  case "${VER_FILE}" in
65
    hrp_readme.txt)
65
    hrp_readme.txt)
66
      cat "${VER_FILE}" | sed -r --posix \
66
      cat "${VER_FILE}" | sed -r --posix \
67
        s/\(Version\ *\)\([0-9\.]*\)\(.*\)\(\\\)\)\(.*\)/\\1${VERSION}\ \(${V_DATE}\)\ \ \\5/ \
67
        s/\(Version\ *\)\([0-9\.]*\)\(.*\)\(\\\)\)\(.*\)/\\1${VERSION}\ \(${V_DATE}\)\ \ \\5/ \
68
        >> "${TARGET_FILE}"
68
        >> "${TARGET_FILE}"
69
      ;;
69
      ;;
70
    duke3d_hrp.def)
70
    duke3d_hrp.def)
-
 
71
      if [ "${HRPTYPE}" = "polymer" ] ; then
-
 
72
        cat "${VER_FILE}" | sed -r --posix \
-
 
73
          s/\(Version\ *\)\([0-9\.]*\)\(.*\)/\\1${VERSION}\ Polymer\\3/ \
-
 
74
          >> "${TARGET_FILE}"
-
 
75
      else
71
      cat "${VER_FILE}" | sed -r --posix \
76
        cat "${VER_FILE}" | sed -r --posix \
72
        s/\(Version\ *\)\([0-9\.]*\)\(.*\)/\\1${VERSION}\\3/ \
77
          s/\(Version\ *\)\([0-9\.]*\)\(.*\)/\\1${VERSION}\\3/ \
73
        >> "${TARGET_FILE}"
78
          >> "${TARGET_FILE}"
-
 
79
      fi
74
      ;;
80
      ;;
75
    duke3d_hrp_polymost.def)
81
    duke3d_hrp_polymost.def)
76
      if [ "${HRPTYPE}" = "polymost_override" ] ; then
82
      if [ "${HRPTYPE}" = "polymost_override" ] ; then
77
        cat "${VER_FILE}" | sed -r --posix \
83
        cat "${VER_FILE}" | sed -r --posix \
78
          s/\(Version\ *\)\([0-9\.]*\)\(\ Polymost\)/\\1${VERSION}\ Polymost\ Override/ \
84
          s/\(Version\ *\)\([0-9\.]*\)\(\ Polymost\)/\\1${VERSION}\ Polymost\ Override/ \
79
          >> "${TARGET_FILE}"
85
          >> "${TARGET_FILE}"
80
      else
86
      else
81
        cat "${VER_FILE}" | sed -r --posix \
87
        cat "${VER_FILE}" | sed -r --posix \
82
          s/\(Version\ *\)\([0-9\.]*\)\(.*\)/\\1${VERSION}\\3/ \
88
          s/\(Version\ *\)\([0-9\.]*\)\(.*\)/\\1${VERSION}\\3/ \
83
          >> "${TARGET_FILE}"
89
          >> "${TARGET_FILE}"
84
      fi
90
      fi
85
      ;;
91
      ;;
86
    *)
92
    *)
87
      echo "###ERROR: copy_set_version() - BAD FILE: ${VER_FILE}"
93
      echo "###ERROR: copy_set_version() - BAD FILE: ${VER_FILE}"
88
      exit 1
94
      exit 1
89
      ;;
95
      ;;
90
  esac
96
  esac
91
}
97
}
92
 
98
 
93
copy_known_files()
99
copy_known_files()
94
{
100
{
95
  if [ "${SET_VERSION}" = "YES" ] ; then
101
  if [ "${SET_VERSION}" = "YES" ] ; then
96
    copy_set_version hrp_readme.txt "${EXTRACTDIR}/hrp_readme.txt"
102
    copy_set_version hrp_readme.txt "${EXTRACTDIR}/hrp_readme.txt"
97
  else
103
  else
98
    cp -pv hrp_readme.txt           "${EXTRACTDIR}"
104
    cp -pv hrp_readme.txt           "${EXTRACTDIR}"
99
  fi
105
  fi
100
  cp -pv hrp_art_license.txt        "${EXTRACTDIR}"
106
  cp -pv hrp_art_license.txt        "${EXTRACTDIR}"
101
 
107
 
102
  if [ "${HRPTYPE}" = "polymost" ] || [ "${HRPTYPE}" = "polymost_override" ] ; then
108
  if [ "${HRPTYPE}" = "polymost" ] || [ "${HRPTYPE}" = "polymost_override" ] ; then
103
    if [ "${SET_VERSION}" = "YES" ] ; then
109
    if [ "${SET_VERSION}" = "YES" ] ; then
104
      copy_set_version duke3d_hrp_polymost.def "${EXTRACTDIR}/duke3d_hrp.def"
110
      copy_set_version duke3d_hrp_polymost.def "${EXTRACTDIR}/duke3d_hrp.def"
105
    else
111
    else
106
      cp -pv           duke3d_hrp_polymost.def "${EXTRACTDIR}/duke3d_hrp.def"
112
      cp -pv           duke3d_hrp_polymost.def "${EXTRACTDIR}/duke3d_hrp.def"
107
    fi
113
    fi
108
  fi
114
  fi
109
 
115
 
110
  if [ "${HRPTYPE}" = "polymost" ] ; then
116
  if [ "${HRPTYPE}" = "polymost" ] ; then
111
    cp -pv duke3d.def "${EXTRACTDIR}"
117
    cp -pv duke3d.def "${EXTRACTDIR}"
112
    #cp -pv duke3d_hrp_polymost.def               "${EXTRACTDIR}"
118
    #cp -pv duke3d_hrp_polymost.def               "${EXTRACTDIR}"
113
    #cp -pv highres/screen/menu/2492_polymost.png "${EXTRACTDIR}/highres/screen/menu"
119
    #cp -pv highres/screen/menu/2492_polymost.png "${EXTRACTDIR}/highres/screen/menu"
114
  fi
120
  fi
115
 
121
 
116
  if [ "${HRPTYPE}" = "full" ] ; then
122
  if [ "${HRPTYPE}" = "full" ] ; then
117
    if [ "${SET_VERSION}" = "YES" ] ; then
123
    if [ "${SET_VERSION}" = "YES" ] ; then
118
      copy_set_version duke3d_hrp_polymost.def "${EXTRACTDIR}/duke3d_hrp_polymost.def"
124
      copy_set_version duke3d_hrp_polymost.def "${EXTRACTDIR}/duke3d_hrp_polymost.def"
119
    else
125
    else
120
      cp -pv           duke3d_hrp_polymost.def "${EXTRACTDIR}"
126
      cp -pv           duke3d_hrp_polymost.def "${EXTRACTDIR}"
121
    fi
127
    fi
122
  fi
128
  fi
123
 
129
 
124
  if [ "${HRPTYPE}" = "polymost_override" ] || [ "${HRPTYPE}" = "full" ] ; then
130
  if [ "${HRPTYPE}" = "polymost_override" ] || [ "${HRPTYPE}" = "full" ] ; then
125
    cp -pv highres/screen/menu/2492_ver_polymost.png "${EXTRACTDIR}/highres/screen/menu"
131
    cp -pv highres/screen/menu/2492_ver_polymost.png "${EXTRACTDIR}/highres/screen/menu"
126
  fi
132
  fi
127
 
133
 
128
  if [ "${HRPTYPE}" = "polymer" ] || [ "${HRPTYPE}" = "full" ] ; then
134
  if [ "${HRPTYPE}" = "polymer" ] || [ "${HRPTYPE}" = "full" ] ; then
129
    cp -pv duke3d.def                   "${EXTRACTDIR}"
135
    cp -pv duke3d.def                   "${EXTRACTDIR}"
130
    if [ "${SET_VERSION}" = "YES" ] ; then
136
    if [ "${SET_VERSION}" = "YES" ] ; then
131
      copy_set_version duke3d_hrp.def "${EXTRACTDIR}/duke3d_hrp.def"
137
      copy_set_version duke3d_hrp.def "${EXTRACTDIR}/duke3d_hrp.def"
132
    else
138
    else
133
      cp -pv           duke3d_hrp.def "${EXTRACTDIR}"
139
      cp -pv           duke3d_hrp.def "${EXTRACTDIR}"
134
    fi
140
    fi
135
    echo                  "\`*.mhk' -> \`${EXTRACTDIR}/*.mhk'"
141
    echo                  "\`*.mhk' -> \`${EXTRACTDIR}/*.mhk'"
136
    cp -p  *.mhk                        "${EXTRACTDIR}"
142
    cp -p  *.mhk                        "${EXTRACTDIR}"
137
    #cp -pv highres/screen/menu/2492.png "${EXTRACTDIR}/highres/screen/menu"
143
    #cp -pv highres/screen/menu/2492.png "${EXTRACTDIR}/highres/screen/menu"
138
 
144
 
139
    #cp -pv highres/common/black.png                          "${EXTRACTDIR}/highres/common"
145
    #cp -pv highres/common/black.png                          "${EXTRACTDIR}/highres/common"
140
    #cp -pv highres/screen/fonts/digital/digital_minus.png    "${EXTRACTDIR}/highres/screen/fonts/digital"
146
    #cp -pv highres/screen/fonts/digital/digital_minus.png    "${EXTRACTDIR}/highres/screen/fonts/digital"
141
    #cp -pv highres/screen/menu/2493_old.png                  "${EXTRACTDIR}/highres/screen/menu"
147
    #cp -pv highres/screen/menu/2493_old.png                  "${EXTRACTDIR}/highres/screen/menu"
142
    #cp -pv highres/screen/menu/widescreen/*_wide.png         "${EXTRACTDIR}/highres/screen/menu"
148
    #cp -pv highres/screen/menu/widescreen/*_wide.png         "${EXTRACTDIR}/highres/screen/menu"
143
    #cp -pv highres/sprites/characters/1357_terminarm.md3     "${EXTRACTDIR}/highres/sprites/characters"
149
    #cp -pv highres/sprites/characters/1357_terminarm.md3     "${EXTRACTDIR}/highres/sprites/characters"
144
    #cp -pv highres/sprites/firstperson/2510_devastator_n.png "${EXTRACTDIR}/highres/sprites/firstperson"
150
    #cp -pv highres/sprites/firstperson/2510_devastator_n.png "${EXTRACTDIR}/highres/sprites/firstperson"
145
    #cp -pv highres/sprites/monsters/1960_reconcar_s.png      "${EXTRACTDIR}/highres/sprites/monsters"
151
    #cp -pv highres/sprites/monsters/1960_reconcar_s.png      "${EXTRACTDIR}/highres/sprites/monsters"
146
    #cp -pv highres/sprites/props/4387.png                    "${EXTRACTDIR}/highres/sprites/props"
152
    #cp -pv highres/sprites/props/4387.png                    "${EXTRACTDIR}/highres/sprites/props"
147
    #cp -pv highres/sprites/signs/4378.png                    "${EXTRACTDIR}/highres/sprites/signs"
153
    #cp -pv highres/sprites/signs/4378.png                    "${EXTRACTDIR}/highres/sprites/signs"
148
    #cp -pv highres/sprites/signs/4379.png                    "${EXTRACTDIR}/highres/sprites/signs"
154
    #cp -pv highres/sprites/signs/4379.png                    "${EXTRACTDIR}/highres/sprites/signs"
149
    #cp -pv highres/sprites/signs/4381-85.png                 "${EXTRACTDIR}/highres/sprites/signs"
155
    #cp -pv highres/sprites/signs/4381-85.png                 "${EXTRACTDIR}/highres/sprites/signs"
150
  fi
156
  fi
151
 
157
 
152
} # copy_known_files()
158
} # copy_known_files()
153
 
159
 
154
 
160
 
155
polymost_mhk_patch()
161
polymost_mhk_patch()
156
{
162
{
157
  MHKFILE="$1"
163
  MHKFILE="$1"
158
  MHK_LINE="$2"
164
  MHK_LINE="$2"
159
 
165
 
160
  case "${MHKFILE}" in
166
  case "${MHKFILE}" in
161
    "E3L1.mhk")
167
    "E3L1.mhk")
162
      echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
168
      echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
163
      MHK_INSERT=`echo "${MHK_LINE}" | grep -oE "sprite\ 575\ pitch\ 1"`
169
      MHK_INSERT=`echo "${MHK_LINE}" | grep -oE "sprite\ 575\ pitch\ 1"`
164
      if [ ! "${MHK_INSERT}" = "" ] ; then
170
      if [ ! "${MHK_INSERT}" = "" ] ; then
165
        echo "sprite 591 mdxoff 425000 // underwater slimebabe (Polymost HRP)\r" \
171
        echo "sprite 591 mdxoff 425000 // underwater slimebabe (Polymost HRP)\r" \
166
             >> "${EXTRACTDIR}/${MHKFILE}"
172
             >> "${EXTRACTDIR}/${MHKFILE}"
167
        echo "sprite 591 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
173
        echo "sprite 591 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
168
        echo "sprite 592 mdxoff 425000 // underwater slimebabe (Polymost HRP)\r" \
174
        echo "sprite 592 mdxoff 425000 // underwater slimebabe (Polymost HRP)\r" \
169
             >> "${EXTRACTDIR}/${MHKFILE}"
175
             >> "${EXTRACTDIR}/${MHKFILE}"
170
        echo "sprite 592 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
176
        echo "sprite 592 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
171
        echo "sprite 593 mdxoff 425000 // underwater slimebabe (Polymost HRP)\r" \
177
        echo "sprite 593 mdxoff 425000 // underwater slimebabe (Polymost HRP)\r" \
172
             >> "${EXTRACTDIR}/${MHKFILE}"
178
             >> "${EXTRACTDIR}/${MHKFILE}"
173
        echo "sprite 593 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
179
        echo "sprite 593 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
174
      fi
180
      fi
175
      ;;
181
      ;;
176
    "E3L3.mhk")
182
    "E3L3.mhk")
177
      MHK_REPLACE=`echo "${MHK_LINE}" | grep -oE "sprite\ 105\ angoff -128"`
183
      MHK_REPLACE=`echo "${MHK_LINE}" | grep -oE "sprite\ 105\ angoff -128"`
178
      if [ ! "${MHK_REPLACE}" = "" ] ; then
184
      if [ ! "${MHK_REPLACE}" = "" ] ; then
179
        echo "sprite 105 angoff 768 // (Polymost HRP)\r" >> "${EXTRACTDIR}/${MHKFILE}"
185
        echo "sprite 105 angoff 768 // (Polymost HRP)\r" >> "${EXTRACTDIR}/${MHKFILE}"
180
      else
186
      else
181
        echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
187
        echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
182
        MHK_INSERT=`echo "${MHK_LINE}" | grep -oE "sprite\ 96\ pitch\ 1"`
188
        MHK_INSERT=`echo "${MHK_LINE}" | grep -oE "sprite\ 96\ pitch\ 1"`
183
        if [ ! "${MHK_INSERT}" = "" ] ; then
189
        if [ ! "${MHK_INSERT}" = "" ] ; then
184
          echo "sprite 105 mdxoff 450000 // underwater slime babe (Polymost HRP)\r" \
190
          echo "sprite 105 mdxoff 450000 // underwater slime babe (Polymost HRP)\r" \
185
                                      >> "${EXTRACTDIR}/${MHKFILE}"
191
                                      >> "${EXTRACTDIR}/${MHKFILE}"
186
          echo "sprite 105 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
192
          echo "sprite 105 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
187
          echo "sprite 447 mdxoff 462000 // underwater slime babe (Polymost HRP)\r" \
193
          echo "sprite 447 mdxoff 462000 // underwater slime babe (Polymost HRP)\r" \
188
                                      >> "${EXTRACTDIR}/${MHKFILE}"
194
                                      >> "${EXTRACTDIR}/${MHKFILE}"
189
          echo "sprite 447 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
195
          echo "sprite 447 pitch 1\r" >> "${EXTRACTDIR}/${MHKFILE}"
190
        fi
196
        fi
191
      fi
197
      fi
192
      ;;
198
      ;;
193
    "E3L6.mhk")
199
    "E3L6.mhk")
194
      MHK_REPLACE1=`echo "${MHK_LINE}" | grep -oE "sprite\ 307\ angoff -210"`
200
      MHK_REPLACE1=`echo "${MHK_LINE}" | grep -oE "sprite\ 307\ angoff -210"`
195
      MHK_REPLACE2=`echo "${MHK_LINE}" | grep -oE "sprite\ 307\ mdxoff -125000 \\/\\/\ flipped hanging babe"`
201
      MHK_REPLACE2=`echo "${MHK_LINE}" | grep -oE "sprite\ 307\ mdxoff -125000 \\/\\/\ flipped hanging babe"`
196
      MHK_REPLACE3=`echo "${MHK_LINE}" | grep -oE "sprite\ 307\ mdzoff -11000"`
202
      MHK_REPLACE3=`echo "${MHK_LINE}" | grep -oE "sprite\ 307\ mdzoff -11000"`
197
      if   [ ! "${MHK_REPLACE1}" = "" ] ; then
203
      if   [ ! "${MHK_REPLACE1}" = "" ] ; then
198
        echo "sprite 307 angoff 200 // (Polymost HRP)\r" >> "${EXTRACTDIR}/${MHKFILE}"
204
        echo "sprite 307 angoff 200 // (Polymost HRP)\r" >> "${EXTRACTDIR}/${MHKFILE}"
199
      elif [ ! "${MHK_REPLACE2}" = "" ] ; then
205
      elif [ ! "${MHK_REPLACE2}" = "" ] ; then
200
        echo "sprite 307 mdxoff 750000 // flipped hanging babe (Polymost HRP)\r" \
206
        echo "sprite 307 mdxoff 750000 // flipped hanging babe (Polymost HRP)\r" \
201
             >> "${EXTRACTDIR}/${MHKFILE}"
207
             >> "${EXTRACTDIR}/${MHKFILE}"
202
      elif [ ! "${MHK_REPLACE3}" = "" ] ; then
208
      elif [ ! "${MHK_REPLACE3}" = "" ] ; then
203
        echo "sprite 307 mdzoff 625000 // flipped hanging babe (Polymost HRP)\r" \
209
        echo "sprite 307 mdzoff 625000 // flipped hanging babe (Polymost HRP)\r" \
204
             >> "${EXTRACTDIR}/${MHKFILE}"
210
             >> "${EXTRACTDIR}/${MHKFILE}"
205
      else
211
      else
206
        echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
212
        echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
207
      fi
213
      fi
208
      ;;
214
      ;;
209
    *)
215
    *)
210
      echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
216
      echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
211
      ;;
217
      ;;
212
  esac
218
  esac
213
} # polymost_mhk_patch()
219
} # polymost_mhk_patch()
214
 
220
 
215
 
221
 
216
create_polymost_mhk()
222
create_polymost_mhk()
217
{
223
{
218
  for MHKFILE in *.mhk ; do
224
  for MHKFILE in *.mhk ; do
219
    MHKSTOP="0"
225
    MHKSTOP="0"
220
    cat   ${MHKFILE} | while read MHK_LINE; do
226
    cat   ${MHKFILE} | while read MHK_LINE; do
221
      if [ "${MHKSTOP}" = "0" ] ; then
227
      if [ "${MHKSTOP}" = "0" ] ; then
222
 
228
 
223
        if [ "${MHKFILE}" = "E3L1.mhk" ] || [ "${MHKFILE}" = "E3L3.mhk" ] || \
229
        if [ "${MHKFILE}" = "E3L1.mhk" ] || [ "${MHKFILE}" = "E3L3.mhk" ] || \
224
           [ "${MHKFILE}" = "E3L6.mhk" ] ; then
230
           [ "${MHKFILE}" = "E3L6.mhk" ] ; then
225
          polymost_mhk_patch ${MHKFILE} "${MHK_LINE}"
231
          polymost_mhk_patch ${MHKFILE} "${MHK_LINE}"
226
        else
232
        else
227
          echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
233
          echo "${MHK_LINE}" >> "${EXTRACTDIR}/${MHKFILE}"
228
        fi
234
        fi
229
 
235
 
230
        MHK_TERM=`echo "${MHK_LINE}" | grep -owE "\\/\\/\\ LIGHTS"`
236
        MHK_TERM=`echo "${MHK_LINE}" | grep -owE "\\/\\/\\ LIGHTS"`
231
        if [ "${MHK_TERM}" = "// LIGHTS" ] ; then
237
        if [ "${MHK_TERM}" = "// LIGHTS" ] ; then
232
          MHKSTOP="1"
238
          MHKSTOP="1"
233
        fi
239
        fi
234
      fi
240
      fi
235
    done
241
    done
236
  done
242
  done
237
  # Some people prefer unusual setups ...
243
  # Some people prefer unusual setups ...
238
  zip -rq9 ${EXTRACTDIR}/polymost_hrp_update_polymer_maphacks.zip *.mhk
244
  zip -rq9 ${EXTRACTDIR}/polymost_hrp_update_polymer_maphacks.zip *.mhk
239
} # create_polymost_mhk()
245
} # create_polymost_mhk()
240
 
246
 
241
 
247
 
242
# I really don't know yet if this will become necessary, or if it doesn't make
248
# I really don't know yet if this will become necessary, or if it doesn't make
243
# sense at all, but at least the files involved are listed.
249
# sense at all, but at least the files involved are listed.
244
dukeplus_polymost_compatibility()
250
dukeplus_polymost_compatibility()
245
{
251
{
246
  # dukeplus.def expects some files to be present in the HRP
252
  # dukeplus.def expects some files to be present in the HRP
247
  #
253
  #
248
  # model "highres/sprites/characters/1405_duke.md3" { // all OK, no action required
254
  # model "highres/sprites/characters/1405_duke.md3" { // all OK, no action required
249
  #    skin { pal 0 surface 0 file "highres/sprites/pickups/0057_jetpack.png" }
255
  #    skin { pal 0 surface 0 file "highres/sprites/pickups/0057_jetpack.png" }
250
  #    skin { pal 0 surface 1 file "highres/sprites/characters/1405_duke.png" }
256
  #    skin { pal 0 surface 1 file "highres/sprites/characters/1405_duke.png" }
251
  #    skin { pal 10 surface 1 file "highres/sprites/characters/1405_duke_10.png" }
257
  #    skin { pal 10 surface 1 file "highres/sprites/characters/1405_duke_10.png" }
252
  #    skin { pal 11 surface 1 file "highres/sprites/characters/1405_duke_11.png" }
258
  #    skin { pal 11 surface 1 file "highres/sprites/characters/1405_duke_11.png" }
253
  #    skin { pal 12 surface 1 file "highres/sprites/characters/1405_duke_12.png" }
259
  #    skin { pal 12 surface 1 file "highres/sprites/characters/1405_duke_12.png" }
254
  #    skin { pal 13 surface 1 file "highres/sprites/characters/1405_duke_13.png" }
260
  #    skin { pal 13 surface 1 file "highres/sprites/characters/1405_duke_13.png" }
255
  #    skin { pal 14 surface 1 file "highres/sprites/characters/1405_duke_14.png" }
261
  #    skin { pal 14 surface 1 file "highres/sprites/characters/1405_duke_14.png" }
256
  #    skin { pal 15 surface 1 file "highres/sprites/characters/1405_duke_15.png" }
262
  #    skin { pal 15 surface 1 file "highres/sprites/characters/1405_duke_15.png" }
257
  #    skin { pal 16 surface 1 file "highres/sprites/characters/1405_duke_16.png" }
263
  #    skin { pal 16 surface 1 file "highres/sprites/characters/1405_duke_16.png" }
258
  #    skin { pal 21 surface 1 file "highres/sprites/characters/1405_duke_21.png" }
264
  #    skin { pal 21 surface 1 file "highres/sprites/characters/1405_duke_21.png" }
259
  #    skin { pal 23 surface 1 file "highres/sprites/characters/1405_duke_23.png" }
265
  #    skin { pal 23 surface 1 file "highres/sprites/characters/1405_duke_23.png" }
260
  #    skin { pal 0 surface 2 file "highres/sprites/pickups/0023_rpg.png" }
266
  #    skin { pal 0 surface 2 file "highres/sprites/pickups/0023_rpg.png" }
261
  #
267
  #
262
  # model "highres/sprites/firstperson/2510_devastator.md3" { // since Imperium, not Eternity
268
  # model "highres/sprites/firstperson/2510_devastator.md3" { // since Imperium, not Eternity
263
  #    skin { pal 0 file "highres/sprites/firstperson/2510_devastator.png" specfactor 0.5 specpower 35 }
269
  #    skin { pal 0 file "highres/sprites/firstperson/2510_devastator.png" specfactor 0.5 specpower 35 }
264
  #    specular { file "highres/sprites/firstperson/2510_devastator_s.png" }
270
  #    specular { file "highres/sprites/firstperson/2510_devastator_s.png" }
265
  #    glow { file "highres/sprites/firstperson/2510_devastator_g.png" }
271
  #    glow { file "highres/sprites/firstperson/2510_devastator_g.png" }
266
  #
272
  #
267
  # model "highres/sprites/firstperson/2524_pistol.md3" {    // most/mer : same MD3 + same skin til r295     
273
  # model "highres/sprites/firstperson/2524_pistol.md3" {    // most/mer : same MD3 + same skin til r295     
268
  #    skin { pal 0 file "highres/sprites/firstperson/2524_pistol.png" } // up to DP2.30 DNE/IMP only
274
  #    skin { pal 0 file "highres/sprites/firstperson/2524_pistol.png" } // up to DP2.30 DNE/IMP only
269
  #    glow { file "highres/sprites/firstperson/2524_pistol_g.png" }     // up to DP2.30 DNE/IMP only
275
  #    glow { file "highres/sprites/firstperson/2524_pistol_g.png" }     // up to DP2.30 DNE/IMP only
270
  # model "highres/sprites/firstperson/2530_clip.md3" {                  // most/mer : diff MD3, same skin
276
  # model "highres/sprites/firstperson/2530_clip.md3" {                  // most/mer : diff MD3, same skin
271
  #    skin { pal 0 file "highres/sprites/pickups/0040_pistolammo.jpg" }
277
  #    skin { pal 0 file "highres/sprites/pickups/0040_pistolammo.jpg" }
272
  # model "highres/sprites/firstperson/2532_cliphand.md3" {  // most/mer : same MD3 + same skin til r295
278
  # model "highres/sprites/firstperson/2532_cliphand.md3" {  // most/mer : same MD3 + same skin til r295
273
  #    skin { pal 0 file "highres/sprites/firstperson/2532_cliphand.png" } // til r295, then duke_hand_*
279
  #    skin { pal 0 file "highres/sprites/firstperson/2532_cliphand.png" } // til r295, then duke_hand_*
274
  #
280
  #
275
 
281
 
276
  SPR="highres/sprites"
282
  SPR="highres/sprites"
277
  SPRE="${EXTRACTDIR}/highres/sprites"
283
  SPRE="${EXTRACTDIR}/highres/sprites"
278
  PATCHTYPE=$1
284
  PATCHTYPE=$1
279
 
285
 
280
  case "$PATCHTYPE" in
286
  case "$PATCHTYPE" in
281
    polymer)
287
    polymer)
282
      echo "  # Using \"Polymer approach\")"
288
      echo "  # Using \"Polymer approach\")"
283
      cp -pi $SPR/firstperson/2510_devastator.md3            "$SPRE/firstperson"
289
      cp -pi $SPR/firstperson/2510_devastator.md3            "$SPRE/firstperson"
284
      cp -pi $SPR/firstperson/2510_devastator.png            "$SPRE/firstperson"
290
      cp -pi $SPR/firstperson/2510_devastator.png            "$SPRE/firstperson"
285
      cp -pi $SPR/firstperson/2510_devastator_s.png          "$SPRE/firstperson"
291
      cp -pi $SPR/firstperson/2510_devastator_s.png          "$SPRE/firstperson"
286
      cp -pi $SPR/firstperson/2510_devastator_g.png          "$SPRE/firstperson"
292
      cp -pi $SPR/firstperson/2510_devastator_g.png          "$SPRE/firstperson"
287
      cp -pi $SPR/firstperson/2524_pistol.md3                "$SPRE/firstperson"
293
      cp -pi $SPR/firstperson/2524_pistol.md3                "$SPRE/firstperson"
288
      cp -pi $SPR/firstperson_polymost/2524_pistol.png       "$SPRE/firstperson"
294
      cp -pi $SPR/firstperson_polymost/2524_pistol.png       "$SPRE/firstperson"
289
      cp -pi $SPR/firstperson_polymost/2524_pistol_g.png     "$SPRE/firstperson"
295
      cp -pi $SPR/firstperson_polymost/2524_pistol_g.png     "$SPRE/firstperson"
290
      cp -pi $SPR/firstperson/2530_clip.md3                  "$SPRE/firstperson"
296
      cp -pi $SPR/firstperson/2530_clip.md3                  "$SPRE/firstperson"
291
      cp -pi $SPR/pickups/0040_pistolammo.jpg                "$SPRE/pickups"
297
      cp -pi $SPR/pickups/0040_pistolammo.jpg                "$SPRE/pickups"
292
      cp -pi $SPR/firstperson/2532_cliphand.md3              "$SPRE/firstperson"
298
      cp -pi $SPR/firstperson/2532_cliphand.md3              "$SPRE/firstperson"
293
      cp -pi $SPR/firstperson/2532_cliphand.png              "$SPRE/firstperson"
299
      cp -pi $SPR/firstperson/2532_cliphand.png              "$SPRE/firstperson"
294
      cp -pi $SPR/firstperson/duke_hand_d.png                "$SPRE/firstperson"
300
      cp -pi $SPR/firstperson/duke_hand_d.png                "$SPRE/firstperson"
295
      cp -pi $SPR/firstperson/duke_hand_n.png                "$SPRE/firstperson"
301
      cp -pi $SPR/firstperson/duke_hand_n.png                "$SPRE/firstperson"
296
      cp -pi $SPR/firstperson/duke_hand_s.png                "$SPRE/firstperson"
302
      cp -pi $SPR/firstperson/duke_hand_s.png                "$SPRE/firstperson"
297
      ;;
303
      ;;
298
    polymost)
304
    polymost)
299
      echo "  # Using (\"Polymost approach\")"
305
      echo "  # Using (\"Polymost approach\")"
300
      cp -pi $SPR/firstperson_polymost/2510_devastator.md3   "$SPRE/firstperson"
306
      cp -pi $SPR/firstperson_polymost/2510_devastator.md3   "$SPRE/firstperson"
301
      cp -pi $SPR/firstperson_polymost/2510_devastator.png   "$SPRE/firstperson"
307
      cp -pi $SPR/firstperson_polymost/2510_devastator.png   "$SPRE/firstperson"
302
      #cp -pi $SPR/firstperson/2510_devastator_s.png          "$SPRE/firstperson"
308
      #cp -pi $SPR/firstperson/2510_devastator_s.png          "$SPRE/firstperson"
303
      cp -pi $SPR/firstperson_polymost/2510_devastator_g.png "$SPRE/firstperson"
309
      cp -pi $SPR/firstperson_polymost/2510_devastator_g.png "$SPRE/firstperson"
304
      cp -pi $SPR/firstperson_polymost/2524_pistol.md3       "$SPRE/firstperson"
310
      cp -pi $SPR/firstperson_polymost/2524_pistol.md3       "$SPRE/firstperson"
305
      cp -pi $SPR/firstperson_polymost/2524_pistol.png       "$SPRE/firstperson"
311
      cp -pi $SPR/firstperson_polymost/2524_pistol.png       "$SPRE/firstperson"
306
      cp -pi $SPR/firstperson_polymost/2524_pistol_g.png     "$SPRE/firstperson"
312
      cp -pi $SPR/firstperson_polymost/2524_pistol_g.png     "$SPRE/firstperson"
307
      cp -pi $SPR/firstperson_polymost/2530_clip.md3         "$SPRE/firstperson"
313
      cp -pi $SPR/firstperson_polymost/2530_clip.md3         "$SPRE/firstperson"
308
      cp -pi $SPR/pickups/0040_pistolammo.jpg                "$SPRE/pickups"
314
      cp -pi $SPR/pickups/0040_pistolammo.jpg                "$SPRE/pickups"
309
      cp -pi $SPR/firstperson_polymost/2532_cliphand.md3     "$SPRE/firstperson"
315
      cp -pi $SPR/firstperson_polymost/2532_cliphand.md3     "$SPRE/firstperson"
310
      cp -pi $SPR/firstperson/2532_cliphand.png              "$SPRE/firstperson"
316
      cp -pi $SPR/firstperson/2532_cliphand.png              "$SPRE/firstperson"
311
      cp -pi $SPR/firstperson/duke_hand_d.png                "$SPRE/firstperson"
317
      cp -pi $SPR/firstperson/duke_hand_d.png                "$SPRE/firstperson"
312
      cp -pi $SPR/firstperson/duke_hand_n.png                "$SPRE/firstperson"
318
      cp -pi $SPR/firstperson/duke_hand_n.png                "$SPRE/firstperson"
313
      cp -pi $SPR/firstperson/duke_hand_s.png                "$SPRE/firstperson"
319
      cp -pi $SPR/firstperson/duke_hand_s.png                "$SPRE/firstperson"
314
      ;;
320
      ;;
315
    mixed)
321
    mixed)
316
      echo "  # Using (\"Mixed approach\")"
322
      echo "  # Using (\"Mixed approach\")"
317
      echo "    # Not applied / Not yet implemented"
323
      echo "    # Not applied / Not yet implemented"
318
      ;;
324
      ;;
319
    none)
325
    none)
320
      #echo "  Not applied"
326
      #echo "  Not applied"
321
      echo "  # Not yet implemented"
327
      echo "  # Not yet implemented"
322
      ;;
328
      ;;
323
    *)
329
    *)
324
      echo "  # Bad parameter"
330
      echo "  # Bad parameter"
325
      ;;
331
      ;;
326
  esac
332
  esac
327
 
333
 
328
} # dukeplus_polymost_compatibility()
334
} # dukeplus_polymost_compatibility()
329
 
335
 
330
 
336
 
331
parse_defs()
337
parse_defs()
332
{
338
{
333
  echo "$1"
339
  echo "$1"
334
  BLOCK_COMMENT="OFF"
340
  BLOCK_COMMENT="OFF"
335
  cat $1 | while read DEF_LINE; do
341
  cat $1 | while read DEF_LINE; do
336
 
342
 
337
    #DOS only: DEF_FILE=`echo "${DEF_LINE}" | grep -wE "^include" | sed s/include\ //`
343
    #DOS only: DEF_FILE=`echo "${DEF_LINE}" | grep -wE "^include" | sed s/include\ //`
338
    DEF_FILE=`echo "${DEF_LINE}" | grep -wE "^include" | sed s/include\ // | sed s/\\\r//`
344
    DEF_FILE=`echo "${DEF_LINE}" | grep -wE "^include" | sed s/include\ // | sed s/\\\r//`
339
    if [ "${DEF_FILE}" != "" ] ; then
345
    if [ "${DEF_FILE}" != "" ] ; then
340
      cp -p      "${DEF_FILE}" "${EXTRACTDIR}/${DEF_FILE}"
346
      cp -p      "${DEF_FILE}" "${EXTRACTDIR}/${DEF_FILE}"
341
      parse_defs "${DEF_FILE}"
347
      parse_defs "${DEF_FILE}"
342
    fi
348
    fi
343
 
349
 
344
    HRP_TERM=`echo "${DEF_LINE}" | grep -owE "file|model|front|right|back|left|top|down"`
350
    HRP_TERM=`echo "${DEF_LINE}" | grep -owE "file|model|front|right|back|left|top|down"`
345
 
351
 
346
    if [ ! "$EXTRACT_COMMENTED_FILES" = "YES" ] ; then
352
    if [ ! "$EXTRACT_COMMENTED_FILES" = "YES" ] ; then
347
 
353
 
348
      COMMENT_TERM=`echo "${DEF_LINE}" | grep -oE "\\/\\*|\\*\\/"`
354
      COMMENT_TERM=`echo "${DEF_LINE}" | grep -oE "\\/\\*|\\*\\/"`
349
      if [ "$COMMENT_TERM"  = "/*" ] ; then BLOCK_COMMENT="ON" ; fi
355
      if [ "$COMMENT_TERM"  = "/*" ] ; then BLOCK_COMMENT="ON" ; fi
350
 
356
 
351
      if [ "$BLOCK_COMMENT" = "ON" ] ; then HRP_TERM="" ; fi
357
      if [ "$BLOCK_COMMENT" = "ON" ] ; then HRP_TERM="" ; fi
352
 
358
 
353
      if [ "$COMMENT_TERM"  = "*/" ] ; then BLOCK_COMMENT="OFF" ; fi
359
      if [ "$COMMENT_TERM"  = "*/" ] ; then BLOCK_COMMENT="OFF" ; fi
354
 
360
 
355
      if [ ! "$HRP_TERM" = "" ] ; then
361
      if [ ! "$HRP_TERM" = "" ] ; then
356
        HRP_COMMENT=`echo "${DEF_LINE}" | grep -E "//.*$HRP_TERM"`
362
        HRP_COMMENT=`echo "${DEF_LINE}" | grep -E "//.*$HRP_TERM"`
357
        if [ ! "$HRP_COMMENT" = "" ] ; then
363
        if [ ! "$HRP_COMMENT" = "" ] ; then
358
          HRP_TERM=""
364
          HRP_TERM=""
359
        fi
365
        fi
360
      fi
366
      fi
361
 
367
 
362
    fi
368
    fi
363
 
369
 
364
    case "$HRP_TERM" in
370
    case "$HRP_TERM" in
365
      file)
371
      file)
366
        #HRP_FILE=`echo "${DEF_LINE}" | sed -r s/^.*file\ *\"//g | sed s/\".*//`
372
        #HRP_FILE=`echo "${DEF_LINE}" | sed -r s/^.*file\ *\"//g | sed s/\".*//`
367
        # Mastering the backslash :-) ... hm, no big performance gain ... :
373
        # Mastering the backslash :-) ... hm, no big performance gain ... :
368
        HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*file\\ *\"\\)\\([^\"]*\\)\\(.*\\)/\\\2/`
374
        HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*file\\ *\"\\)\\([^\"]*\\)\\(.*\\)/\\\2/`
369
        # Ignore comments WIP:
375
        # Ignore comments WIP:
370
        #HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*file\\ *\\)\\(\\"\\(.*\\)\\"\\)\\(.*\\)/\\\3/`
376
        #HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*file\\ *\\)\\(\\"\\(.*\\)\\"\\)\\(.*\\)/\\\3/`
371
        ;;
377
        ;;
372
      model)
378
      model)
373
        HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*model\\ *\"\\)\\([^\"]*\\)\\(.*\\)/\\\2/`
379
        HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*model\\ *\"\\)\\([^\"]*\\)\\(.*\\)/\\\2/`
374
        ;;
380
        ;;
375
      front|right|back|left|top|down)
381
      front|right|back|left|top|down)
376
        #HRP_FILE=`echo "${DEF_LINE}" | sed -r s/^.*${HRP_TERM}\ *\"//g | sed s/\".*//`
382
        #HRP_FILE=`echo "${DEF_LINE}" | sed -r s/^.*${HRP_TERM}\ *\"//g | sed s/\".*//`
377
        HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*${HRP_TERM}\\ *\"\\)\\([^\"]*\\)\\(.*\\)/\\\2/`
383
        HRP_FILE=`echo "${DEF_LINE}" | sed -r --posix s/\\(^.*${HRP_TERM}\\ *\"\\)\\([^\"]*\\)\\(.*\\)/\\\2/`
378
        ;;
384
        ;;
379
      *)
385
      *)
380
        HRP_FILE=""
386
        HRP_FILE=""
381
        ;;
387
        ;;
382
    esac
388
    esac
383
 
389
 
384
    if [  !   "${HRP_FILE}" = "" ] ; then
390
    if [  !   "${HRP_FILE}" = "" ] ; then
385
      if [ -f "${HRP_FILE}" ] ; then
391
      if [ -f "${HRP_FILE}" ] ; then
386
        cp -p "${HRP_FILE}" "${EXTRACTDIR}/${HRP_FILE}"
392
        cp -p "${HRP_FILE}" "${EXTRACTDIR}/${HRP_FILE}"
387
      else
393
      else
388
        echo  "WARNING : ${HRP_FILE} is missing!"
394
        echo  "WARNING : ${HRP_FILE} is missing!"
389
      fi
395
      fi
390
    fi
396
    fi
391
 
397
 
392
  done
398
  done
393
} # parse_defs()
399
} # parse_defs()
394
 
400
 
395
 
401
 
396
delete_empty_folders()
402
delete_empty_folders()
397
{
403
{
398
    if [ -d "${EXTRACTDIR}" ] ; then
404
    if [ -d "${EXTRACTDIR}" ] ; then
399
      rm -rf ${EXTRACTDIR}/.svn
405
      rm -rf ${EXTRACTDIR}/.svn
400
      rm -rf ${EXTRACTDIR}/installer
406
      rm -rf ${EXTRACTDIR}/installer
401
      DIRLIST=./EXTRACT_DIRECTORIES.lst
407
      DIRLIST=./EXTRACT_DIRECTORIES.lst
402
      du "${EXTRACTDIR}" > ${DIRLIST}
408
      du "${EXTRACTDIR}" > ${DIRLIST}
403
      cat ${DIRLIST} | while read DIR ; do
409
      cat ${DIRLIST} | while read DIR ; do
404
        if [ "0" = "`echo \"${DIR}\" | grep -owE \"0\"`" ] ; then
410
        if [ "0" = "`echo \"${DIR}\" | grep -owE \"0\"`" ] ; then
405
          EMPTYDIR="`echo \"${DIR}\" | sed -r --posix s/0//`"
411
          EMPTYDIR="`echo \"${DIR}\" | sed -r --posix s/0//`"
406
          if [ -d ${EMPTYDIR} ] ; then
412
          if [ -d ${EMPTYDIR} ] ; then
407
            rmdir ${EMPTYDIR}
413
            rmdir ${EMPTYDIR}
408
          fi
414
          fi
409
        fi
415
        fi
410
      done
416
      done
411
      rm ${DIRLIST}
417
      rm ${DIRLIST}
412
    else
418
    else
413
      echo "No ${EXTRACTDIR}."
419
      echo "No ${EXTRACTDIR}."
414
    fi
420
    fi
415
} # delete_empty_folders()
421
} # delete_empty_folders()
416
 
422
 
417
 
423
 
418
main()
424
main()
419
{
425
{
420
  EXTRACTDIR=../hrp_${HRPTYPE}_extract
426
  EXTRACTDIR=../hrp_${HRPTYPE}_extract
421
  echo  "EXTRACT :" ${HRPROOT}/${EXTRACTDIR}
427
  echo  "EXTRACT :" ${HRPROOT}/${EXTRACTDIR}
422
 
428
 
423
  if [ $FORCE = 0 ] ; then
429
  if [ $FORCE = 0 ] ; then
424
    if ask "Proceed?"
430
    if ask "Proceed?"
425
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
431
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
426
      else exit 0
432
      else exit 0
427
    fi
433
    fi
428
  fi
434
  fi
429
 
435
 
430
  date +%F" "%H:%M:%S
436
  date +%F" "%H:%M:%S
431
 
437
 
432
  echo "### Deleting ${EXTRACTDIR} ... ###"
438
  echo "### Deleting ${EXTRACTDIR} ... ###"
433
  rm -rf ${EXTRACTDIR}
439
  rm -rf ${EXTRACTDIR}
434
 
440
 
435
  echo "### Copying directory tree ... ###"
441
  echo "### Copying directory tree ... ###"
436
  copy_folders
442
  copy_folders
437
 
443
 
438
  echo "### Copying 'known' files ... ###"
444
  echo "### Copying 'known' files ... ###"
439
  copy_known_files
445
  copy_known_files
440
 
446
 
441
  if [ "${HRPTYPE}" = "polymost" ] || [ "${HRPTYPE}" = "polymost_override" ] ; then
447
  if [ "${HRPTYPE}" = "polymost" ] || [ "${HRPTYPE}" = "polymost_override" ] ; then
442
    echo "### Creating Polymost maphacks ... ###"
448
    echo "### Creating Polymost maphacks ... ###"
443
    create_polymost_mhk
449
    create_polymost_mhk
444
 
450
 
445
    #echo "### DukePlus<>Polymost HRP compatibility patch ... ###"
451
    #echo "### DukePlus<>Polymost HRP compatibility patch ... ###"
446
    #dukeplus_polymost_compatibility $DUKEPLUS_POLYMOST_COMPATIBILTY_APPROACH
452
    #dukeplus_polymost_compatibility $DUKEPLUS_POLYMOST_COMPATIBILTY_APPROACH
447
  fi
453
  fi
448
 
454
 
449
  echo "### Parsing DEF file hierarchy ... ###"
455
  echo "### Parsing DEF file hierarchy ... ###"
450
  if [ "$EXTRACT_COMMENTED_FILES" = "YES" ] ; then
456
  if [ "$EXTRACT_COMMENTED_FILES" = "YES" ] ; then
451
    echo "  # Extract commented textures and models: $EXTRACT_COMMENTED_FILES"
457
    echo "  # Extract commented textures and models: $EXTRACT_COMMENTED_FILES"
452
  else
458
  else
453
    echo "  # Extract commented textures and models: NO"
459
    echo "  # Extract commented textures and models: NO"
454
  fi
460
  fi
455
  if [ "${HRPTYPE}" = "polymost" ] || [ "${HRPTYPE}" = "full" ] ; then
461
  if [ "${HRPTYPE}" = "polymost" ] || [ "${HRPTYPE}" = "full" ] ; then
456
    parse_defs duke3d_hrp_polymost.def
462
    parse_defs duke3d_hrp_polymost.def
457
  fi
463
  fi
458
  if [ "${HRPTYPE}" = "polymer" ] || [ "${HRPTYPE}" = "full" ] ; then
464
  if [ "${HRPTYPE}" = "polymer" ] || [ "${HRPTYPE}" = "full" ] ; then
459
    parse_defs duke3d_hrp.def
465
    parse_defs duke3d_hrp.def
460
  fi
466
  fi
461
 
467
 
462
  echo "### Deleting empty directories in ${EXTRACTDIR} ... ###"
468
  echo "### Deleting empty directories in ${EXTRACTDIR} ... ###"
463
  delete_empty_folders
469
  delete_empty_folders
464
 
470
 
465
  date +%F" "%H:%M:%S
471
  date +%F" "%H:%M:%S
466
 
472
 
467
  echo "Command line example for creating a ZIP package:"
473
  echo "Command line example for creating a ZIP package:"
468
  echo "sh -c \"cd ${EXTRACTDIR} ; zip -rqn .zip:.jpg:.png ${EXTRACTDIR}.zip *\""
474
  echo "sh -c \"cd ${EXTRACTDIR} ; zip -rqn .zip:.jpg:.png ${EXTRACTDIR}.zip *\""
469
} # main()
475
} # main()
470
 
476
 
471
 
477
 
472
 
478
 
473
PRGPATH=$0
479
PRGPATH=$0
474
HRPTYPE=$1
480
HRPTYPE=$1
475
if [ "$2" = "y" ] ; then FORCE=1 ; else FORCE=0 ; fi
481
if [ "$2" = "y" ] ; then FORCE=1 ; else FORCE=0 ; fi
476
if [ "$2" = "v" ] && [ ! "$3" = "" ] ; then VERSION="$3" ; fi
482
if [ "$2" = "v" ] && [ ! "$3" = "" ] ; then
-
 
483
  VERSION="$3"
-
 
484
  echo "${VERSION}" > VERSION
-
 
485
fi
477
HRPROOT=.
486
HRPROOT=.
478
 
487
 
479
cd               "${HRPROOT}"
488
cd               "${HRPROOT}"
480
echo  "PWD     :" `pwd`
489
echo  "PWD     :" `pwd`
481
echo  "HRPROOT :" ${HRPROOT}
490
echo  "HRPROOT :" ${HRPROOT}
482
 
491
 
483
if [ ! -f "./duke3d.def" ] ; then
492
if [ ! -f "./duke3d.def" ] ; then
484
  echo "ERROR : ./duke3d.def not found. This is no HRP root directory. Exit."
493
  echo "ERROR : ./duke3d.def not found. This is no HRP root directory. Exit."
485
  exit 1
494
  exit 1
486
fi
495
fi
487
 
496
 
488
case "$HRPTYPE" in
497
case "$HRPTYPE" in
489
  polymer|polymost_override|polymost)
498
  polymer|polymost_override|polymost)
490
    main $HRPTYPE
499
    main $HRPTYPE
491
    ;;
500
    ;;
492
  full)
501
  full)
493
    if [ $FORCE = 0 ] ; then if ask "Extract full HRP (+ Override Pack)?"
502
    if [ $FORCE = 0 ] ; then if ask "Extract full HRP (+ Override Pack)?"
494
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
503
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
495
      else exit 0
504
      else exit 0
496
    fi ; fi
505
    fi ; fi
497
    ${PRGPATH} polymost_override y
506
    ${PRGPATH} polymost_override y
498
    main $HRPTYPE
507
    main $HRPTYPE
499
    ;;
508
    ;;
500
  both)
509
  both)
501
    if [ $FORCE = 0 ] ; then if ask "Extract both pure HRP?"
510
    if [ $FORCE = 0 ] ; then if ask "Extract both pure HRP?"
502
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
511
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
503
      else exit 0
512
      else exit 0
504
    fi ; fi
513
    fi ; fi
505
    ${PRGPATH} polymer  y
514
    ${PRGPATH} polymer  y
506
    ${PRGPATH} polymost y
515
    ${PRGPATH} polymost y
507
    ;;
516
    ;;
508
  all)
517
  all)
509
    if [ $FORCE = 0 ] ; then if ask "Extract all packs from the repository?"
518
    if [ $FORCE = 0 ] ; then if ask "Extract all packs from the repository?"
510
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
519
      then echo "Extracting ${HRPTYPE} from \"${HRPROOT}\" "
511
      else exit 0
520
      else exit 0
512
    fi ; fi
521
    fi ; fi
513
    ${PRGPATH} both y
522
    ${PRGPATH} both y
514
    ${PRGPATH} full y
523
    ${PRGPATH} full y
515
    ;;
524
    ;;
516
  unused)
525
  unused)
517
    echo "Option \"$1\" not yet implemented."
526
    echo "Option \"$1\" not yet implemented."
518
    ##(cd ${1}; tar cf - . ) | (cd ${2}; tar xf -)
527
    ##(cd ${1}; tar cf - . ) | (cd ${2}; tar xf -)
519
    ;;
528
    ;;
520
  debug)
529
  debug)
521
    echo "Nothing to debug."
530
    echo "Nothing to debug."
522
    ;;
531
    ;;
523
  *)
532
  *)
524
    echo "Usage: ${0} {full|polymer|polymost_override|polymost|both|all} [v VERSION]"
533
    echo "Usage: ${0} {full|polymer|polymost_override|polymost|both|all} [v VERSION]"
525
    exit 1
534
    exit 1
526
    ;;
535
    ;;
527
esac
536
esac
528
 
537
 
529
exit 0
538
exit 0
530
 
539