mirror of
https://github.com/freedoom/freedoom.git
synced 2025-09-01 13:25:46 -04:00
Move scripts that are part of the build system into scripts/.
This commit is contained in:
parent
ece77ca176
commit
5f299ad776
5 changed files with 10 additions and 10 deletions
73
scripts/extract-pnames.py
Executable file
73
scripts/extract-pnames.py
Executable file
|
@ -0,0 +1,73 @@
|
|||
#!/usr/bin/env python
|
||||
#
|
||||
# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
||||
# Contributors to the Freedoom project. All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * 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.
|
||||
# * Neither the name of the freedoom project 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.
|
||||
|
||||
import os
|
||||
import sys
|
||||
import re
|
||||
import glob
|
||||
|
||||
texture_re = re.compile(r'\*\s+(\w+)')
|
||||
|
||||
# Parse a TEXTURE1 file and generate a list of patches
|
||||
|
||||
def parse_texture_file():
|
||||
patches = {}
|
||||
|
||||
for line in sys.stdin:
|
||||
match = texture_re.match(line)
|
||||
|
||||
if match:
|
||||
name = match.group(1)
|
||||
|
||||
patches[name] = True
|
||||
|
||||
print "; autogenerated patch list\n"
|
||||
|
||||
for name in sorted(patches.keys()):
|
||||
print name
|
||||
|
||||
# Generate a full list of textures from the files in the
|
||||
# patches/ directory
|
||||
|
||||
def list_all_textures():
|
||||
print "; autogenerated patch list\n"
|
||||
|
||||
for filename in sorted(glob.glob("patches/*.gif")):
|
||||
base = os.path.basename(filename)
|
||||
patch_name = base[0:-4]
|
||||
print patch_name
|
||||
|
||||
if len(sys.argv) == 1:
|
||||
parse_texture_file()
|
||||
elif sys.argv[1] == "-a":
|
||||
list_all_textures()
|
||||
else:
|
||||
print "Usage: extract-pnames.pl [-a]"
|
||||
|
109
scripts/makepkgs
Executable file
109
scripts/makepkgs
Executable file
|
@ -0,0 +1,109 @@
|
|||
#!/usr/bin/env python
|
||||
#
|
||||
# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
||||
# Contributors to the Freedoom project. All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * 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.
|
||||
# * Neither the name of the freedoom project 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.
|
||||
|
||||
import os
|
||||
import sys
|
||||
|
||||
# Documentation files included with distributions.
|
||||
|
||||
DIST_DOCS = [
|
||||
"NEWS",
|
||||
"ChangeLog",
|
||||
"COPYING",
|
||||
"CREDITS",
|
||||
"README"
|
||||
]
|
||||
|
||||
# Most WADs are given a ZIP equal to their name, but some have different
|
||||
# names:
|
||||
|
||||
DIR_NAMES = {
|
||||
'doom2' : 'freedoom-iwad',
|
||||
'doom1' : 'freedoom-demo',
|
||||
'doom' : 'freedoom-episodes',
|
||||
'freedoom' : 'freedoom-resource-wad',
|
||||
}
|
||||
|
||||
# Run a command, displaying it before executing it.
|
||||
|
||||
def run_command(command):
|
||||
print "> " + command
|
||||
os.system(command)
|
||||
|
||||
# Find the version to build:
|
||||
|
||||
version = os.getenv("VERSION")
|
||||
|
||||
if version is None:
|
||||
raise Exception("Version not specified for release!")
|
||||
|
||||
# Build all of the packages
|
||||
|
||||
for filename in sys.argv[1:]:
|
||||
|
||||
path = os.path.dirname(filename)
|
||||
basename = os.path.basename(filename)
|
||||
|
||||
# Cut off the extension, and build the directory name
|
||||
|
||||
pkgname = basename[0:-4]
|
||||
|
||||
if pkgname in DIR_NAMES:
|
||||
base_dir = DIR_NAMES[pkgname]
|
||||
else:
|
||||
base_dir = pkgname
|
||||
|
||||
# Append the version:
|
||||
|
||||
base_dir += "-" + version
|
||||
|
||||
# Replace underscores with hyphens:
|
||||
|
||||
base_dir = base_dir.replace("_", "-")
|
||||
|
||||
full_path = path + "/" + base_dir
|
||||
|
||||
# Create directory, and add files.
|
||||
|
||||
run_command("mkdir %s" % full_path)
|
||||
|
||||
for doc in DIST_DOCS + [ filename ]:
|
||||
run_command("cp %s %s" % (doc, full_path))
|
||||
|
||||
# Change to the parent directory, and build the zip
|
||||
|
||||
orig_dir = os.getcwd()
|
||||
|
||||
os.chdir(path)
|
||||
run_command("rm -f %s.zip" % base_dir)
|
||||
run_command("zip -r %s.zip %s" % (base_dir, base_dir))
|
||||
run_command("rm -rf %s" % base_dir)
|
||||
os.chdir(orig_dir)
|
||||
|
106
scripts/sanity-check.py
Executable file
106
scripts/sanity-check.py
Executable file
|
@ -0,0 +1,106 @@
|
|||
#!/usr/bin/env python
|
||||
#
|
||||
# perform sanity check on assignments lists; make sure everything in
|
||||
# the deutex tree is listed in the assignment lists
|
||||
#
|
||||
# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
|
||||
# Contributors to the Freedoom project. All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * 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.
|
||||
# * Neither the name of the freedoom project 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.
|
||||
|
||||
import glob
|
||||
import re
|
||||
import sys
|
||||
|
||||
# Find the file matching the given lump name:
|
||||
|
||||
def find_file(dirname, lumpname):
|
||||
|
||||
if dirname == "musics":
|
||||
lumpname = "d_" + lumpname
|
||||
|
||||
files = glob.glob("%s/%s*" % (dirname, lumpname))
|
||||
|
||||
if len(files) > 0:
|
||||
return files[0]
|
||||
else:
|
||||
return None
|
||||
|
||||
# Perform sanity check on the given directory:
|
||||
|
||||
def sanity_check(dirname, filename):
|
||||
|
||||
print "Checking %s" % dirname
|
||||
|
||||
f = file(filename)
|
||||
|
||||
for line in f:
|
||||
|
||||
# Strip newline
|
||||
|
||||
line = line[0:len(line)-1]
|
||||
|
||||
# Ignore comments and empty lines
|
||||
|
||||
if line == " " * len(line) or line[0] == "#":
|
||||
continue
|
||||
|
||||
match = re.match(r'(\w+)', line)
|
||||
|
||||
resource = match.group(1)
|
||||
|
||||
# Find the file for this lump, if it exists
|
||||
|
||||
filename = find_file(dirname, resource)
|
||||
|
||||
# Is this resource supposed to be present? Check this
|
||||
# matches what is present.
|
||||
|
||||
if re.search(r"(done|in dev)", line):
|
||||
if filename is None:
|
||||
print "%s: files not found for %s" % \
|
||||
(dirname, resource)
|
||||
else:
|
||||
if filename is None:
|
||||
print "%s: files found for %s" % \
|
||||
(dirname, resource)
|
||||
|
||||
f.close()
|
||||
|
||||
status_dir = "status"
|
||||
|
||||
sections = {
|
||||
"sprites" : "sprites_list",
|
||||
"patches" : "patches_list",
|
||||
"flats" : "flats_list",
|
||||
"graphics" : "graphics_list",
|
||||
"sounds" : "sounds_list",
|
||||
"musics" : "musics_list",
|
||||
}
|
||||
|
||||
for section in sections.keys():
|
||||
sanity_check(section, "%s/%s" % (status_dir, sections[section]))
|
||||
|
188
scripts/wadinfo-builder.py
Executable file
188
scripts/wadinfo-builder.py
Executable file
|
@ -0,0 +1,188 @@
|
|||
#!/usr/bin/env python
|
||||
#
|
||||
# Wadinfo builder, rewritten in Python :)
|
||||
#
|
||||
# Copyright (c) 2006 Simon Howard. All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted provided that the following conditions are
|
||||
# met:
|
||||
#
|
||||
# * Redistributions of source code must retain the above copyright
|
||||
# notice, this list of conditions and the following disclaimer.
|
||||
# * 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.
|
||||
# * Neither the name of Simon Howard 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.
|
||||
|
||||
import glob
|
||||
import os
|
||||
import sys
|
||||
import re
|
||||
|
||||
dummy = False
|
||||
|
||||
# Given a file name, get the resource name for it:
|
||||
|
||||
def resource_for_filename(filename):
|
||||
if "." in filename:
|
||||
return filename[0:filename.index(".")]
|
||||
else:
|
||||
return filename
|
||||
|
||||
# Build look-up table, mapping section and resource name to filename.
|
||||
|
||||
def build_lookup_table():
|
||||
result = {}
|
||||
|
||||
for filename in glob.glob("*/*"):
|
||||
section = os.path.dirname(filename)
|
||||
basename = os.path.basename(filename)
|
||||
|
||||
resource = resource_for_filename(basename)
|
||||
|
||||
result[(section, resource)] = filename
|
||||
|
||||
return result
|
||||
|
||||
# Given a file base name, eg. "HEADE5", find the file to be used for
|
||||
# that resource. If the file cannot be found, None is returned.
|
||||
|
||||
def find_file(section, name):
|
||||
key = (section, name)
|
||||
|
||||
if key in file_lut:
|
||||
return file_lut[key]
|
||||
else:
|
||||
return None
|
||||
|
||||
# Warning header displayed at the top of an output file.
|
||||
|
||||
def print_warning_header():
|
||||
print "; This file is automatically generated."
|
||||
print "; Do not edit it directly!"
|
||||
print
|
||||
|
||||
# Remove comments beginning with "#" or ";"
|
||||
|
||||
def remove_comments(text):
|
||||
if "#" in text:
|
||||
return text[0:text.index("#")]
|
||||
elif ";" in text:
|
||||
return text[0:text.index(";")]
|
||||
else:
|
||||
return text
|
||||
|
||||
# Get the name of a dummy lump to use as a stand-in for the
|
||||
# given resource.
|
||||
|
||||
def get_dummy_name(resource):
|
||||
if resource.lower().startswith("demo"):
|
||||
return "fakedemo"
|
||||
else:
|
||||
return "dummy"
|
||||
|
||||
# Parse an assignment statement.
|
||||
|
||||
def parse_assignment(section, line, match):
|
||||
resource = match.group(1).lower()
|
||||
override = match.group(3)
|
||||
|
||||
# allow "= filename.ext" to override the filename used
|
||||
|
||||
if override is not None:
|
||||
filename = find_file(section, override)
|
||||
else:
|
||||
filename = find_file(section, resource)
|
||||
|
||||
# File not found?
|
||||
|
||||
if filename is None:
|
||||
|
||||
# This resource hasn't been submitted yet, so either
|
||||
# comment the line out, or use a dummy resource,
|
||||
# depending on configuration.
|
||||
|
||||
if dummy:
|
||||
dummy_name = get_dummy_name(resource)
|
||||
|
||||
result = "%s = %s" % (resource, dummy_name)
|
||||
else:
|
||||
result = "; " + line
|
||||
else:
|
||||
# Resource found.
|
||||
|
||||
result = line
|
||||
|
||||
return result
|
||||
|
||||
# Parse data from the given input stream.
|
||||
|
||||
def parse_stream(stream):
|
||||
|
||||
section_re = re.compile(r'\[(.*)\]')
|
||||
assignment_re = re.compile(r'\s*(\S+)[^\=]*(\s*\=\s*(\S+))?')
|
||||
|
||||
print_warning_header()
|
||||
|
||||
section = None
|
||||
|
||||
# Parse each line of the input file, possibly changing things as we go.
|
||||
|
||||
for line in stream:
|
||||
|
||||
# Strip newline
|
||||
|
||||
line = line[0:len(line) - 1]
|
||||
|
||||
# Remove comments
|
||||
|
||||
line = remove_comments(line)
|
||||
|
||||
# start of new section?
|
||||
|
||||
match = section_re.search(line)
|
||||
|
||||
if match:
|
||||
section = match.group(1)
|
||||
|
||||
if section == "texture1" or section == "texture2":
|
||||
section = "textures"
|
||||
|
||||
# Possibly comment out assignments.
|
||||
|
||||
match = assignment_re.match(line)
|
||||
|
||||
if match:
|
||||
line = parse_assignment(section, line, match)
|
||||
|
||||
print line
|
||||
|
||||
# Parse command line options:
|
||||
|
||||
for arg in sys.argv:
|
||||
if arg == "-dummy":
|
||||
dummy = True
|
||||
|
||||
# Build look-up table for files:
|
||||
|
||||
file_lut = build_lookup_table()
|
||||
|
||||
# Parse the input stream:
|
||||
|
||||
parse_stream(sys.stdin)
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue