diff options
Diffstat (limited to 'contrib')
35 files changed, 1529 insertions, 3205 deletions
| diff --git a/contrib/Makefile.am b/contrib/Makefile.am new file mode 100644 index 00000000000..d89f48418db --- /dev/null +++ b/contrib/Makefile.am @@ -0,0 +1,25 @@ +# Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/> +# +# Copyright (C) 2008-2009 Trinity <http://www.trinitycore.org/> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA + +## Process this file with automake to produce Makefile.in + +## Sub-directories to parse +SUBDIRS = extractor + +## Additional files to include when running 'make dist' +#  Nothing yet. diff --git a/contrib/extractor/CMakeLists.txt b/contrib/extractor/CMakeLists.txt new file mode 100644 index 00000000000..9052903b1ed --- /dev/null +++ b/contrib/extractor/CMakeLists.txt @@ -0,0 +1,26 @@ +# Copyright (C) 2005-2009 MaNGOS project <http://getmangos.com/> +# +# This file is free software; as a special exception the author gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY, to the extent permitted by law; without even the +# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +cmake_minimum_required (VERSION 2.6) +project (MANGOS_MAP_EXTRACTOR) + +add_subdirectory (libmpq) +add_subdirectory (loadlib) + +include_directories (${MANGOS_MAP_EXTRACTOR_SOURCE_DIR}/libmpq)  +include_directories (${MANGOS_MAP_EXTRACTOR_SOURCE_DIR}/loadlib)  + +link_directories (${MANGOS_MAP_EXTRACTOR_SOURCE_DIR}/libmpq)  +link_directories (${MANGOS_MAP_EXTRACTOR_SOURCE_DIR}/loadlib)  + +add_executable (ad dbcfile.cpp mpq_libmpq.cpp System.cpp) + +target_link_libraries (ad libmpq) +target_link_libraries (ad loadlib) diff --git a/contrib/extractor/Makefile b/contrib/extractor/Makefile deleted file mode 100644 index 55eb35f336a..00000000000 --- a/contrib/extractor/Makefile +++ /dev/null @@ -1,471 +0,0 @@ -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005  Free Software Foundation, Inc. -# This Makefile.in is free software; the Free Software Foundation -# gives unlimited permission to copy and/or distribute it, -# with or without modifications, as long as this notice is preserved. - -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. - - -# Copyright (C) 2008 Trinity <http://www.trinitycore.org/> -# -# Thanks to the original authors: MaNGOS <http://www.mangosproject.org/> -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA - -SOURCES = $(ad_SOURCES) - -srcdir = . -top_srcdir = . - -pkgdatadir = $(datadir)/mangos -pkglibdir = $(libdir)/mangos -pkgincludedir = $(includedir)/mangos -top_builddir = ../.. -am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -INSTALL = /usr/bin/ginstall -c -install_sh_DATA = $(install_sh) -c -m 644 -install_sh_PROGRAM = $(install_sh) -c -install_sh_SCRIPT = $(install_sh) -c -INSTALL_HEADER = $(INSTALL_DATA) -transform = $(program_transform_name) -NORMAL_INSTALL = : -PRE_INSTALL = : -POST_INSTALL = : -NORMAL_UNINSTALL = : -PRE_UNINSTALL = : -POST_UNINSTALL = : -build_triplet = i686-pc-linux-gnu -host_triplet = i686-pc-linux-gnu -bin_PROGRAMS = ad$(EXEEXT) -subdir = contrib/extractor -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in -ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -am__aclocal_m4_deps = $(top_srcdir)/configure.ac -am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ -	$(ACLOCAL_M4) -mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs -CONFIG_HEADER = $(top_builddir)/config.h -CONFIG_CLEAN_FILES = -am__installdirs = "$(DESTDIR)$(bindir)" -binPROGRAMS_INSTALL = $(INSTALL_PROGRAM) -PROGRAMS = $(bin_PROGRAMS) -am_ad_OBJECTS = System.$(OBJEXT) adt.$(OBJEXT) dbcfile.$(OBJEXT) \ -		mpq_libmpq.$(OBJEXT)	 -ad_OBJECTS = $(am_ad_OBJECTS) -ad_DEPENDENCIES = -DEFAULT_INCLUDES = -I. -I$(srcdir) -I$(top_builddir) -depcomp = $(SHELL) $(top_srcdir)/depcomp -am__depfiles_maybe = depfiles -CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ -	$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -LTCXXCOMPILE = $(LIBTOOL) --tag=CXX --mode=compile $(CXX) $(DEFS) \ -	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ -	$(AM_CXXFLAGS) $(CXXFLAGS) -CXXLD = $(CXX) -CXXLINK = $(LIBTOOL) --tag=CXX --mode=link $(CXXLD) $(AM_CXXFLAGS) \ -	$(CXXFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ -COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ -	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -LTCOMPILE = $(LIBTOOL) --tag=CC --mode=compile $(CC) $(DEFS) \ -	$(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ -	$(AM_CFLAGS) $(CFLAGS) -CCLD = $(CC) -LINK = $(LIBTOOL) --tag=CC --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ -	$(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(ad_SOURCES) -DIST_SOURCES = $(ad_SOURCES) -ETAGS = etags -CTAGS = ctags -DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -ACLOCAL = -ALLOCA =  -AMDEP_FALSE = # -AMDEP_TRUE =  -AMTAR = ${SHELL} /home/wow/MaNGOS/trunk/missing --run tar -AR = ar -AUTOCONF = ${SHELL} /home/wow/MaNGOS/trunk/missing --run autoconf -AUTOHEADER = ${SHELL} /home/wow/MaNGOS/trunk/missing --run autoheader -AUTOMAKE = ${SHELL} /home/wow/MaNGOS/trunk/missing --run automake-1.9 -AWK = gawk -CC = gcc -CCDEPMODE = depmode=gcc3 -CFLAGS = -g -O3 -COMPILER_OPTIONS = -g -O3 -CPP = gcc -E -CPPFLAGS =  -CXX = g++ -CXXCPP = g++ -E -CXXDEPMODE = depmode=gcc3 -CXXFLAGS = -g -O3 -CYGPATH_W = echo -DEFS = -DHAVE_CONFIG_H -DEPDIR = .deps -ECHO = echo -ECHO_C =  -ECHO_N = -n -ECHO_T =  -EGREP = grep -E -EXEEXT =  -EXTRA_COMPILER_OPTIONS =  -EXTRA_LINKER_OPTIONS =  -F77 =  -FFLAGS =  -INCLUDES = -I$(srcdir) -INSTALL_DATA = ${INSTALL} -m 644 -INSTALL_PROGRAM = ${INSTALL} -INSTALL_SCRIPT = ${INSTALL} -INSTALL_STRIP_PROGRAM = ${SHELL} $(install_sh) -c -s -LDFLAGS =  -LIBOBJS =  -LIBS = -lz -lpthread  -LIBTOOL = $(SHELL) $(top_builddir)/libtool -LINKER_OPTIONS = -static -LN_S = ln -s -LTLIBOBJS =  -LT_AGE = 2 -LT_CURRENT = 2 -LT_RELEASE = 2.3.2 -LT_REVISION = 3 -MAINT = # -MAINTAINER_MODE_FALSE =  -MAINTAINER_MODE_TRUE = # -MAKEINFO =  -MANGOSD_CONFIG = /home/wow/server/etc/mangosd.conf -MANGOSD_CONFIGDIR = /home/wow/server/etc -MANGOSD_DATA = /home/wow/server/share/mangos -OBJEXT = o -PACKAGE = mangos -PACKAGE_BUGREPORT = http://www.mangosproject.org/ -PACKAGE_NAME = MaNGOS -PACKAGE_STRING = MaNGOS 0.2-SVN -PACKAGE_TARNAME = mangos -PACKAGE_VERSION = 0.2-SVN -PATH_SEPARATOR = : -RANLIB = ranlib -SET_MAKE =  -SHELL = /bin/sh -STRIP = strip -VERSION = 0.2-SVN -ac_ct_AR = ar -ac_ct_CC = gcc -ac_ct_CXX = g++ -ac_ct_F77 =  -ac_ct_RANLIB = ranlib -ac_ct_STRIP = strip -am__fastdepCC_FALSE = # -am__fastdepCC_TRUE =  -am__fastdepCXX_FALSE = # -am__fastdepCXX_TRUE =  -am__include = include -am__leading_dot = . -am__quote =  -am__tar = ${AMTAR} chof - "$$tardir" -am__untar = ${AMTAR} xf - -bindir = ${exec_prefix}/bin -build = i686-pc-linux-gnu -build_alias =  -build_cpu = i686 -build_os = linux-gnu -build_vendor = pc -datadir = ${prefix}/share -exec_prefix = ${prefix} -host = i686-pc-linux-gnu -host_alias =  -host_cpu = i686 -host_os = linux-gnu -host_vendor = pc -includedir = ${prefix}/include -infodir = ${prefix}/info -install_sh = /home/wow/MaNGOS/trunk/install-sh -libdir = ${exec_prefix}/lib -libexecdir = ${exec_prefix}/libexec -localstatedir = ${prefix}/var -mandir = ${prefix}/man -mkdir_p = mkdir -p -- -oldincludedir = /usr/include -prefix = /home/wow/server -program_transform_name = s,x,x, -sbindir = ${exec_prefix}/sbin -sharedstatedir = ${prefix}/com - -# use our configured sysconfdir -sysconfdir = /home/wow/server/etc -target_alias =  -ad_SOURCES = \ -    System.cpp \ -    adt.h \ -    adt.cpp \ -    dbcfile.cpp \ -    dbcfile.h \ -    mpq_libmpq.cpp \ -    mpq_libmpq.h - -ad_LDADD = libmpq/libmpq.a -add_LDFLAGS = -L$(srcdir) -L$(srcdir)/libmpq - -all: create-dir all-am - -.SUFFIXES: -.SUFFIXES: .cpp .lo .o .obj - -.PRECIOUS: Makefile - -install-binPROGRAMS: $(bin_PROGRAMS) -	@$(NORMAL_INSTALL) -	test -z "$(bindir)" || $(mkdir_p) "$(DESTDIR)$(bindir)" -	@list='$(bin_PROGRAMS)'; for p in $$list; do \ -	  p1=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ -	  if test -f $$p \ -	     || test -f $$p1 \ -	  ; then \ -	    f=`echo "$$p1" | sed 's,^.*/,,;$(transform);s/$$/$(EXEEXT)/'`; \ -	   echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) '$$p' '$(DESTDIR)$(bindir)/$$f'"; \ -	   $(INSTALL_PROGRAM_ENV) $(LIBTOOL) --mode=install $(binPROGRAMS_INSTALL) "$$p" "$(DESTDIR)$(bindir)/$$f" || exit 1; \ -	  else :; fi; \ -	done - -uninstall-binPROGRAMS: -	@$(NORMAL_UNINSTALL) -	@list='$(bin_PROGRAMS)'; for p in $$list; do \ -	  f=`echo "$$p" | sed 's,^.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/'`; \ -	  echo " rm -f '$(DESTDIR)$(bindir)/$$f'"; \ -	  rm -f "$(DESTDIR)$(bindir)/$$f"; \ -	done - -clean-binPROGRAMS: -	@list='$(bin_PROGRAMS)'; for p in $$list; do \ -	  f=`echo $$p|sed 's/$(EXEEXT)$$//'`; \ -	  echo " rm -f $$p $$f"; \ -	  rm -f $$p $$f ; \ -	done -ad$(EXEEXT): $(ad_OBJECTS) $(ad_DEPENDENCIES)  -	@rm -f ad$(EXEEXT) -	$(CXXLINK) $(ad_LDFLAGS) $(ad_OBJECTS) $(ad_LDADD) $(LIBS) - -mostlyclean-compile: -	-rm -f *.$(OBJEXT) - -distclean-compile: -	-rm -f *.tab.c - -.cpp.o: -	if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -	then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -#	source='$<' object='$@' libtool=no \ -#	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) \ -#	$(CXXCOMPILE) -c -o $@ $< - -.cpp.obj: -	if $(CXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -	then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -#	source='$<' object='$@' libtool=no \ -#	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) \ -#	$(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` - -.cpp.lo: -	if $(LTCXXCOMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -	then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Plo"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -#	source='$<' object='$@' libtool=yes \ -#	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) \ -#	$(LTCXXCOMPILE) -c -o $@ $< - -mostlyclean-libtool: -	-rm -f *.lo - -clean-libtool: -	-rm -rf .libs _libs -	-rm .deps/* - -distclean-libtool: -	-rm -f libtool -uninstall-info-am: - -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) -	list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '    { files[$$0] = 1; } \ -	       END { for (i in files) print i; }'`; \ -	mkid -fID $$unique -tags: TAGS - -TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) -	tags=; \ -	here=`pwd`; \ -	list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '    { files[$$0] = 1; } \ -	       END { for (i in files) print i; }'`; \ -	if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ -	  test -n "$$unique" || unique=$$empty_fix; \ -	  $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ -	    $$tags $$unique; \ -	fi -ctags: CTAGS -CTAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) -	tags=; \ -	here=`pwd`; \ -	list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '    { files[$$0] = 1; } \ -	       END { for (i in files) print i; }'`; \ -	test -z "$(CTAGS_ARGS)$$tags$$unique" \ -	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ -	     $$tags $$unique - -GTAGS: -	here=`$(am__cd) $(top_builddir) && pwd` \ -	  && cd $(top_srcdir) \ -	  && gtags -i $(GTAGS_ARGS) $$here - -distclean-tags: -	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags - -distdir: $(DISTFILES) -	@srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ -	topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ -	list='$(DISTFILES)'; for file in $$list; do \ -	  case $$file in \ -	    $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ -	    $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ -	  esac; \ -	  if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ -	  dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ -	  if test "$$dir" != "$$file" && test "$$dir" != "."; then \ -	    dir="/$$dir"; \ -	    $(mkdir_p) "$(distdir)$$dir"; \ -	  else \ -	    dir=''; \ -	  fi; \ -	  if test -d $$d/$$file; then \ -	    if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ -	      cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ -	    fi; \ -	    cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ -	  else \ -	    test -f $(distdir)/$$file \ -	    || cp -p $$d/$$file $(distdir)/$$file \ -	    || exit 1; \ -	  fi; \ -	done -check-am: all-am -check: check-am -all-am: Makefile $(PROGRAMS); -installdirs: -	for dir in "$(DESTDIR)$(bindir)"; do \ -	  test -z "$$dir" || $(mkdir_p) "$$dir"; \ -	done -install: install-am -install-exec: install-exec-am -install-data: install-data-am -uninstall: uninstall-am - -install-am: all-am -	@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am - -installcheck: installcheck-am -install-strip: -	$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ -	  install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ -	  `test -z '$(STRIP)' || \ -	    echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -mostlyclean-generic: - -clean-generic: - -distclean-generic: -	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) - -maintainer-clean-generic: -	@echo "This command is intended for maintainers to use" -	@echo "it deletes files that may require special tools to rebuild." -clean: clean-am - -clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am - -distclean: distclean-am -	-rm -rf ./$(DEPDIR) -distclean-am: clean-am distclean-compile distclean-generic \ -	distclean-libtool distclean-tags - -dvi: dvi-am - -dvi-am: - -html: html-am - -info: info-am - -info-am: - -install-data-am: - -install-exec-am: install-binPROGRAMS - -install-info: install-info-am - -install-man: - -installcheck-am: - -maintainer-clean: maintainer-clean-am -	-rm -rf ./$(DEPDIR) -	-rm -f Makefile -maintainer-clean-am: distclean-am maintainer-clean-generic - -mostlyclean: mostlyclean-am - -mostlyclean-am: mostlyclean-compile mostlyclean-generic \ -	mostlyclean-libtool - -pdf: pdf-am - -pdf-am: - -ps: ps-am - -ps-am: - -uninstall-am: uninstall-binPROGRAMS uninstall-info-am - -create-dir: -	mkdir -p ".deps" - -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-binPROGRAMS \ -	clean-generic clean-libtool ctags distclean distclean-compile \ -	distclean-generic distclean-libtool distclean-tags distdir dvi \ -	dvi-am html html-am info info-am install install-am \ -	install-binPROGRAMS install-data install-data-am install-exec \ -	install-exec-am install-info install-info-am install-man \ -	install-strip installcheck installcheck-am installdirs \ -	maintainer-clean maintainer-clean-generic mostlyclean \ -	mostlyclean-compile mostlyclean-generic mostlyclean-libtool \ -	pdf pdf-am ps ps-am tags uninstall uninstall-am \ -	uninstall-binPROGRAMS uninstall-info-am - -# Tell versions [3.59,3.63) of GNU make to not export all variables. -# Otherwise a system limit (for SysV at least) may be exceeded. -.NOEXPORT: diff --git a/contrib/extractor/README.linux b/contrib/extractor/README.linux index 52b907391b8..1986831e751 100644 --- a/contrib/extractor/README.linux +++ b/contrib/extractor/README.linux @@ -1,7 +1,7 @@ -= Trinity Core -- Linux instructions for extractor = +Linux instructions +------------------ -Copyright (C) Trinity Core (http://www.trinitycore.org) - -1: Configure and build MaNGOS. -2: cd contrib/extractor/libmpq && make && cd .. && make -3: run ad
\ No newline at end of file +1. install cmake +2. cmake -i +3. make +4. ./ad diff --git a/contrib/extractor/System.cpp b/contrib/extractor/System.cpp index a1641699163..b656a6ab535 100644 --- a/contrib/extractor/System.cpp +++ b/contrib/extractor/System.cpp @@ -3,6 +3,7 @@  #include <stdio.h>  #include <deque>  #include <set> +#include <cstdlib>  #ifdef WIN32  #include "direct.h" @@ -13,37 +14,78 @@  #include "dbcfile.h"  #include "mpq_libmpq.h" -extern unsigned int iRes; -extern ArchiveSet gOpenArchives; +#include "loadlib/adt.h" +#include "loadlib/wdt.h" +#include <fcntl.h> -bool ConvertADT(char*,char*); +#if defined( __GNUC__ ) +    #define _open   open +    #define _close close +    #ifndef O_BINARY +        #define O_BINARY 0 +    #endif +#else +    #include <io.h> +#endif -typedef struct{ -    char name[64]; -    unsigned int id; -}map_id; +#ifdef O_LARGEFILE +    #define OPEN_FLAGS  (O_RDONLY | O_BINARY | O_LARGEFILE) +#else +    #define OPEN_FLAGS (O_RDONLY | O_BINARY) +#endif +extern ArchiveSet gOpenArchives; -typedef unsigned char uint8; -typedef unsigned short uint16; -typedef unsigned int uint32; +typedef struct +{ +    char name[64]; +    uint32 id; +} map_id; -map_id * map_ids; -uint16 * areas; -char output_path[128]="."; -char input_path[128]="."; +map_id *map_ids; +uint16 *areas; +uint16 *LiqType; +char output_path[128] = "."; +char input_path[128] = "."; +uint32 maxAreaId = 0; +//************************************************** +// Extractor options +//**************************************************  enum Extract  {      EXTRACT_MAP = 1,      EXTRACT_DBC = 2  }; -int extract = EXTRACT_MAP | EXTRACT_DBC; + +// Select data for extract +int   CONF_extract = EXTRACT_MAP | EXTRACT_DBC; +// This option allow limit minimum height to some value (Allow save some memory) +bool  CONF_allow_height_limit = true; +float CONF_use_minHeight = -500.0f; + +// This option allow use float to int conversion +bool  CONF_allow_float_to_int   = true; +float CONF_float_to_int8_limit  = 2.0f;      // Max accuracy = val/256 +float CONF_float_to_int16_limit = 2048.0f;   // Max accuracy = val/65536 +float CONF_flat_height_delta_limit = 0.005f; // If max - min less this value - surface is flat +float CONF_flat_liquid_delta_limit = 0.001f; // If max - min less this value - liquid surface is flat + +// List MPQ for extract from +char *CONF_mpq_list[]={ +    "common.MPQ", +    "common-2.MPQ", +    "lichking.MPQ", +    "expansion.MPQ", +    "patch.MPQ", +    "patch-2.MPQ", +    "patch-3.MPQ", +    "patch-4.MPQ", +    "patch-5.MPQ", +};  static char* const langs[] = {"enGB", "enUS", "deDE", "esES", "frFR", "koKR", "zhCN", "zhTW", "enCN", "enTW", "esMX", "ruRU" };  #define LANG_COUNT 12 -#define ADT_RES 64 -  void CreateDir( const std::string& Path )  {      #ifdef WIN32 @@ -55,9 +97,10 @@ void CreateDir( const std::string& Path )  bool FileExists( const char* FileName )  { -    if(FILE* fp = fopen( FileName, "rb" )) +    int fp = _open(FileName, OPEN_FLAGS); +    if(fp != -1)      { -        fclose(fp); +        _close(fp);          return true;      } @@ -66,47 +109,54 @@ bool FileExists( const char* FileName )  void Usage(char* prg)  { -    printf("Usage:\n%s -[var] [value]\n-i set input path\n-o set output path\n-r set resolution\n-e extract only MAP(1)/DBC(2) - standard: both(3)\nExample: %s -r 256 -i \"c:\\games\\game\"", -    prg,prg); +    printf( +        "Usage:\n"\ +        "%s -[var] [value]\n"\ +        "-i set input path\n"\ +        "-o set output path\n"\ +        "-e extract only MAP(1)/DBC(2) - standard: both(3)\n"\ +        "-f height stored as int (less map size but lost some accuracy) 1 by default\n"\ +        "Example: %s -f 0 -i \"c:\\games\\game\"", prg, prg);      exit(1);  }  void HandleArgs(int argc, char * arg[])  { -    for(int c=1;c<argc;c++) +    for(int c = 1; c < argc; ++c)      { -        //i - input path -        //o - output path -        //r - resolution, array of (r * r) heights will be created -        //e - extract only MAP(1)/DBC(2) - standard both(3) +        // i - input path +        // o - output path +        // e - extract only MAP(1)/DBC(2) - standard both(3) +        // f - use float to int conversion +        // h - limit minimum height          if(arg[c][0] != '-')              Usage(arg[0]);          switch(arg[c][1])          {              case 'i': -                if(c+1<argc)//all ok -                    strcpy(input_path,arg[(c++) +1]); +                if(c + 1 < argc)                            // all ok +                    strcpy(input_path, arg[(c++) + 1]);                  else                      Usage(arg[0]);                  break;              case 'o': -                if(c+1<argc)//all ok -                    strcpy(output_path,arg[(c++) +1]); +                if(c + 1 < argc)                            // all ok +                    strcpy(output_path, arg[(c++) + 1]);                  else                      Usage(arg[0]);                  break; -            case 'r': -                if(c+1<argc)//all ok -                    iRes=atoi(arg[(c++) +1]); +            case 'f': +                if(c + 1 < argc)                            // all ok +                    CONF_allow_float_to_int=atoi(arg[(c++) + 1])!=0;                  else                      Usage(arg[0]);                  break;              case 'e': -                if(c+1<argc)//all ok +                if(c + 1 < argc)                            // all ok                  { -                    extract=atoi(arg[(c++) +1]); -                    if(!(extract > 0 && extract < 4)) +                    CONF_extract=atoi(arg[(c++) + 1]); +                    if(!(CONF_extract > 0 && CONF_extract < 4))                          Usage(arg[0]);                  }                  else @@ -120,14 +170,19 @@ uint32 ReadMapDBC()  {      printf("Read Map.dbc file... ");      DBCFile dbc("DBFilesClient\\Map.dbc"); -    dbc.open(); -    uint32 map_count=dbc.getRecordCount(); -    map_ids=new map_id[map_count]; -    for(unsigned int x=0;x<map_count;x++) +    if(!dbc.open())      { -        map_ids[x].id=dbc.getRecord(x).getUInt(0); -        strcpy(map_ids[x].name,dbc.getRecord(x).getString(1)); +        printf("Fatal error: Invalid Map.dbc file format!\n"); +        exit(1); +    } + +    size_t map_count = dbc.getRecordCount(); +    map_ids = new map_id[map_count]; +    for(uint32 x = 0; x < map_count; ++x) +    { +        map_ids[x].id = dbc.getRecord(x).getUInt(0); +        strcpy(map_ids[x].name, dbc.getRecord(x).getString(1));      }      printf("Done! (%u maps loaded)\n", map_count);      return map_count; @@ -135,60 +190,689 @@ uint32 ReadMapDBC()  void ReadAreaTableDBC()  { -    printf("Read AreaTable.dbc file... "); +    printf("Read AreaTable.dbc file...");      DBCFile dbc("DBFilesClient\\AreaTable.dbc"); -    dbc.open(); -    unsigned int area_count=dbc.getRecordCount(); -    uint32 maxid = dbc.getMaxId(); -    areas=new uint16[maxid + 1]; -    memset(areas, 0xff, sizeof(areas)); -    for(unsigned int x=0; x<area_count;++x) +    if(!dbc.open()) +    { +        printf("Fatal error: Invalid AreaTable.dbc file format!\n"); +        exit(1); +    } + +    size_t area_count = dbc.getRecordCount(); +    size_t maxid = dbc.getMaxId(); +    areas = new uint16[maxid + 1]; +    memset(areas, 0xff, (maxid + 1) * sizeof(uint16)); + +    for(uint32 x = 0; x < area_count; ++x)          areas[dbc.getRecord(x).getUInt(0)] = dbc.getRecord(x).getUInt(3); +    maxAreaId = dbc.getMaxId(); +      printf("Done! (%u areas loaded)\n", area_count);  } +void ReadLiquidTypeTableDBC() +{ +    printf("Read LiquidType.dbc file..."); +    DBCFile dbc("DBFilesClient\\LiquidType.dbc"); +    if(!dbc.open()) +    { +        printf("Fatal error: Invalid LiquidType.dbc file format!\n"); +        exit(1); +    } + +    size_t LiqType_count = dbc.getRecordCount(); +    size_t LiqType_maxid = dbc.getMaxId(); +    LiqType = new uint16[LiqType_maxid + 1]; +    memset(LiqType, 0xff, (LiqType_maxid + 1) * sizeof(uint16)); + +    for(uint32 x = 0; x < LiqType_count; ++x) +        LiqType[dbc.getRecord(x).getUInt(0)] = dbc.getRecord(x).getUInt(3); + +    printf("Done! (%u LiqTypes loaded)\n", LiqType_count); +} + +// +// Adt file convertor function and data +// + +// Map file format data +#define MAP_MAGIC             'SPAM' +#define MAP_VERSION_MAGIC     '0.1w' +#define MAP_AREA_MAGIC        'AERA' +#define MAP_HEIGTH_MAGIC      'TGHM' +#define MAP_LIQUID_MAGIC      'QILM' + +struct map_fileheader{ +    uint32 mapMagic; +    uint32 versionMagic; +    uint32 areaMapOffset; +    uint32 areaMapSize; +    uint32 heightMapOffset; +    uint32 heightMapSize; +    uint32 liquidMapOffset; +    uint32 liquidMapSize; +}; + +#define MAP_AREA_NO_AREA      0x0001 +struct map_areaHeader{ +    uint32 fourcc; +    uint16 flags; +    uint16 gridArea; +}; + +#define MAP_HEIGHT_NO_HIGHT   0x0001 +#define MAP_HEIGHT_AS_INT16   0x0002 +#define MAP_HEIGHT_AS_INT8    0x0004 + +struct map_heightHeader{ +    uint32 fourcc; +    uint32 flags; +    float  gridHeight; +    float  gridMaxHeight; +}; + +#define MAP_LIQUID_TYPE_NO_WATER    0x00 +#define MAP_LIQUID_TYPE_WATER       0x01 +#define MAP_LIQUID_TYPE_OCEAN       0x02 +#define MAP_LIQUID_TYPE_MAGMA       0x04 +#define MAP_LIQUID_TYPE_SLIME       0x08 + +#define MAP_LIQUID_TYPE_DARK_WATER  0x10 +#define MAP_LIQUID_TYPE_WMO_WATER   0x20 + + +#define MAP_LIQUID_NO_TYPE    0x0001 +#define MAP_LIQUID_NO_HIGHT   0x0002 + +struct map_liquidHeader{ +    uint32 fourcc; +    uint16 flags; +    uint16 liquidType; +    uint8  offsetX; +    uint8  offsetY; +    uint8  width; +    uint8  height; +    float  liquidLevel; +}; + +float selectUInt8StepStore(float maxDiff) +{ +    return 255 / maxDiff; +} + +float selectUInt16StepStore(float maxDiff) +{ +    return 65535 / maxDiff; +} +// Temporary grid data store +uint16 area_flags[ADT_CELLS_PER_GRID][ADT_CELLS_PER_GRID]; + +float V8[ADT_GRID_SIZE][ADT_GRID_SIZE]; +float V9[ADT_GRID_SIZE+1][ADT_GRID_SIZE+1]; +uint16 uint16_V8[ADT_GRID_SIZE][ADT_GRID_SIZE]; +uint16 uint16_V9[ADT_GRID_SIZE+1][ADT_GRID_SIZE+1]; +uint8  uint8_V8[ADT_GRID_SIZE][ADT_GRID_SIZE]; +uint8  uint8_V9[ADT_GRID_SIZE+1][ADT_GRID_SIZE+1]; + +uint8 liquid_type[ADT_CELLS_PER_GRID][ADT_CELLS_PER_GRID]; +bool  liquid_show[ADT_GRID_SIZE][ADT_GRID_SIZE]; +float liquid_height[ADT_GRID_SIZE+1][ADT_GRID_SIZE+1]; + +bool ConvertADT(char *filename, char *filename2, int cell_y, int cell_x) +{ +    ADT_file adt; + +    if (!adt.loadFile(filename)) +        return false; + +    adt_MCIN *cells = adt.a_grid->getMCIN(); +    if (!cells) +    { +        printf("Can't find cells in '%s'\n", filename); +        return false; +    } + +    memset(liquid_show, 0, sizeof(liquid_show)); +    memset(liquid_type, 0, sizeof(liquid_type)); + +    // Prepare map header +    map_fileheader map; +    map.mapMagic = MAP_MAGIC; +    map.versionMagic = MAP_VERSION_MAGIC; + +    // Get area flags data +    for (int i=0;i<ADT_CELLS_PER_GRID;i++) +    { +        for(int j=0;j<ADT_CELLS_PER_GRID;j++) +        { +            adt_MCNK * cell = cells->getMCNK(i,j); +            uint32 areaid = cell->areaid; +            if(areaid && areaid <= maxAreaId) +            { +                if(areas[areaid] != 0xffff) +                { +                    area_flags[i][j] = areas[areaid]; +                    continue; +                } +                printf("File: filename\nCan't find area flag for areaid %u [%d, %d].\n", filename, areaid, cell->ix, cell->iy); +            } +            area_flags[i][j] = 0xffff; +        } +    } +    //============================================ +    // Try pack area data +    //============================================ +    bool fullAreaData = false; +    uint32 areaflag = area_flags[0][0]; +    for (int y=0;y<ADT_CELLS_PER_GRID;y++) +    { +        for(int x=0;x<ADT_CELLS_PER_GRID;x++) +        { +            if(area_flags[y][x]!=areaflag) +            { +                fullAreaData = true; +                break; +            } +        } +    } + +    map.areaMapOffset = sizeof(map); +    map.areaMapSize   = sizeof(map_areaHeader); + +    map_areaHeader areaHeader; +    areaHeader.fourcc = MAP_AREA_MAGIC; +    areaHeader.flags = 0; +    if (fullAreaData) +    { +        areaHeader.gridArea = 0; +        map.areaMapSize+=sizeof(area_flags); +    } +    else +    { +        areaHeader.flags |= MAP_AREA_NO_AREA; +        areaHeader.gridArea = (uint16)areaflag; +    } + +    // +    // Get Height map from grid +    // +    for (int i=0;i<ADT_CELLS_PER_GRID;i++) +    { +        for(int j=0;j<ADT_CELLS_PER_GRID;j++) +        { +            adt_MCNK * cell = cells->getMCNK(i,j); +            if (!cell) +                continue; +            // Height values for triangles stored in order: +            // 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 +            // . . . . . . . . +            // For better get height values merge it to V9 and V8 map +            // V9 height map: +            // 1     2     3     4     5     6     7     8     9 +            // 18    19    20    21    22    23    24    25    26 +            // . . . . . . . . +            // V8 height map: +            //    10    11    12    13    14    15    16    17 +            //    27    28    29    30    31    32    33    34 +            // . . . . . . . . + +            // Set map height as grid height +            for (int y=0; y <= ADT_CELL_SIZE; y++) +            { +                int cy = i*ADT_CELL_SIZE + y; +                for (int x=0; x <= ADT_CELL_SIZE; x++) +                { +                    int cx = j*ADT_CELL_SIZE + x; +                    V9[cy][cx]=cell->ypos; +                } +            } +            for (int y=0; y < ADT_CELL_SIZE; y++) +            { +                int cy = i*ADT_CELL_SIZE + y; +                for (int x=0; x < ADT_CELL_SIZE; x++) +                { +                    int cx = j*ADT_CELL_SIZE + x; +                    V8[cy][cx]=cell->ypos; +                } +            } +            // Get custom height +            adt_MCVT *v = cell->getMCVT(); +            if (!v) +                continue; +            // get V9 height map +            for (int y=0; y <= ADT_CELL_SIZE; y++) +            { +                int cy = i*ADT_CELL_SIZE + y; +                for (int x=0; x <= ADT_CELL_SIZE; x++) +                { +                    int cx = j*ADT_CELL_SIZE + x; +                    V9[cy][cx]+=v->height_map[y*(ADT_CELL_SIZE*2+1)+x]; +                } +            } +            // get V8 height map +            for (int y=0; y < ADT_CELL_SIZE; y++) +            { +                int cy = i*ADT_CELL_SIZE + y; +                for (int x=0; x < ADT_CELL_SIZE; x++) +                { +                    int cx = j*ADT_CELL_SIZE + x; +                    V8[cy][cx]+=v->height_map[y*(ADT_CELL_SIZE*2+1)+ADT_CELL_SIZE+1+x]; +                } +            } +        } +    } +    //============================================ +    // Try pack height data +    //============================================ +    float maxHeight = -20000; +    float minHeight =  20000; +    for (int y=0; y<ADT_GRID_SIZE; y++) +    { +        for(int x=0;x<ADT_GRID_SIZE;x++) +        { +            float h = V8[y][x]; +            if (maxHeight < h) maxHeight = h; +            if (minHeight > h) minHeight = h; +        } +    } +    for (int y=0; y<=ADT_GRID_SIZE; y++) +    { +        for(int x=0;x<=ADT_GRID_SIZE;x++) +        { +            float h = V9[y][x]; +            if (maxHeight < h) maxHeight = h; +            if (minHeight > h) minHeight = h; +        } +    } + +    // Check for allow limit minimum height (not store height in deep ochean - allow save some memory) +    if (CONF_allow_height_limit && minHeight < CONF_use_minHeight) +    { +        for (int y=0; y<ADT_GRID_SIZE; y++) +            for(int x=0;x<ADT_GRID_SIZE;x++) +                if (V8[y][x] < CONF_use_minHeight) +                    V8[y][x] = CONF_use_minHeight; +        for (int y=0; y<=ADT_GRID_SIZE; y++) +            for(int x=0;x<=ADT_GRID_SIZE;x++) +                if (V9[y][x] < CONF_use_minHeight) +                    V9[y][x] = CONF_use_minHeight; +        if (minHeight < CONF_use_minHeight) +            minHeight = CONF_use_minHeight; +        if (maxHeight < CONF_use_minHeight) +            maxHeight = CONF_use_minHeight; +    } + +    map.heightMapOffset = map.areaMapOffset + map.areaMapSize; +    map.heightMapSize = sizeof(map_heightHeader); + +    map_heightHeader heightHeader; +    heightHeader.fourcc = MAP_HEIGTH_MAGIC; +    heightHeader.flags = 0; +    heightHeader.gridHeight    = minHeight; +    heightHeader.gridMaxHeight = maxHeight; + +    if (maxHeight == minHeight) +        heightHeader.flags |=MAP_HEIGHT_NO_HIGHT; + +    // Not need store if flat surface +    if (CONF_allow_float_to_int && (maxHeight - minHeight) < CONF_flat_height_delta_limit) +        heightHeader.flags |=MAP_HEIGHT_NO_HIGHT; + +    // Try store as packed in uint16 or uint8 values +    if (!(heightHeader.flags&MAP_HEIGHT_NO_HIGHT)) +    { +        float step; +        // Try Store as uint values +        if (CONF_allow_float_to_int) +        { +            float diff = maxHeight - minHeight; +            if (diff < CONF_float_to_int8_limit)      // As uint8 (max accuracy = CONF_float_to_int8_limit/256) +            { +                heightHeader.flags|=MAP_HEIGHT_AS_INT8; +                step = selectUInt8StepStore(diff); +            } +            else if (diff<CONF_float_to_int16_limit)  // As uint16 (max accuracy = CONF_float_to_int16_limit/65536) +            { +                heightHeader.flags|=MAP_HEIGHT_AS_INT16; +                step = selectUInt16StepStore(diff); +            } +        } + +        // Pack it to int values if need +        if (heightHeader.flags&MAP_HEIGHT_AS_INT8) +        { +            for (int y=0; y<ADT_GRID_SIZE; y++) +                for(int x=0;x<ADT_GRID_SIZE;x++) +                    uint8_V8[y][x] = uint8((V8[y][x] - minHeight) * step + 0.5f); +            for (int y=0; y<=ADT_GRID_SIZE; y++) +                for(int x=0;x<=ADT_GRID_SIZE;x++) +                    uint8_V9[y][x] = uint8((V9[y][x] - minHeight) * step + 0.5f); +            map.heightMapSize+= sizeof(uint8_V9) + sizeof(uint8_V8); +        } +        else if (heightHeader.flags&MAP_HEIGHT_AS_INT16) +        { +            for (int y=0; y<ADT_GRID_SIZE; y++) +                for(int x=0;x<ADT_GRID_SIZE;x++) +                    uint16_V8[y][x] = uint16((V8[y][x] - minHeight) * step + 0.5f); +            for (int y=0; y<=ADT_GRID_SIZE; y++) +                for(int x=0;x<=ADT_GRID_SIZE;x++) +                    uint16_V9[y][x] = uint16((V9[y][x] - minHeight) * step + 0.5f); +            map.heightMapSize+= sizeof(uint16_V9) + sizeof(uint16_V8); +        } +        else +            map.heightMapSize+= sizeof(V9) + sizeof(V8); +    } + +    // Get liquid map for grid (in WOTLK used MH2O chunk) +    adt_MH2O * h2o = adt.a_grid->getMH2O(); +    if (h2o) +    { +        for (int i=0;i<ADT_CELLS_PER_GRID;i++) +        { +            for(int j=0;j<ADT_CELLS_PER_GRID;j++) +            { +                adt_liquid_header *h = h2o->getLiquidData(i,j); +                if (!h) +                    continue; + +                int count = 0; +                uint64 show = h2o->getLiquidShowMap(h); +                for (int y=0; y < h->height;y++) +                { +                    int cy = i*ADT_CELL_SIZE + y + h->yOffset; +                    for (int x=0; x < h->width; x++) +                    { +                        int cx = j*ADT_CELL_SIZE + x + h->xOffset; +                        if (show & 1) +                        { +                            liquid_show[cy][cx] = true; +                            ++count; +                        } +                        show>>=1; +                    } +                } + +                uint32 type = LiqType[h->liquidType]; +                switch (type) +                { +                    case LIQUID_TYPE_WATER: liquid_type[i][j] |= MAP_LIQUID_TYPE_WATER; break; +                    case LIQUID_TYPE_OCEAN: liquid_type[i][j] |= MAP_LIQUID_TYPE_OCEAN; break; +                    case LIQUID_TYPE_MAGMA: liquid_type[i][j] |= MAP_LIQUID_TYPE_MAGMA; break; +                    case LIQUID_TYPE_SLIME: liquid_type[i][j] |= MAP_LIQUID_TYPE_SLIME; break; +                    default: +                        printf("\nCan't find Liquid type %u for map %s\nchunk %d,%d\n", h->liquidType, filename, i, j); +                        break; +                } +                // Dark water detect +                if (type == LIQUID_TYPE_OCEAN) +                { +                    uint8 *lm = h2o->getLiquidLightMap(h);  +                    if (!lm) +                        liquid_type[i][j]|=MAP_LIQUID_TYPE_DARK_WATER; +                } + +                if (!count && liquid_type[i][j]) +                    printf("Wrong liquid detect in MH2O chunk"); + +                float *height = h2o->getLiquidHeightMap(h); +                int pos = 0; +                for (int y=0; y<=h->height;y++) +                { +                    int cy = i*ADT_CELL_SIZE + y + h->yOffset; +                    for (int x=0; x<= h->width; x++) +                    { +                        int cx = j*ADT_CELL_SIZE + x + h->xOffset; +                        if (height) +                            liquid_height[cy][cx] = height[pos]; +                        else +                            liquid_height[cy][cx] = h->heightLevel1; +                        pos++; +                    } +                } +            } +        } +    } +    else +    { +        // Get from MCLQ chunk (old) +        for (int i=0;i<ADT_CELLS_PER_GRID;i++) +        { +            for(int j=0;j<ADT_CELLS_PER_GRID;j++) +            { +                adt_MCNK *cell = cells->getMCNK(i, j); +                if (!cell) +                    continue; + +                adt_MCLQ *liquid = cell->getMCLQ(); +                int count = 0; +                if (!liquid || cell->sizeMCLQ <= 8) +                    continue; + +                for (int y=0; y < ADT_CELL_SIZE; y++) +                { +                    int cy = i*ADT_CELL_SIZE + y; +                    for (int x=0; x < ADT_CELL_SIZE; x++) +                    { +                        int cx = j*ADT_CELL_SIZE + x; +                        if (liquid->flags[y][x] != 0x0F) +                        { +                            liquid_show[cy][cx] = true; +                            if (liquid->flags[y][x]&(1<<7)) +                                liquid_type[i][j]|=MAP_LIQUID_TYPE_DARK_WATER; +                            ++count; +                        } +                    } +                } + +                uint32 c_flag = cell->flags; +                if(c_flag & (1<<2)) +                    liquid_type[i][j]|=MAP_LIQUID_TYPE_WATER;            // water +                if(c_flag & (1<<3)) +                    liquid_type[i][j]|=MAP_LIQUID_TYPE_OCEAN;            // ochean +                if(c_flag & (1<<4)) +                    liquid_type[i][j]|=MAP_LIQUID_TYPE_MAGMA;            // magma/slime + +                if (!count && liquid_type[i][j]) +                    printf("Wrong liquid detect in MCLQ chunk"); + +                for (int y=0; y <= ADT_CELL_SIZE; y++) +                { +                    int cy = i*ADT_CELL_SIZE + y; +                    for (int x=0; x<= ADT_CELL_SIZE; x++) +                    { +                        int cx = j*ADT_CELL_SIZE + x; +                        liquid_height[cy][cx] = liquid->liquid[y][x].height; +                    } +                } +            } +        } +    } + +    //============================================ +    // Pack liquid data +    //============================================ +    uint8 type = liquid_type[0][0]; +    bool fullType = false; +    for (int y=0;y<ADT_CELLS_PER_GRID;y++) +    { +        for(int x=0;x<ADT_CELLS_PER_GRID;x++) +        { +            if (liquid_type[y][x]!=type) +            { +                fullType = true; +                y = ADT_CELLS_PER_GRID; +                break; +            } +        } +    } + +    map_liquidHeader liquidHeader; + +    // no water data (if all grid have 0 liquid type) +    if (type == 0 && !fullType) +    { +        // No liquid data +        map.liquidMapOffset = 0; +        map.liquidMapSize   = 0; +    } +    else +    { +        int minX = 255, minY = 255; +        int maxX = 0, maxY = 0; +        maxHeight = -20000; +        minHeight = 20000; +        for (int y=0; y<ADT_GRID_SIZE; y++) +        { +            for(int x=0; x<ADT_GRID_SIZE; x++) +            { +                if (liquid_show[y][x]) +                { +                    if (minX > x) minX = x; +                    if (maxX < x) maxX = x; +                    if (minY > y) minY = y; +                    if (maxY < y) maxY = y; +                    float h = liquid_height[y][x]; +                    if (maxHeight < h) maxHeight = h; +                    if (minHeight > h) minHeight = h; +                } +                else +                    liquid_height[y][x] = CONF_use_minHeight; +            } +        } +        map.liquidMapOffset = map.heightMapOffset + map.heightMapSize; +        map.liquidMapSize = sizeof(map_liquidHeader); +        liquidHeader.fourcc = MAP_LIQUID_MAGIC; +        liquidHeader.flags = 0; +        liquidHeader.liquidType = 0; +        liquidHeader.offsetX = minX; +        liquidHeader.offsetY = minY; +        liquidHeader.width   = maxX - minX + 1; +        liquidHeader.height  = maxY - minY + 1; +        liquidHeader.liquidLevel = minHeight; + +        if (maxHeight == minHeight) +            liquidHeader.flags|=MAP_LIQUID_NO_HIGHT; + +        // Not need store if flat surface +        if (CONF_allow_float_to_int && (maxHeight - minHeight) < CONF_flat_liquid_delta_limit) +            liquidHeader.flags|=MAP_LIQUID_NO_HIGHT; + +        if (!fullType) +            liquidHeader.flags|=MAP_LIQUID_NO_TYPE; + +        if (liquidHeader.flags&MAP_LIQUID_NO_TYPE) +            liquidHeader.liquidType = type; +        else +            map.liquidMapSize+=sizeof(liquid_type); +      +        if (!(liquidHeader.flags&MAP_LIQUID_NO_HIGHT)) +            map.liquidMapSize+=sizeof(float)*liquidHeader.width*liquidHeader.height; +    } + +    // Ok all data prepared - store it +    FILE *output=fopen(filename2, "wb"); +    if(!output) +    { +        printf("Can't create the output file '%s'\n", filename2); +        return false; +    } +    fwrite(&map, sizeof(map), 1, output); +    // Store area data +    fwrite(&areaHeader, sizeof(areaHeader), 1, output); +    if (!(areaHeader.flags&MAP_AREA_NO_AREA)) +        fwrite(area_flags, sizeof(area_flags), 1, output); + +    // Store height data +    fwrite(&heightHeader, sizeof(heightHeader), 1, output); +    if (!(heightHeader.flags&MAP_HEIGHT_NO_HIGHT)) +    { +        if (heightHeader.flags&MAP_HEIGHT_AS_INT16) +        { +            fwrite(uint16_V9, sizeof(uint16_V9), 1, output); +            fwrite(uint16_V8, sizeof(uint16_V8), 1, output); +        } +        else if (heightHeader.flags&MAP_HEIGHT_AS_INT8) +        { +            fwrite(uint8_V9, sizeof(uint8_V9), 1, output); +            fwrite(uint8_V8, sizeof(uint8_V8), 1, output); +        } +        else +        { +            fwrite(V9, sizeof(V9), 1, output); +            fwrite(V8, sizeof(V8), 1, output); +        } +    } + +    // Store liquid data if need +    if (map.liquidMapOffset) +    { +        fwrite(&liquidHeader, sizeof(liquidHeader), 1, output); +        if (!(liquidHeader.flags&MAP_LIQUID_NO_TYPE)) +            fwrite(liquid_type, sizeof(liquid_type), 1, output); +        if (!(liquidHeader.flags&MAP_LIQUID_NO_HIGHT)) +        { +            for (int y=0; y<liquidHeader.height;y++) +                fwrite(&liquid_height[y+liquidHeader.offsetY][liquidHeader.offsetX], sizeof(float), liquidHeader.width, output); +        } +    } +    fclose(output); + +    return true; +} +  void ExtractMapsFromMpq()  {      char mpq_filename[1024];      char output_filename[1024]; +    char mpq_map_name[1024];      printf("Extracting maps...\n");      uint32 map_count = ReadMapDBC();      ReadAreaTableDBC(); - -    unsigned int total=map_count*ADT_RES*ADT_RES; -    unsigned int done=0; +    ReadLiquidTypeTableDBC();      std::string path = output_path;      path += "/maps/";      CreateDir(path); -    for(unsigned int x = 0; x < ADT_RES; ++x) +    printf("Convert map files\n"); +    for(uint32 z = 0; z < map_count; ++z)      { -        for(unsigned int y = 0; y < ADT_RES; ++y) +        printf("Extract %s (%d/%d)                  \n", map_ids[z].name, z+1, map_count); +        // Loadup map grid data +        sprintf(mpq_map_name, "World\\Maps\\%s\\%s.wdt", map_ids[z].name, map_ids[z].name); +        WDT_file wdt; +        if (!wdt.loadFile(mpq_map_name, false))          { -            for(unsigned int z = 0; z < map_count; ++z) +//            printf("Error loading %s map wdt data\n", map_ids[z].name); +            continue; +        } + +        for(uint32 y = 0; y < WDT_MAP_SIZE; ++y) +        { +            for(uint32 x = 0; x < WDT_MAP_SIZE; ++x)              { -                sprintf(mpq_filename,"World\\Maps\\%s\\%s_%u_%u.adt",map_ids[z].name,map_ids[z].name,x,y); -                sprintf(output_filename,"%s/maps/%03u%02u%02u.map",output_path,map_ids[z].id,y,x); -                ConvertADT(mpq_filename,output_filename); -                done++; +                if (!wdt.main->adt_list[y][x].exist) +                    continue; +                sprintf(mpq_filename, "World\\Maps\\%s\\%s_%u_%u.adt", map_ids[z].name, map_ids[z].name, x, y); +                sprintf(output_filename, "%s/maps/%03u%02u%02u.map", output_path, map_ids[z].id, y, x); +                ConvertADT(mpq_filename, output_filename, y, x);              } -            //draw progess bar -            printf("Processing........................%d%%\r",(100*done)/total); +            // draw progress bar +            printf("Processing........................%d%%\r", (100 * (y+1)) / WDT_MAP_SIZE);          }      } -      delete [] areas;      delete [] map_ids;  } -//bool WMO(char* filename); -  void ExtractDBCFiles(int locale, bool basicLocale)  {      printf("Extracting dbc files...\n"); @@ -222,7 +906,7 @@ void ExtractDBCFiles(int locale, bool basicLocale)          string filename = path;          filename += (iter->c_str() + strlen("DBFilesClient\\")); -        FILE *output=fopen(filename.c_str(), "wb"); +        FILE *output = fopen(filename.c_str(), "wb");          if(!output)          {              printf("Can't create the output file '%s'\n", filename.c_str()); @@ -260,18 +944,10 @@ void LoadLocaleMPQFiles(int const locale)  void LoadCommonMPQFiles()  {      char filename[512]; - -    sprintf(filename,"%s/Data/common.MPQ", input_path); -    new MPQArchive(filename); -    sprintf(filename,"%s/Data/expansion.MPQ", input_path); -    new MPQArchive(filename); -    for(int i = 1; i < 5; ++i) +    int count = sizeof(CONF_mpq_list)/sizeof(char*); +    for(int i = 0; i < count; ++i)      { -        char ext[3] = ""; -        if(i > 1) -            sprintf(ext, "-%i", i); - -        sprintf(filename,"%s/Data/patch%s.MPQ", input_path, ext); +        sprintf(filename, "%s/Data/%s", input_path, CONF_mpq_list[i]);          if(FileExists(filename))              new MPQArchive(filename);      } @@ -303,7 +979,7 @@ int main(int argc, char * arg[])              //Open MPQs              LoadLocaleMPQFiles(i); -            if((extract & EXTRACT_DBC) == 0) +            if((CONF_extract & EXTRACT_DBC) == 0)              {                  FirstLocale = i;                  break; @@ -329,7 +1005,7 @@ int main(int argc, char * arg[])          return 0;      } -    if (extract & EXTRACT_MAP) +    if (CONF_extract & EXTRACT_MAP)      {          printf("Using locale: %s\n", langs[FirstLocale]); diff --git a/contrib/extractor/VC71_ad.vcproj b/contrib/extractor/VC71_ad.vcproj index fd2d16120e8..541540ceaa2 100644 --- a/contrib/extractor/VC71_ad.vcproj +++ b/contrib/extractor/VC71_ad.vcproj @@ -213,7 +213,15 @@  			Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"  			>  			<File -				RelativePath=".\adt.cpp" +				RelativePath=".\loadlib\loadlib.cpp" +				> +			</File> +			<File +				RelativePath=".\loadlib\adt.cpp" +				> +			</File> +			<File +				RelativePath=".\loadlib\wdt.cpp"  				>  			</File>  			<File diff --git a/contrib/extractor/VC80_ad.vcproj b/contrib/extractor/VC80_ad.vcproj index fedab5b89eb..a20ff016ca8 100644 --- a/contrib/extractor/VC80_ad.vcproj +++ b/contrib/extractor/VC80_ad.vcproj @@ -218,7 +218,7 @@  			Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"  			>  			<File -				RelativePath=".\adt.cpp" +				RelativePath=".\loadlib\adt.cpp"  				>  			</File>  			<File @@ -226,6 +226,10 @@  				>  			</File>  			<File +				RelativePath=".\loadlib\loadlib.cpp" +				> +			</File> +			<File  				RelativePath=".\mpq_libmpq.cpp"  				>  			</File> @@ -253,6 +257,10 @@  					/>  				</FileConfiguration>  			</File> +			<File +				RelativePath=".\loadlib\wdt.cpp" +				> +			</File>  			<Filter  				Name="libmpq"  				> diff --git a/contrib/extractor/VC90_ad.vcproj b/contrib/extractor/VC90_ad.vcproj index 59fdf6d21f1..9a039a0fbb0 100644 --- a/contrib/extractor/VC90_ad.vcproj +++ b/contrib/extractor/VC90_ad.vcproj @@ -216,7 +216,15 @@  			Filter="cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"  			>  			<File -				RelativePath=".\adt.cpp" +				RelativePath=".\loadlib\loadlib.cpp" +				> +			</File> +			<File +				RelativePath=".\loadlib\adt.cpp" +				> +			</File> +			<File +				RelativePath=".\loadlib\wdt.cpp"  				>  			</File>  			<File diff --git a/contrib/extractor/ad.exe b/contrib/extractor/ad.exeBinary files differ index f0a7e4408ce..208eb2da030 100644 --- a/contrib/extractor/ad.exe +++ b/contrib/extractor/ad.exe diff --git a/contrib/extractor/adt.cpp b/contrib/extractor/adt.cpp index a8f640a63bc..fcbfc95a072 100644 --- a/contrib/extractor/adt.cpp +++ b/contrib/extractor/adt.cpp @@ -15,16 +15,14 @@  #include "adt.h"  #include "mpq_libmpq.h" -//#include <windows.h> -unsigned int iRes=256; -extern uint16*areas; +extern uint16 *areas; +extern uint16 *LiqType; +extern uint32 maxAreaId;  vec wmoc; -Cell * cell; -uint32 wmo_count; +Cell *cell;  mcell *mcells; -  int holetab_h[4] = {0x1111, 0x2222, 0x4444, 0x8888};  int holetab_v[4] = {0x000F, 0x00F0, 0x0F00, 0xF000}; @@ -35,168 +33,154 @@ bool LoadADT(char* filename)      if(mf.isEof())      { -        //printf("No such file.\n"); +        //printf("No such file %s\n", filename);          return false;      } -    mcells=new mcell; -    wmoc.x =65*TILESIZE; -    wmoc.z =65*TILESIZE; +    MapLiqFlag = new uint8[256]; +    for(uint32 j = 0; j < 256; ++j) +        MapLiqFlag[j] = 0;                                  // no water + +    MapLiqHeight = new float[16384]; +    for(uint32 j = 0; j < 16384; ++j) +        MapLiqHeight[j] = -999999;                          // no water + +    mcells = new mcell; + +    wmoc.x = 65 * TILESIZE; +    wmoc.z = 65 * TILESIZE;      size_t mcnk_offsets[256], mcnk_sizes[256]; -    wmo_count=0; -    bool found=false; -    //uint32 fs=mf.getSize()-3; -    //while (mf.getPos()<fs) +    chunk_num = 0; +    k = 0; +    m = 0;      while (!mf.isEof())      {          uint32 fourcc; -        mf.read(&fourcc,4); +        mf.read(&fourcc, 4);          mf.read(&size, 4);          size_t nextpos = mf.getPos() + size; -        switch(fourcc) + +        //if(fourcc==0x4d484452)                            // MHDR header +        //if(fourcc==0x4d564552)                            // MVER +        if(fourcc == 0x4d43494e)                            // MCIN          { -            case 0x4d43494e:                                // MCIN +            for (uint32 i = 0; i < 256; ++i)              { -                //printf("Found chunks info\n"); -                // mapchunk offsets/sizes -                for (int i=0; i<256; i++) -                { -                    mf.read(&mcnk_offsets[i],4); -                    mf.read(&mcnk_sizes[i],4); -                    mf.seekRelative(8); -                } -                break; +                mf.read(&mcnk_offsets[i], 4); +                mf.read(&mcnk_sizes[i], 4); +                mf.seekRelative(8);              } -            case 0x4d4f4446:                                // MODF +        } +        //if(fourcc == 0x4d544558)                          // MTEX textures (strings) +        //if(fourcc == 0x4d4d4458)                          // MMDX m2 models (strings) +        //if(fourcc == 0x4d4d4944)                          // MMID offsets for strings in MMDX +        //if(fourcc == 0x4d574d4f)                          // MWMO +        //if(fourcc == 0x4d574944)                          // MWID offsets for strings in MWMO +        //if(fourcc == 0x4d444446)                          // MDDF +        //if(fourcc == 0x4d4f4446)                          // MODF +        if(fourcc == 0x4d48324f)                            // MH2O new in WotLK +        { +            // çäåñ?íàäî çàïîìíèò?áàçîâó?ïîçèöè??ôàéë?òê âñ?ñìåùåí? áóäó?îò íåãî +            uint32 base_pos = mf.getPos(); +            uint32 header_pos = 0; +            MH2O_offsData *LiqOffsData = new MH2O_offsData; +            MH2O_Data1 *LiqChunkData1 = new MH2O_Data1; +            float *ChunkLiqHeight = new float[81]; +            for(chunk_num = 0; chunk_num < 256; ++chunk_num)              { -                /* -                if(size) +                mf.read(LiqOffsData, 0x0C); +                header_pos = mf.getPos(); +                if(LiqOffsData->offsData1 != 0)             // åñëè äàííûå ?Data1 ?âîäå åñòü, òî èõ íàäî êîíâåðòèðîâàòü                  { -                    //printf("\nwmo count %d\n",size/64); -                    wmo_count =size/64; -                    for (int i=0; i<wmo_count; i++) +                    // ïåðåõî?ïî ñìåùåíèþ èç offsData1 ÎÒ ×À?êóñê? +                    mf.seek(base_pos + LiqOffsData->offsData1); +                    mf.read(LiqChunkData1, 0x18);           // ñ÷èòûâàå?ñàìè äàííûå ?ñòðóêòóð?òèïà MH2O_Data1 +                    // çàíîñè?äàííûå ôëàã?äëÿ êóñê? +                    if(LiqType[LiqChunkData1->LiquidTypeId] == 0xffff) +                        printf("\nCan't find Liquid type for map %s\nchunk %d\n", filename, chunk_num); +                    else if(LiqType[LiqChunkData1->LiquidTypeId] == LIQUID_TYPE_WATER || LiqType[LiqChunkData1->LiquidTypeId] == LIQUID_TYPE_OCEAN) +                        MapLiqFlag[chunk_num] |= 1;         // water/ocean +                    else if(LiqType[LiqChunkData1->LiquidTypeId] == LIQUID_TYPE_MAGMA || LiqType[LiqChunkData1->LiquidTypeId] == LIQUID_TYPE_SLIME) +                        MapLiqFlag[chunk_num] |= 2;         // magma/slime +                    // ïðåäâàðèòåëüíî çàïîëíÿåì âåñü êóñî?äàííûì?- íå?âîäû +                    for(int j = 0; j < 81; ++j) +                    { +                        ChunkLiqHeight[j] = -999999;        // no liquid/water +                    } +                    // òåïåðü âû÷èñëÿåì òå ÷ò??âîäî??ïåðåçàïèñûâàåì èõ ?êóñê? +                    for(int b = 0; b <= LiqChunkData1->height; ++b)                      { -                        int id; -                        mf.read(&id, 4); -                        WMO *wmo = (WMO*)wmomanager.items[wmomanager.get(wmos[id])]; -                        WMOInstance inst(wmo, mf); -                        wmois.push_back(inst); +                        for(int c = LiqChunkData1->xOffset; c <= (LiqChunkData1->xOffset + LiqChunkData1->width); ++c) +                        { +                            int n = (9 * (LiqChunkData1->yOffset + b)) + c; +                            ChunkLiqHeight[n] = LiqChunkData1->heightLevel1; +                        }                      } +                    mf.seek(header_pos);                    // ?íå çàáûòü âåðíóòüñÿ íà èñõîäíóþ ïîçèöè?èìåííî ?ÕÈÄÅÐÅ +                } +                else                                        // åñëè äàííûõ ?Data1 íå? òî íàäî çàïîëíèò?âåñü êóñî? íî äàííûì?- íå?âîäû +                { +                    for(int j = 0; j < 81; ++j) +                        ChunkLiqHeight[j] = -999999;        // no liquid/water +                } -                }*/ -                break; -            } -            case 0x4d574d4f:                                // MWMO -            { -                /* -                if (size) +                if(!(chunk_num % 16)) +                    m = 1024 * (chunk_num / 16);            // ñìåùåíèå ïî ?äà?êóñêîâ ?ïåðåêðûòèå?= 1024 +                k = m + (chunk_num % 16) * 8;               // óñòàíàâëèâàåìñÿ íà íà÷àëüíû?èíäåêñ äëÿ çàïîëíåí? ?äà +                // çàíîñè?äàííûå êóñê??ìàññèâ äëÿ êàðò? ?ïåðåêðûòèå??îáðåçàíèåì êóñêîâ òê äàííûõ 81 +                // ýò?àíàëîã ñòàðîã?îáðåçàíèÿ ãðàíè÷íû?ïðàâûõ-áîêîâû??íèæíèõ äàííûõ +                for(int p = 0; p < 72; p += 9)              // íèæíèå 8 íå çàíîñè?òê îí?äóáëèðóåòñÿ ñëåä êóñêîì                  { -                    char *buf = new char[size]; -                    mf.read(buf, size); -                    char *p=buf; -                    while (p<buf+size) +                    for(int s = 0; s < 8; ++s)              // 9 çíà÷åíèå ?ñòðîêå íå çàíîñè?òê îí?äóáëèðóåòñÿ ñëåä êóñêîì, ??ïðâû?áîêîâû?îáðåçàåò? äëÿ 128?28                      { -                    std::string path(p); -                        p+=strlen(p)+1; -                        fixname(path); - -                        wmomanager.add(path); -                        wmos.push_back(path); +                        MapLiqHeight[k] = ChunkLiqHeight[p + s]; +                        ++k;                      } -                    delete[] buf; -                }*/ -                break; -            } -            case 0x4d564552:                                // MVER -            case 0x4d484452:                                // MHDR header -            case 0x4d434e4b:                                // MCNK -            case 0x4d544558:                                // MTEX textures (strings) -            case 0x4d4d4458:                                // MMDX m2 models (strings) -            case 0x4d4d4944:                                // MMID offsets for strings in MMDX -            case 0x4d574944:                                // MWID offsets for strings in MWMO -            case 0x4d444446:                                // MDDF -            case 0x4d46424f:                                // MFBO new in BC -            case 0x4d48324f:                                // MH2O new in WotLK -                break; -            default: -            { -                // mf.seekRelative(-3); -                printf("Unhandled map chunk: %u\n",fourcc); -                break; +                    k = k + 120; +                }              } +            delete LiqOffsData; +            delete LiqChunkData1; +            delete []ChunkLiqHeight; +          } +        //case 0x4d434e4b:                                  // MCNK +        //case 0x4d46424f:                                  // MFBO new in BC +        //case 0x4d545846:                                  // MTXF new in WotLK          mf.seek(nextpos);      }      //printf("Loading chunks info\n");      // read individual map chunks -    for (int j=0; j<16; j++) -        for (int i=0; i<16; i++) +    chunk_num = 0; +    k = 0; +    m = 0; +    for (int j = 0; j < 16; ++j) +    { +        for (int i = 0; i < 16; ++i)          { -            mf.seek((int)mcnk_offsets[j*16+i]); -            LoadMapChunk(mf,&(mcells->ch[i][j])); +            mf.seek((int)mcnk_offsets[j * 16 + i]); +            LoadMapChunk(mf, &(mcells->ch[i][j])); +            ++chunk_num;          } - -    /* -    for(uint32 t=0;t<wmo_count ;t++) -    { -        wmois[t].draw(); -    }*/ - +    }      mf.close();      return true;  } -struct MapChunkHeader { -    uint32 flags; -    uint32 ix; -    uint32 iy; -    uint32 nLayers; -    uint32 nDoodadRefs; -    uint32 ofsHeight; -    uint32 ofsNormal; -    uint32 ofsLayer; -    uint32 ofsRefs; -    uint32 ofsAlpha; -    uint32 sizeAlpha; -    uint32 ofsShadow; -    uint32 sizeShadow; -    uint32 areaid; -    uint32 nMapObjRefs; -    uint32 holes; -    uint16 s1; -    uint16 s2; -    uint32 d1; -    uint32 d2; -    uint32 d3; -    uint32 predTex; -    uint32 nEffectDoodad; -    uint32 ofsSndEmitters; -    uint32 nSndEmitters; -    uint32 ofsLiquid; -    uint32 sizeLiquid; -    float  zpos; -    float  xpos; -    float  ypos; -    uint32 textureId; -    uint32 props; -    uint32 effectId; -}; -  bool isHole(int holes, int i, int j)  { -    int testi = i/2; -    int testj = j/4; -    if(testi>3) testi = 3; -    if(testj>3) testj = 3; -    return (holes & holetab_h[testi] & holetab_v[testj])!=0; +    int testi = i / 2; +    int testj = j / 4; +    if(testi > 3) testi = 3; +    if(testj > 3) testj = 3; +    return (holes & holetab_h[testi] & holetab_v[testj]) != 0;  } -inline -void LoadMapChunk(MPQFile & mf, chunk*_chunk) +inline void LoadMapChunk(MPQFile &mf, chunk *_chunk)  {      float h;      uint32 fourcc; @@ -207,298 +191,191 @@ void LoadMapChunk(MPQFile & mf, chunk*_chunk)      mf.read(&size, 4);      size_t lastpos = mf.getPos() + size; -    mf.read(&header, 0x80); -    _chunk->area_id =header.areaid ; -    _chunk->flag =0; +    mf.read(&header, 0x80);                                 // what if header size got changed? +    _chunk->area_id = header.areaid;      float xbase = header.xpos;      float ybase = header.ypos;      float zbase = header.zpos; -    zbase = TILESIZE*32-zbase; -    xbase = TILESIZE*32-xbase; -    if(wmoc.x >xbase)wmoc.x =xbase; -    if(wmoc.z >zbase)wmoc.z =zbase; +    zbase = TILESIZE * 32 - zbase; +    xbase = TILESIZE * 32 - xbase; +    if(wmoc.x > xbase) wmoc.x = xbase; +    if(wmoc.z > zbase) wmoc.z = zbase;      int chunkflags = header.flags; -    float zmin=999999999.0f; -    float zmax=-999999999.0f; -    //must be there, bl!zz uses some crazy format -    int nTextures; +    //printf("LMC: flags %X\n", chunkflags); +    float zmin = 999999999.0f; +    float zmax = -999999999.0f; +    // must be there, bl!zz uses some crazy format      while (mf.getPos() < lastpos)      { -        mf.read(&fourcc,4); +        mf.read(&fourcc, 4);          mf.read(&size, 4); -        //if(size!=580) -        //    printf("\n sz=%d",size); -        size_t nextpos = mf.getPos()  + size; -        if(fourcc==0x4d435654)                              // MCVT +        size_t nextpos = mf.getPos() + size; +        if(fourcc == 0x4d435654)                            // MCVT          { -            for (int j=0; j<17; j++) -                for (int i=0; i<((j%2)?8:9); i++) +            for (int j = 0; j < 17; ++j) +            { +                for (int i = 0; i < ((j % 2) ? 8 : 9); ++i)                  { -                    mf.read(&h,4); -                    float z=h+ybase; -                    if (j%2) +                    mf.read(&h, 4); +                    float z = h + ybase; +                    if (j % 2)                      { -                        if(isHole(header.holes,i,j)) -                            _chunk->v8[i][j/2] = -1000; +                        if(isHole(header.holes, i, j)) +                            _chunk->v8[i][j / 2] = -1000;                          else -                            _chunk->v8[i][j/2] = z; +                            _chunk->v8[i][j / 2] = z;                      }                      else                      { -                        if(isHole(header.holes,i,j)) -                            _chunk->v9[i][j/2] = -1000; +                        if(isHole(header.holes, i, j)) +                            _chunk->v9[i][j / 2] = -1000;                          else -                            _chunk->v9[i][j/2] = z; +                            _chunk->v9[i][j / 2] = z;                      } -                    if(z>zmax)zmax=z; -                    //if(z<zmin)zmin=z; +                    if(z > zmax) zmax = z; +                    //if(z < zmin) zmin = z;                  } +            }          } -        else if(fourcc==0x4d434e52)                         // MCNR +        else if(fourcc == 0x4d434e52)                       // MCNR          { -            nextpos = mf.getPos() + 0x1C0; // size fix +            nextpos = mf.getPos() + 0x1C0;                  // size fix          } -        else if(fourcc==0x4d434c51)                         // MCLQ +        else if(fourcc == 0x4d434c51)                       // íå áóäå?ó÷èòûâàò?åñëè óæ?áûëè äàííûå ?MH2O, ïåðåñòðàõîâê?:)                      // MCLQ          {              // liquid / water level -            //bool haswater;              char fcc1[5]; -            mf.read(fcc1,4); +            mf.read(fcc1, 4);              flipcc(fcc1); -            fcc1[4]=0; +            fcc1[4] = 0; +            float *ChunkLiqHeight = new float[81]; -            if (!strcmp(fcc1,"MCSE")) +            if (!strcmp(fcc1, "MCSE"))              { -                for(int i=0;i<9;i++) -                    for(int j=0;j<9;j++) -                        _chunk->waterlevel[i][j]=-999999; // no liquid/water +                for(int j = 0; j < 81; ++j) +                { +                    ChunkLiqHeight[j] = -999999;            // no liquid/water +                }              }              else              {                  float maxheight;                  mf.read(&maxheight, 4); +                for(int j = 0; j < 81; ++j) +                { +                    LiqData liq; +                    mf.read(&liq, 8); -                for(int j=0;j<9;j++) -                    for(int i=0;i<9;i++) -                    { -                        mf.read(&h, 4); -                        mf.read(&h, 4); -                        if(h > maxheight) -                            _chunk->waterlevel[i][j]=-999999; -                        else -                            _chunk->waterlevel[i][j]=h; -                    } +                    if(liq.height > maxheight) +                        ChunkLiqHeight[j] = -999999; +                    else +                        ChunkLiqHeight[j] = h; +                }                  if(chunkflags & 4 || chunkflags & 8) -                    _chunk->flag |=1; +                    MapLiqFlag[chunk_num] |= 1;             // water                  if(chunkflags & 16) -                    _chunk->flag |=2; - +                    MapLiqFlag[chunk_num] |= 2;             // magma/slime +            } +            // àïîëíå?òà?æå êà??MH2O +            if(!(chunk_num % 16)) +                m = 1024 * (chunk_num / 16); +            k = m + (chunk_num % 16) * 8; +             +            for(int p = 0; p < 72; p += 9) +            { +                for(int s = 0; s < 8; ++s) +                { +                    MapLiqHeight[k] = ChunkLiqHeight[p + s]; +                    ++k;     +                } +                k = k + 120;              } +            delete []ChunkLiqHeight;              break;          } -        else if (fourcc==0x4d434c59)                        // MCLY -        { -            // texture info -            nTextures = (int)size; -        } -        else if (fourcc==0x4d43414c)                        // MCAL -        { -            if (nTextures<=0) -                continue; -        } -          mf.seek(nextpos);      }  } -double solve (vec *v,vec *p) +inline void TransformData()  { -    double a = v[0].y *(v[1].z - v[2].z) + v[1].y *(v[2].z - v[0].z) + v[2].y *(v[0].z - v[1].z); -    double b = v[0].z *(v[1].x - v[2].x) + v[1].z *(v[2].x - v[0].x) + v[2].z *(v[0].x - v[1].x); -    double c = v[0].x *(v[1].y - v[2].y) + v[1].x *(v[2].y - v[0].y) + v[2].x *(v[0].y - v[1].y); -    double d = v[0].x *(v[1].y*v[2].z - v[2].y*v[1].z) + v[1].x* (v[2].y*v[0].z - v[0].y*v[2].z) + v[2].x* (v[0].y*v[1].z - v[1].y*v[0].z); -    //-d - -    //plane equation ax+by+cz+d=0 -    return ((a*p->x+c*p->z-d)/b); -} - -inline -double GetZ(double x,double z) -{ -    vec v[3]; -    vec p; - -    //bool inWMO=false; +    cell = new Cell; -    //if(!inWMO) +    for(uint32 x = 0; x < 128; ++x)      { -        //find out quadrant -        int xc=(int)(x/UNITSIZE); -        int zc=(int)(z/UNITSIZE); -        if(xc>127)xc=127; -        if(zc>127)zc=127; - -        double lx=x-xc*UNITSIZE; -        double lz=z-zc*UNITSIZE; -        p.x=lx; -        p.z=lz; - -        v[0].x=UNITSIZE/2; -        v[0].y =cell->v8[xc][zc]; -        v[0].z=UNITSIZE/2; - -        if(lx>lz) +        for(uint32 y = 0; y < 128; ++y)          { -            v[1].x=UNITSIZE; -            v[1].y =cell->v9[xc+1][zc]; -            v[1].z=0; -        } -        else -        { -            v[1].x=0.0; -            v[1].y =cell->v9[xc][zc+1]; -            v[1].z=UNITSIZE; -        } - -        if(lz>UNITSIZE-lx) -        { -            v[2].x=UNITSIZE; -            v[2].y =cell->v9[xc+1][zc+1]; -            v[2].z=UNITSIZE; -        } -        else -        { -            v[2].x=0; -            v[2].y=cell->v9[xc][zc]; -            v[2].z=0; +            cell->v8[y][x] = (float)mcells->ch[x / 8][y / 8].v8[x % 8][y % 8]; +            cell->v9[y][x] = (float)mcells->ch[x / 8][y / 8].v9[x % 8][y % 8];          } -        return -solve(v,&p); +        // extra 1 point on bounds +        cell->v9[128][x] = (float)mcells->ch[x / 8][15].v9[x % 8][8]; +        // x == y +        cell->v9[x][128] = (float)mcells->ch[15][x / 8].v9[8][x % 8];      } -} - -inline -void TransformWaterData() -{ -    cell= new Cell; -    for(int x=0;x<128;x++) -        for(int y=0;y<128;y++) -            cell->v9[x][y] = mcells->ch[x/8][y/8].waterlevel[x%8][y%8]; - -    //and the last 1 -    cell->v9[128][128] = mcells->ch[15][15].waterlevel[8][8]; -} - -inline -void TransformData() -{ -    cell= new Cell; - -    for(int x=0;x<128;x++) -    { -        for(int y=0;y<128;y++) -        { -            cell->v8[y][x] = (float)mcells->ch[x/8][y/8].v8[x%8][y%8]; -            cell->v9[y][x] = (float)mcells->ch[x/8][y/8].v9[x%8][y%8]; -        } - -        //extra 1 point on bounds -        cell->v9[128][x] = (float)mcells->ch[x/8][15].v9[x%8][8]; -        //x==y -        cell->v9[x][128] = (float)mcells->ch[15][x/8].v9[8][x%8]; -    } - -    //and the last 1 +    // and the last 1      cell->v9[128][128] = (float)mcells->ch[15][15].v9[8][8];      delete mcells;  } -const char MAP_MAGIC[] = "MAP_2.50"; +const char MAP_MAGIC[] = "MAP_3.00"; -bool ConvertADT(char * filename,char * filename2) +bool ConvertADT(char *filename, char *filename2)  { -    //if(!strstr(filename,"oth_32_48"))return false;      if(!LoadADT(filename))          return false; -    FILE *output=fopen(filename2,"wb"); +    FILE *output=fopen(filename2, "wb");      if(!output)      { -        printf("Can't create the output file '%s'\n",filename2); +        printf("Can't create the output file '%s'\n", filename2); +        delete [] MapLiqHeight; +        delete [] MapLiqFlag;          return false;      }      // write magic header -    fwrite(MAP_MAGIC,1,8,output); +    fwrite(MAP_MAGIC, 1, 8, output); -    for(unsigned int x=0;x<16;x++) +    for(uint32 x = 0; x < 16; ++x)      { -        for(unsigned int y=0;y<16;y++) +        for(uint32 y = 0; y < 16; ++y)          { -            if(mcells->ch[y][x].area_id && mcells->ch[y][x].area_id < 0x102D) +            if(mcells->ch[y][x].area_id && mcells->ch[y][x].area_id <= maxAreaId)              { -                if(areas[mcells->ch[y][x].area_id]==0xffff) -                    printf("\nCan't find area flag for areaid %u.\n",mcells->ch[y][x].area_id); +                if(areas[mcells->ch[y][x].area_id] == 0xffff) +                    printf("\nCan't find area flag for areaid %u.\n", mcells->ch[y][x].area_id); -                fwrite(&areas[mcells->ch[y][x].area_id],1,2,output); +                fwrite(&areas[mcells->ch[y][x].area_id], 1, 2, output);              }              else              { -                uint16 flag=0xffff; -                fwrite(&flag,1,2,output); +                uint16 flag = 0xffff; +                fwrite(&flag, 1, 2, output);              }          }      } -    for(unsigned int x=0;x<16;x++) -        for(unsigned int y=0;y<16;y++) -            fwrite(&mcells->ch[y][x].flag,1,1,output); - -    TransformWaterData(); +    fwrite(MapLiqFlag, 1, 256, output); +    delete [] MapLiqFlag; -    for(unsigned int x=0;x<128;x++) -        for(unsigned int y=0;y<128;y++) -            fwrite(&cell->v9[y][x],1,sizeof(float),output); +    fwrite(MapLiqHeight, sizeof(float), 16384, output); +    delete [] MapLiqHeight; -    delete cell;      TransformData(); -    /* -    for(unsigned int x=0;x<iRes;x++) -    for(unsigned int y=0;y<iRes;y++) -    { -        float z=(float)GetZ( -                    (((double)(y))*TILESIZE)/((double)(iRes-1)), -                    (((double)(x))*TILESIZE)/((double)(iRes-1))); - -        fwrite(&z,1,sizeof(z),output); -    }*/      fwrite(&cell->v9, 1, sizeof(cell->v9), output);      fwrite(&cell->v8, 1, sizeof(cell->v8), output);      fclose(output);      delete cell; -/* -    for (std::vector<std::string>::iterator it = wmos.begin(); it != wmos.end(); ++it) -    wmomanager.delbyname(*it); - -    wmos.clear(); -    wmois.clear(); - -    for (std::vector<model>::iterator it = wmomodel.begin(); it != wmomodel.end(); ++it) -    { -        it->tr.clear(); - -    } -    //printf("\n %d \n",in); -    wmomodel.clear(); -    //polygons.clear();*/ +          return true;  } diff --git a/contrib/extractor/adt.h b/contrib/extractor/adt.h index 9af85b14d8c..516ed88a86e 100644 --- a/contrib/extractor/adt.h +++ b/contrib/extractor/adt.h @@ -9,47 +9,122 @@ typedef unsigned char uint8;  typedef unsigned short uint16;  typedef unsigned int uint32;  class Liquid; -typedef struct { -float x; -float y; -float z; -}svec; - -typedef struct { -double x; -double y; -double z; -}vec; - -typedef struct{ +typedef struct +{ +    float x; +    float y; +    float z; +} svec; + +typedef struct +{ +    double x; +    double y; +    double z; +} vec; + +typedef struct +{      vec v[3]; -}triangle; +} triangle; + +typedef struct +{ +    float v9[16 * 8 + 1][16 * 8 + 1]; +    float v8[16 * 8][16 * 8]; +} Cell; + +typedef struct +{ +    double v9[9][9]; +    double v8[8][8]; +    uint16 area_id; +} chunk; -typedef struct{ -float v9[16*8+1][16*8+1]; -float v8[16*8][16*8]; -}Cell; +typedef struct +{ +    chunk ch[16][16]; +} mcell; -typedef struct{ -double v9[9][9]; -double v8[8][8]; -uint16 area_id; -//Liquid *lq; -float waterlevel[9][9]; -uint8 flag; -}chunk; +struct MapChunkHeader +{ +    uint32 flags; +    uint32 ix; +    uint32 iy; +    uint32 nLayers; +    uint32 nDoodadRefs; +    uint32 ofsHeight; +    uint32 ofsNormal; +    uint32 ofsLayer; +    uint32 ofsRefs; +    uint32 ofsAlpha; +    uint32 sizeAlpha; +    uint32 ofsShadow; +    uint32 sizeShadow; +    uint32 areaid; +    uint32 nMapObjRefs; +    uint32 holes; +    uint16 s1; +    uint16 s2; +    uint32 d1; +    uint32 d2; +    uint32 d3; +    uint32 predTex; +    uint32 nEffectDoodad; +    uint32 ofsSndEmitters; +    uint32 nSndEmitters; +    uint32 ofsLiquid;                                       // not use in WotLK +    uint32 sizeLiquid;                                      // not use in WotLK +    float  zpos; +    float  xpos; +    float  ypos; +    uint32 textureId;                                       // new offsColorValues in WotLK +    uint32 props; +    uint32 effectId; +}; -class WMO; -class WMOManager; -void fixname(std::string &name); +typedef struct +{ +    uint32 offsData1; +    uint32 used; +    uint32 offsData2; +} MH2O_offsData;  typedef struct  { -chunk ch[16][16]; -}mcell; +    uint16 LiquidTypeId; +    uint16 type; +    float heightLevel1; +    float heightLevel2; +    uint8 xOffset; +    uint8 yOffset; +    uint8 width; +    uint8 height; +    uint32 ofsData2a; +    uint32 ofsData2b; +} MH2O_Data1; + +typedef struct +{ +    uint16 unk1; +    uint16 unk2; +    float height; +} LiqData; + +enum LiquidType +{ +    LIQUID_TYPE_WATER = 0, +    LIQUID_TYPE_OCEAN = 1, +    LIQUID_TYPE_MAGMA = 2, +    LIQUID_TYPE_SLIME = 3 +}; +  class MPQFile; -void LoadMapChunk(MPQFile &,chunk*); -bool LoadWMO(char* filename); + +float *MapLiqHeight; +uint8 *MapLiqFlag; +uint32 k, m, chunk_num; +void LoadMapChunk(MPQFile &, chunk*);  #endif diff --git a/contrib/extractor/dbcfile.cpp b/contrib/extractor/dbcfile.cpp index dbe379d27f7..dd58ac1b4a6 100644 --- a/contrib/extractor/dbcfile.cpp +++ b/contrib/extractor/dbcfile.cpp @@ -9,29 +9,42 @@ DBCFile::DBCFile(const std::string &filename):  {  } -void DBCFile::open() +bool DBCFile::open()  {      MPQFile f(filename.c_str());      char header[4];      unsigned int na,nb,es,ss; -    f.read(header,4); // Number of records -    assert(header[0]=='W' && header[1]=='D' && header[2]=='B' && header[3] == 'C'); -    f.read(&na,4); // Number of records -    f.read(&nb,4); // Number of fields -    f.read(&es,4); // Size of a record -    f.read(&ss,4); // String size +    if(f.read(header,4)!=4)                                 // Number of records +        return false; + +    if(header[0]!='W' || header[1]!='D' || header[2]!='B' || header[3]!='C') +        return false; + +    if(f.read(&na,4)!=4)                                    // Number of records +        return false; +    if(f.read(&nb,4)!=4)                                    // Number of fields +        return false; +    if(f.read(&es,4)!=4)                                    // Size of a record +        return false; +    if(f.read(&ss,4)!=4)                                    // String size +        return false;      recordSize = es;      recordCount = na;      fieldCount = nb;      stringSize = ss; -    assert(fieldCount*4 == recordSize); +    if(fieldCount*4 != recordSize) +        return false;      data = new unsigned char[recordSize*recordCount+stringSize];      stringTable = data + recordSize*recordCount; -    f.read(data,recordSize*recordCount+stringSize); + +    size_t data_size = recordSize*recordCount+stringSize; +    if(f.read(data,data_size)!=data_size) +        return false;      f.close(); +    return true;  }  DBCFile::~DBCFile()  { diff --git a/contrib/extractor/dbcfile.h b/contrib/extractor/dbcfile.h index 7d709e80948..aef61df7aaa 100644 --- a/contrib/extractor/dbcfile.h +++ b/contrib/extractor/dbcfile.h @@ -10,7 +10,7 @@ public:      ~DBCFile();      // Open database. It must be openened before it can be used. -    void open(); +    bool open();      // Database exceptions      class Exception diff --git a/contrib/extractor/libmpq/CMakeLists.txt b/contrib/extractor/libmpq/CMakeLists.txt new file mode 100644 index 00000000000..c00120c6e48 --- /dev/null +++ b/contrib/extractor/libmpq/CMakeLists.txt @@ -0,0 +1,13 @@ +# Copyright (C) 2005-2009 MaNGOS project <http://getmangos.com/> +# +# This file is free software; as a special exception the author gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY, to the extent permitted by law; without even the +# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +add_library (libmpq common.cpp  explode.cpp  extract.cpp  huffman.cpp  mpq.cpp  parser.cpp  wave.cpp ) +# link libmpq with zlib +target_link_libraries (libmpq z) diff --git a/contrib/extractor/libmpq/Makefile b/contrib/extractor/libmpq/Makefile deleted file mode 100644 index eb1965e29f1..00000000000 --- a/contrib/extractor/libmpq/Makefile +++ /dev/null @@ -1,17 +0,0 @@ -CC = g++ -AR = ar -objects = common.o explode.o extract.o huffman.o wave.o mpq.o parser.o -zlib_objects = ../../../dep/src/zlib/*.o #adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o zutil.o inflate.o inftrees.o inffast.o - -all:	libmpq.a libmpq.so - -clean:  -	rm -f libmpq.a libmpq.so *.o - -libmpq.a: $(objects) $(zlib_objects) -	$(AR) cru $@ $+ -libmpq.so: $(objects) $(zlib_objects) -	$(CC) -fPIC -o $@ $+ - -%.o:%.cpp -	$(CC) -I../ -c $+ diff --git a/contrib/extractor/libmpq/mpq.cpp b/contrib/extractor/libmpq/mpq.cpp index eddd92ac483..a59d3dff2f1 100644 --- a/contrib/extractor/libmpq/mpq.cpp +++ b/contrib/extractor/libmpq/mpq.cpp @@ -199,7 +199,7 @@ int libmpq_archive_info(mpq_archive *mpq_a, unsigned int infotype) {  /*   * This function returns some useful file information.   */ -int libmpq_file_info(mpq_archive *mpq_a, unsigned int infotype, const int unsigned number) { +int libmpq_file_info(mpq_archive *mpq_a, unsigned int infotype, const unsigned int number) {      int blockindex = number; //-1;      int i = 0;      mpq_block *mpq_b = NULL; diff --git a/contrib/extractor/mpq_libmpq.h b/contrib/extractor/mpq_libmpq.h index 97b7b75035b..d61cda7f919 100644 --- a/contrib/extractor/mpq_libmpq.h +++ b/contrib/extractor/mpq_libmpq.h @@ -4,6 +4,7 @@  #ifndef MPQ_H  #define MPQ_H +#include "loadlib/loadlib.h"  #include "libmpq/mpq.h"  #include <string.h>  #include <ctype.h> @@ -13,7 +14,6 @@  using namespace std; -typedef unsigned int uint32;  class MPQArchive  { diff --git a/contrib/vmap_debugger/ModelContainerView.cpp b/contrib/vmap_debugger/ModelContainerView.cpp index f9b19c2a1fd..fbfa565696f 100644 --- a/contrib/vmap_debugger/ModelContainerView.cpp +++ b/contrib/vmap_debugger/ModelContainerView.cpp @@ -451,7 +451,7 @@ namespace VMAP      //==================================================================== -    Vector3 ModelContainerView::convertPositionToTrinityRep(float x, float y, float z) const { +    Vector3 ModelContainerView::convertPositionToMangosRep(float x, float y, float z) const {          float pos[3];          pos[0] = z;          pos[1] = x; @@ -490,7 +490,7 @@ namespace VMAP  #if 0              i_App->defaultController.getPosition();              Vector3 pos = i_App->defaultController.getPosition(); -            Vector3 pos2 = convertPositionToTrinityRep(pos.x, pos.y, pos.z); +            Vector3 pos2 = convertPositionToMangosRep(pos.x, pos.y, pos.z);              //Vector3 pos3 = iVMapManager->convertPositionToInternalRep(pos2.x, pos2.y, pos2.z);              //pos3 = iVMapManager->convertPositionToInternalRep(pos2.x, pos2.y, pos2.z); diff --git a/contrib/vmap_extract_assembler_bin/vmap_assembler.exe b/contrib/vmap_extract_assembler_bin/vmap_assembler.exeBinary files differ index 5cb08f770aa..a6ef74dc086 100644 --- a/contrib/vmap_extract_assembler_bin/vmap_assembler.exe +++ b/contrib/vmap_extract_assembler_bin/vmap_assembler.exe diff --git a/contrib/vmap_extract_assembler_bin/vmapextract_v2.exe b/contrib/vmap_extract_assembler_bin/vmapextract_v2.exeBinary files differ index c38b6e64f64..a1e982f0cba 100644 --- a/contrib/vmap_extract_assembler_bin/vmapextract_v2.exe +++ b/contrib/vmap_extract_assembler_bin/vmapextract_v2.exe diff --git a/contrib/vmap_extractor_v2/doc/MoPaQ_0.9.txt b/contrib/vmap_extractor_v2/doc/MoPaQ_0.9.txt deleted file mode 100644 index ce8d8f70166..00000000000 --- a/contrib/vmap_extractor_v2/doc/MoPaQ_0.9.txt +++ /dev/null @@ -1,318 +0,0 @@ -THE MOPAQ ARCHIVE FORMAT -v0.9 (Thursday, June 30, 2005) -by Justin Olbrantz(Quantam) - -Distribution and reproduction of this specification are allowed without limitation, as long as it is not altered. Quoting -in other works is freely allowed, as long as the source and author of the quote is stated. - -TABLE OF CONTENTS -1. Introduction to the MoPaQ Format -2. The MoPaQ Format -	2.1 General Archive Layout -	2.2 Archive Header -	2.3 Block Table -	2.4 Hash Table -	2.5 File Data -	2.6 Listfile -	2.7 Extended Attributes -	2.8 Weak (Old) Digital Signature -	2.9 Strong (New) Digital Signature -3. Algorithm Source Code -	3.1 Encryption/Decryption -	3.2 Hashing -	3.3 Conversion of FILETIME and time_t - -1. INTRODUCTION TO THE MOPAQ FORMAT -The MoPaQ (or MPQ) format is an archive file format designed by Mike O'Brien (hence the name Mike O'brien PaCK) at Blizzard -Entertainment. The format has been used in all Blizzard games since (and including) Diablo. It is heavily optimized to be -a read-only game archive format, and excels at this role.  - -The Blizzard MoPaQ-reading functions are contained in the Storm module, which my be either statically or dynamically linked. -The Blizzard MoPaQ-writing functions are contained in the MPQAPI module, which is always statically linked. - -2. THE MOPAQ FORMAT -All numbers in the MoPaQ format are in little endian. Data types are listed either as int (integer, the number of bits specified), -byte (8 bits), and char (bytes which contain ASCII characters). All sizes and offsets are in bytes, unless specified otherwise. -Structure members are listed in the following general form: -offset from the beginning of the structure: data type(array size) member name : member description - -2.1 GENERAL ARCHIVE LAYOUT -- Archive Header -- File Data -- File Data - Special Files -- Hash Table -- Block Table -- Strong Digital signature - -This is the usual archive format, and is not absolutely essential. Some archives have been observed placing the hash table -and file table after the archive header, and before the file data. - -2.2 ARCHIVE HEADER -00h: char(4) Magic : Indicates that the file is a MoPaQ archive. Must be ASCII "MPQ" 1Ah. -04h: int32 HeaderSize : Size of the archive header. Should be 32. -08h: int32 ArchiveSize : Size of the whole archive, including the header. Does not include the strong digital signature, if present. -This size is used, among other things, for determining the region to hash in computing the digital signature. -0Ch: int16 Unknown : Unknown -0Eh: int8 SectorSizeShift : Power of two exponent specifying the number of 512-byte disk sectors in each logical sector -in the archive. The size of each logical sector the archive is 512 * 2^SectorSizeShift. Bugs in the Storm library dictate -that this should always be 3 (4096 byte sectors). -10h: int32 HashTableOffset : Offset to the beginning of the hash table, relative to the beginning of the archive. -14h: int32 BlockTableOffset : Offset to the beginning of the block table, relative to the beginning of the archive. -18h: int32 HashTableEntries : Number of entries in the hash table. Must be a power of two, and must be less than 2^16. -1Ch: int32 BlockTableEntries : Number of entries in the block table. - -The archive header is the first structure in the archive, at archive offset 0, but the archive does not need to be at offset -0 of the containing file. The offset of the archive in the file is referred to here as ArchiveOffset. If the archive is not -at the beginning of the file, it must begin at a disk sector boundary (512 bytes). Early versions of Storm require that the -archive be at the end of the containing file (ArchiveOffset + ArchiveSize = file size), but this is not required in newer -versions (due to the strong digital signature not being considered a part of the archive). - -2.3 BLOCK TABLE -The block table contains entries for each region in the archive. Regions may be either files or empty space, which may be -overwritten by new files (typically this space is from deleted file data). The block table is encrypted, using the hash -of "(block table)" as the key. Each entry is structured as follows: - -00h: int32 BlockOffset : Offset of the beginning of the block, relative to the beginning of the archive. Meaningless if the block size is 0. -04h: int32 BlockSize : Size of the block in the archive. -08h: int32 FileSize : Size of the file data stored in the block. Only valid if the block is a file, otherwise meaningless, and should be 0. If the file is compressed, this is the size of the uncompressed file data. -0Ch: int32 Flags : Bit mask of the flags for the block. The following values are conclusively identified: -	80000000h: Block is a file, and follows the file data format; otherwise, block is free space, and may be overwritten. If the block is not a file, all other flags should be cleared. -	01000000h: File is stored as a single unit, rather than split into sectors. -	00020000h: The file's encryption key is adjusted by the block offset and file size (explained in detail in the File Data section). File must be encrypted. -	00010000h: File is encrypted. -	00000200h: File is compressed. Mutually exclusive to file imploded. -	00000100h: File is imploded. Mutually exclusive to file compressed. - -2.4 HASH TABLE -Instead of storing file names, for quick access MoPaQs use a fixed, power of two-size hash table of files in the archive. A file is uniquely identified by its file path, its language, and its platform. The home entry for a file in the hash table is computed as a hash of the file path. In the event of a collision (the home entry is occupied by another file), progressive overflow is used, and the file is placed in the next available hash table entry. Searches for a desired file in the hash table proceed from the home entry for the file until either the file is found, the entire hash table is searched, or an empty hash table entry (FileBlockIndex of FFFFFFFFh) is encountered. The hash table is encrypted using the hash of "(hash table)" as the key. Each entry is structured as follows: - -00h: int32 FilePathHashA : The hash of the file path, using method A. -04h: int32 FilePathHashB : The hash of the file path, using method B. -08h: int16 Language : The language of the file. This is a Windows LANGID data type, and uses the same values. 0 indicates the default language (American English), or that the file is language-neutral. -0Ah: int8 Platform : The platform the file is used for. 0 indicates the default platform. No other values have been observed. -0Ch: int32 FileBlockIndex : If the hash table entry is valid, this is the index into the block table of the file. Otherwise, one of the following two values: -	FFFFFFFFh: Hash table entry is empty, and has always been empty. Terminates searches for a given file. -	FFFFFFFEh: Hash table entry is empty, but was valid at some point (in other words, the file was deleted). Does not terminate searches for a given file. - -2.5 FILE DATA -00h: int32(SectorsInFile + 1) SectorOffsetTable : Offsets to the start of each sector's data, relative to the beginning of the file data. Not present if this information is calculatable (see details below). -immediately following SectorOffsetTable: SectorData : Data of each sector in the file, packed end to end (see details below). - -Normally, file data is split up into sectors, for simple streaming. All sectors, save for the last, will contain as many bytes of file data as specified in the archive header's SectorSizeShift; the last sector may be smaller than this, depending on the size of the file data. This sector size is the size of the raw file data; if the file is compressed, the compressed sector will be smaller or the same size as the uncompressed sector size. Individual sectors in a compressed file may be stored uncompressed; this occurs if and only if the sector could not be compressed by the algorithm used (if the compressed sector size was greater than or equal to the size of the raw data), and is indicated by the sector's compressed size in SectorOffsetTable being equal to the uncompressed size of the sector (which may be calculated from the FileSize). - -If the sector is compressed (but not imploded), a bit mask byte of the compression algorithm(s) used to compress the sector is appended to the beginning of the compressed sector data. This additional byte counts towards the total size of the sector; if the size of the sector (including this byte) exceeds or matches the uncompressed size of the sector data, the sector will be stored uncompressed, and this byte omitted. Multiple compression algorithms may be used on the same sector; in this case, successive compression occurs in the order the algorithms are listed below, and decompression occurs in the opposite order. For implimentations of all of these algorithms, see StormLib. -	40h: IMA ADPCM mono -	80h: IMA ADPCM stereo -	01h: Huffman encoded -	02h: Deflated (see ZLib) -	08h: Imploded (see PKWare Data Compression Library) -	10h: BZip2 compressed (see BZip2) - -If the file is stored as a single unit (indicated in the file's Flags), there is effectively only a single sector, which -contains the entire file. - -If the file is encrypted, each sector (after compression and appendage of the compression type byte, if applicable) -is encrypted with the file's key. The base key for a file is determined by a hash of the file name stripped of the -directory (i.e. the key for a file named "directory\file" would be computed as the hash of "file"). If this key is -adjusted, as indicated in the file's Flags, the final key is calculated as ((base key + BlockOffset - ArchiveOffset) -XOR FileSize) (StormLib - an open-source implementation of the MoPaQ reading and writing functions, -by Ladislav Zezula - incorrectly uses an AND in place of the XOR). Each sector is encrypted using the key + the -0-based index of the sector in the file. The SectorOffsetTable, if present, is encrypted using the key - 1. - -The SectorOffsetTable is omitted when the sizes and offsets of all sectors in the file are calculatable from the FileSize. -This can happen in several circumstances. If the file is not compressed/imploded, then the size and offset of all sectors -is known, based on the archive's SectorSizeShift. If the file is stored as a single unit compressed/imploded, then the -SectorOffsetTable is omitted, as the single file "sector" corresponds to BlockSize and FileSize, as mentioned previously. -Note that the SectorOffsetTable will always be present if the file is compressed/imploded and the file is not stored as -a single unit, even if there is only a single sector in the file (the size of the file is less than or equal to the -archive's sector size). - -2.6 LISTFILE -The listfile is a very simple extension to the MoPaQ format that contains the file paths of (most) files in the archive. -The languages and platforms of the files are not stored in the listfile. The listfile is contained in the file "(listfile)", -and is simply a non-Unix-style text file with one file path on each line, lines terminated with the bytes 0Dh 0Ah. The file -"(listfile)" may not be listed in the listfile. - -2.7 EXTENDED ATTRIBUTES -The extended attributes are optional file attributes for files in the block table. These attributes were added at times after -the MoPaQ format was already finalized, and it is not necessary for every archive to have all (or any) of the extended attributes. -If an archive contains a given attribute, there will be an instance of that attribute for every block in the block table, although -the attribute will be meaningless if the block is not a file. The order of the attributes for blocks correspond to the order of the -blocks in the block table, and are of the same number. The attributes are stored in parallel arrays in the "(attributes)" file, -in the archive. The attributes corresponding to this file need not be valid (and logically cannot be). Unlike all the other -structures in the MoPaQ format, entries in the extended attributes are NOT guaranteed to be aligned. Also note that in some -archives, malicious zeroing of the attributes has been observed, perhaps with the intent of breaking archive viewers. This -file is structured as follows: - -00h: int32 Version : Specifies the extended attributes format version. For now, must be 100. -04h: int32 AttributesPresent : Bit mask of the extended attributes present in the archive: -	00000001h: File CRC32s. -	00000002h: File timestamps. -	00000004h: File MD5s. -08h: int32(BlockTableEntries) CRC32s : CRC32s of the (uncompressed) file data for each block in the archive. Omitted if the -archive does not have CRC32s. immediately after CRC32s: FILETIME(BlockTableEntries) Timestamps : Timestamps for each block -in the archive. The format is that of the Windows FILETIME structure. Omitted if the archive does not have timestamps. -immediately after Timestamps: MD5(BlockTableEntries) MD5s : MD5s of the (uncompressed) file data for each block in the archive. -Omitted if the archive does not have MD5s. - -2.8 WEAK DIGITAL SIGNATURE -The weak digital signature is a digital signature using Microsoft CryptoAPI. It is an implimentation of the RSASSA-PKCS1-v1_5 -digital signature protocol, using the MD5 hashing algorithm and a 512-bit (weak) RSA key (for more information about this -protocol, see the RSA Labs PKCS1 specification). The public key and exponent are stored in a resource in Storm. The signature -is stored uncompressed, unencrypted in the file "(signature)" in the archive. The archive is hashed from the beginning of the -archive (ArchiveOffset in the containing file) to the end of the archive (the length indicated by ArchiveSize); the signature -file is added to the archive before signing, and the space occupied by the file is considered to be all binary 0s during -signing/verification. This file is structured as follows: - -00h: int32 Unknown : Must be 0. -04h: int32 Unknown : must be 0. -08h: int512 Signature : The digital signature. Like all other numbers in the MoPaQ format, this is stored in little-endian order. - -2.9 STRONG DIGITAL SIGNATURE -The strong digital signature uses a simple proprietary implementation of RSA signing, using the SHA-1 hashing algorithm and -a 2048-bit (strong) RSA key. The default public key and exponent are stored in Storm, but other keys may be used as well. -The strong digital signature is stored immediately after the archive, in the containing file; the entire archive (ArchiveSize -bytes, starting at ArchiveOffset in the containing file) is hashed as a single block. The signature has the following format: - -00h: char(4) Magic : Indicates the presence of a digital signature. Must be "NGIS" ("SIGN" backwards). -04h: int2048 Signature : The digital signature, stored in little-endian format. - -When the Signature field is decrypted with the public key and exponent, and the result stored in little-endian order, it is structured as follows: - -00h: byte Padding : Must be 0Bh. -01h: byte(235) Padding : Must be BBh. -ECh: byte(20) SHA-1 : SHA-1 hash of the archive, in standard SHA-1 format. - -3. ALGORITHM SOURCE CODE -3.1 ENCRYPTION/DECRYPTION -I believe this was derived at some point from code in StormLib. Assumes the long type to be 32 bits, and the machine to be little endian order. - -unsigned long dwCryptTable[0x500]; - -void InitializeCryptTable() -{ -    unsigned long seed   = 0x00100001; -    unsigned long index1 = 0; -    unsigned long index2 = 0; -    int   i; - -    for (index1 = 0; index1 < 0x100; index1++) -    { -        for (index2 = index1, i = 0; i < 5; i++, index2 += 0x100) -        { -            unsigned long temp1, temp2; - -            seed  = (seed * 125 + 3) % 0x2AAAAB; -            temp1 = (seed & 0xFFFF) << 0x10; - -            seed  = (seed * 125 + 3) % 0x2AAAAB; -            temp2 = (seed & 0xFFFF); - -            dwCryptTable[index2] = (temp1 | temp2); -        } -    } -} - -void EncryptData(void *lpbyBuffer, unsigned long dwLength, unsigned long dwKey) -{ -    unsigned long *lpdwBuffer = (unsigned long *)lpbyBuffer; -    unsigned long seed = 0xEEEEEEEE; -    unsigned long ch; - -	assert(lpbyBuffer); - -    dwLength /= sizeof(unsigned long); - -    while(dwLength-- > 0) -    { -        seed += dwCryptTable[0x400 + (dwKey & 0xFF)]; -        ch = *lpdwBuffer ^ (dwKey + seed); - -        dwKey = ((~dwKey << 0x15) + 0x11111111) | (dwKey >> 0x0B); -        seed = *lpdwBuffer + seed + (seed << 5) + 3; - -		*lpdwBuffer++ = ch; -    } -} - -void DecryptData(void *lpbyBuffer, unsigned long dwLength, unsigned long dwKey) -{ -	unsigned long *lpdwBuffer = (unsigned long *)lpbyBuffer; -    unsigned long seed = 0xEEEEEEEE; -    unsigned long ch; - -	assert(lpbyBuffer); - -    dwLength /= sizeof(unsigned long); - -    while(dwLength-- > 0) -    { -        seed += dwCryptTable[0x400 + (dwKey & 0xFF)]; -        ch = *lpdwBuffer ^ (dwKey + seed); - -        dwKey = ((~dwKey << 0x15) + 0x11111111) | (dwKey >> 0x0B); -        seed = ch + seed + (seed << 5) + 3; - -		*lpdwBuffer++ = ch; -    } -} - -3.2 HASHING -Based on code from StormLib. - -// Different types of hashes to make with HashString -#define MPQ_HASH_TABLE_OFFSET	0 -#define MPQ_HASH_NAME_A	1 -#define MPQ_HASH_NAME_B	2 -#define MPQ_HASH_FILE_KEY	3 - -unsigned long HashString(const char *lpszString, unsigned long dwHashType) -{ -    unsigned long  seed1 = 0x7FED7FED; -    unsigned long  seed2 = 0xEEEEEEEE; -    int    ch; - -    while (*lpszString != 0) -    { -        ch = toupper(*lpszString++); - -        seed1 = dwCryptTable[(dwHashType * 0xFF) + ch] ^ (seed1 + seed2); -        seed2 = ch + seed1 + seed2 + (seed2 << 5) + 3; -    } -    return seed1; -} - -3.3 CONVERSION OF FILETIME AND time_t - -#define EPOCH_OFFSET 116444736000000000ULL	// Number of 100 ns units between 01/01/1601 and 01/01/1970 - -bool GetTimeFromFileTime(FILETIME &fileTime, time_t &time) -{ -	// The FILETIME represents a 64-bit integer: the number of 100 ns units since January 1, 1601 -	unsigned long long nTime = ((unsigned long long)fileTime.dwHighDateTime << 32) + fileTime.dwLowDateTime; - -	if (nTime < EPOCH_OFFSET) -		return false; - -	nTime -= EPOCH_OFFSET;	// Convert the time base from 01/01/1601 to 01/01/1970 -	nTime /= 10000000ULL;	// Convert 100 ns to sec - -	time = (time_t)nTime; - -	// Test for overflow (FILETIME is 64 bits, time_t is 32 bits) -	if ((nTime - (unsigned long long)time) > 0) -		return false; - -	return true; -} - -void GetFileTimeFromTime(time_t &time, FILETIME &fileTime) -{ -	unsigned long long nTime = (unsigned long long)time; - -	nTime *= 10000000ULL; -	nTime += EPOCH_OFFSET; - -	fileTime.dwLowDateTime = (DWORD)nTime; -	fileTime.dwHighDateTime = (DWORD)(nTime >> 32); -} diff --git a/contrib/vmap_extractor_v2/doc/MoPaQ_1.0.txt b/contrib/vmap_extractor_v2/doc/MoPaQ_1.0.txt deleted file mode 100644 index 6a21eca5472..00000000000 --- a/contrib/vmap_extractor_v2/doc/MoPaQ_1.0.txt +++ /dev/null @@ -1,421 +0,0 @@ -THE MOPAQ ARCHIVE FORMAT -v1.0 (Friday, September 1, 2006) -by Justin Olbrantz(Quantam) - -Distribution and reproduction of this specification are allowed without limitation, as long as it is not altered. Quotation in other works is freely allowed, as long as the source and author of the quote are stated. - -TABLE OF CONTENTS -1. Introduction to the MoPaQ Format -2. The MoPaQ Format -	2.1 General Archive Layout -	2.2 Archive Header -	2.3 Block Table -	2.4 Extended Block Table -	2.5 Hash Table -	2.6 File Data -	2.7 Listfile -	2.8 Extended Attributes -	2.9 Weak (Old) Digital Signature -	2.10 Strong (New) Digital Signature -3. Algorithm Source Code -	3.1 Encryption/Decryption -	3.2 Hashing and File Key Computation -	3.3 Finding Files -	3.4 Deleting Files -	3.5 Conversion of FILETIME and time_t -	3.6 Forming a 64-bit Large Archive Offset from 32-bit and 16-bit Components -4. Revision History - -1. INTRODUCTION TO THE MOPAQ FORMAT -The MoPaQ (or MPQ) format is an archive file format designed by Mike O'Brien (hence the name Mike O'brien PaCK) at Blizzard Entertainment. The format has been used in all Blizzard games since (and including) Diablo. It is heavily optimized to be a read-only game archive format, and excels at this role.  - -The Blizzard MoPaQ-reading functions are contained in the Storm module, which my be either statically or dynamically linked. The Blizzard MoPaQ-writing functions are contained in the MPQAPI module, which is always statically linked. - -StormLib - mentioned several times in this specification - is an open-source MoPaQ reading and writing library written by Ladislav Zezula (no affiliation with Blizzard Entertainment). While it's a bit dated, and does not support all of the newer MoPaQ features, it contains source code to the more exotic compression methods used by MoPaQ, such as the PKWare implode algorithm, MoPaQ's huffman compression algorithm, and the IMA ADPCM compression used by MoPaQ. - -2. THE MOPAQ FORMAT -All numbers in the MoPaQ format are in little endian byte order; signed numbers use the two's complement system. Data types are listed either as int (integer, the number of bits specified), byte (8 bits), or char (bytes which contain ASCII characters). All sizes and offsets are in bytes, unless specified otherwise. Structure members are listed in the following general form: -offset from the beginning of the structure: data type(array size) member name : member description - -2.1 GENERAL ARCHIVE LAYOUT -- Archive Header -- File Data -- File Data - Special Files -- Hash Table -- Block Table -- Extended Block Table -- Strong Digital signature - -This is the usual archive format, but it is not mandatory. Some archives have been observed placing the hash table and file table after the archive header, and before the file data. - -2.2 ARCHIVE HEADER -00h: char(4) Magic : Indicates that the file is a MoPaQ archive. Must be ASCII "MPQ" 1Ah. -04h: int32 HeaderSize : Size of the archive header. -08h: int32 ArchiveSize : Size of the whole archive, including the header. Does not include the strong digital signature, if present. This size is used, among other things, for determining the region to hash in computing the digital signature. This field is deprecated in the Burning Crusade MoPaQ format, and the size of the archive is calculated as the size from the beginning of the archive to the end of the hash table, block table, or extended block table (whichever is largest). -0Ch: int16 FormatVersion : MoPaQ format version. MPQAPI will not open archives where this is negative. Known versions: -	0000h: Original format. HeaderSize should be 20h, and large archives are not supported. -	0001h: Burning Crusade format. Header size should be 2Ch, and large archives are supported. -0Eh: int8 SectorSizeShift : Power of two exponent specifying the number of 512-byte disk sectors in each logical sector in the archive. The size of each logical sector in the archive is 512 * 2^SectorSizeShift. Bugs in the Storm library dictate that this should always be 3 (4096 byte sectors). -10h: int32 HashTableOffset : Offset to the beginning of the hash table, relative to the beginning of the archive. -14h: int32 BlockTableOffset : Offset to the beginning of the block table, relative to the beginning of the archive. -18h: int32 HashTableEntries : Number of entries in the hash table. Must be a power of two, and must be less than 2^16 for the original MoPaQ format, or less than 2^20 for the Burning Crusade format. -1Ch: int32 BlockTableEntries : Number of entries in the block table. -Fields only present in the Burning Crusade format and later: -20h: int64 ExtendedBlockTableOffset : Offset to the beginning of the extended block table, relative to the beginning of the archive. -28h: int16 HashTableOffsetHigh : High 16 bits of the hash table offset for large archives. -2Ah: int16 BlockTableOffsetHigh : High 16 bits of the block table offset for large archives. - -The archive header is the first structure in the archive, at archive offset 0; however, the archive does not need to be at offset 0 of the containing file. The offset of the archive in the file is referred to here as ArchiveOffset. If the archive is not at the beginning of the file, it must begin at a disk sector boundary (512 bytes). Early versions of Storm require that the archive be at the end of the containing file (ArchiveOffset + ArchiveSize = file size), but this is not required in newer versions (due to the strong digital signature not being considered a part of the archive). - -2.3 BLOCK TABLE -The block table contains entries for each region in the archive. Regions may be either files, empty space, which may be overwritten by new files (typically this space is from deleted file data), or unused block table entries. Empty space entries should have BlockOffset and BlockSize nonzero, and FileSize and Flags zero; unused block table entries should have BlockSize, FileSize, and Flags zero. The block table is encrypted, using the hash of "(block table)" as the key. Each entry is structured as follows: - -00h: int32 BlockOffset : Offset of the beginning of the block, relative to the beginning of the archive. -04h: int32 BlockSize : Size of the block in the archive. -08h: int32 FileSize : Size of the file data stored in the block. Only valid if the block is a file; otherwise meaningless, and should be 0. If the file is compressed, this is the size of the uncompressed file data. -0Ch: int32 Flags : Bit mask of the flags for the block. The following values are conclusively identified: -	80000000h: Block is a file, and follows the file data format; otherwise, block is free space or unused. If the block is not a file, all other flags should be cleared, and FileSize should be 0. -	01000000h: File is stored as a single unit, rather than split into sectors. -	00020000h: The file's encryption key is adjusted by the block offset and file size (explained in detail in the File Data section). File must be encrypted. -	00010000h: File is encrypted. -	00000200h: File is compressed. File cannot be imploded. -	00000100h: File is imploded. File cannot be compressed. - -2.4 EXTENDED BLOCK TABLE -The extended block table was added to support archives larger than 4 gigabytes (2^32 bytes). The table contains the upper bits of the archive offsets for each block in the block table. It is simply an array of int16s, which become bits 32-47 of the archive offsets for each block, with bits 48-63 being zero. Individual blocks in the archive are still limited to 4 gigabytes in size. This table is only present in Burning Crusade format archives that exceed 4 gigabytes size. - -As of the Burning Crusade Friends and Family beta, this table is not encrypted. - -2.5 HASH TABLE -Instead of storing file names, for quick access MoPaQs use a fixed, power of two-size hash table of files in the archive. A file is uniquely identified by its file path, its language, and its platform. The home entry for a file in the hash table is computed as a hash of the file path. In the event of a collision (the home entry is occupied by another file), progressive overflow is used, and the file is placed in the next available hash table entry. Searches for a desired file in the hash table proceed from the home entry for the file until either the file is found, the entire hash table is searched, or an empty hash table entry (FileBlockIndex of FFFFFFFFh) is encountered. The hash table is encrypted using the hash of "(hash table)" as the key. Each entry is structured as follows: - -00h: int32 FilePathHashA : The hash of the file path, using method A. -04h: int32 FilePathHashB : The hash of the file path, using method B. -08h: int16 Language : The language of the file. This is a Windows LANGID data type, and uses the same values. 0 indicates the default language (American English), or that the file is language-neutral. -0Ah: int8 Platform : The platform the file is used for. 0 indicates the default platform. No other values have been observed. -0Ch: int32 FileBlockIndex : If the hash table entry is valid, this is the index into the block table of the file. Otherwise, one of the following two values: -	FFFFFFFFh: Hash table entry is empty, and has always been empty. Terminates searches for a given file. -	FFFFFFFEh: Hash table entry is empty, but was valid at some point (in other words, the file was deleted). Does not terminate searches for a given file. - -2.6 FILE DATA -The data for each file is composed of the following structure: -00h: int32(SectorsInFile + 1) SectorOffsetTable : Offsets to the start of each sector, relative to the beginning of the file data. The last entry contains the file size, making it possible to easily calculate the size of any given sector. This table is not present if this information can be calculated (see details below). -immediately following SectorOffsetTable: SECTOR Sectors(SectorsInFile) : Data of each sector in the file, packed end to end (see details below). - -Normally, file data is split up into sectors, for simple streaming. All sectors, save for the last, will contain as many bytes of file data as specified in the archive header's SectorSizeShift; the last sector may contain less than this, depending on the size of the entire file's data. If the file is compressed or imploded, the sector will be smaller or the same size as the file data it contains. Individual sectors in a compressed or imploded file may be stored uncompressed; this occurs if and only if the file data the sector contains could not be compressed by the algorithm(s) used (if the compressed sector size was greater than or equal to the size of the file data), and is indicated by the sector's size in SectorOffsetTable being equal to the size of the file data in the sector (which may be calculated from the FileSize).  - -The format of each sector depends on the kind of sector it is. Uncompressed sectors are simply the the raw file data contained in the sector. Imploded sectors are the raw compressed data following compression with the implode algorithm (these sectors can only be in imploded files). Compressed sectors (only found in compressed - not imploded - files) are compressed with one or more compression algorithms, and have the following structure: -00h: byte CompressionMask : Mask of the compression types applied to this sector. If multiple compression types are used, they are applied in the order listed below, and decompression is performed in the opposite order. This byte counts towards the total sector size, meaning that the sector will be stored uncompressed if the data cannot be compressed by at least two bytes; as well, this byte is encrypted with the sector data, if applicable. The following compression types are defined (for implementations of these algorithms, see StormLib): -	40h: IMA ADPCM mono -	80h: IMA ADPCM stereo -	01h: Huffman encoded -	02h: Deflated (see ZLib) -	08h: Imploded (see PKWare Data Compression Library) -	10h: BZip2 compressed (see BZip2) -01h: byte(SectorSize - 1) SectorData : The compressed data for the sector. - -If the file is stored as a single unit (indicated in the file's Flags), there is effectively only a single sector, which contains the entire file data. - -If the file is encrypted, each sector (after compression/implosion, if applicable) is encrypted with the file's key. The base key for a file is determined by a hash of the file name stripped of the directory (i.e. the key for a file named "directory\file" would be computed as the hash of "file"). If this key is adjusted, as indicated in the file's Flags, the final key is calculated as ((base key + BlockOffset - ArchiveOffset) XOR FileSize) (StormLib incorrectly uses an AND in place of the XOR). Each sector is encrypted using the key + the 0-based index of the sector in the file. The SectorOffsetTable, if present, is encrypted using the key - 1. - -The SectorOffsetTable is omitted when the sizes and offsets of all sectors in the file are calculatable from the FileSize. This can happen in several circumstances. If the file is not compressed/imploded, then the size and offset of all sectors is known, based on the archive's SectorSizeShift. If the file is stored as a single unit compressed/imploded, then the SectorOffsetTable is omitted, as the single file "sector" corresponds to BlockSize and FileSize, as mentioned previously. However, the SectorOffsetTable will be present if the file is compressed/imploded and the file is not stored as a single unit, even if there is only a single sector in the file (the size of the file is less than or equal to the archive's sector size). - -2.7 LISTFILE -The listfile is a very simple extension to the MoPaQ format that contains the file paths of (most) files in the archive. The languages and platforms of the files are not stored in the listfile. The listfile is contained in the file "(listfile)" (default language and platform), and is simply a text file with file paths separated by ';', 0Dh, 0Ah, or some combination of these. The file "(listfile)" may not be listed in the listfile. - -2.8 EXTENDED ATTRIBUTES -The extended attributes are optional file attributes for files in the block table. These attributes were added at times after the MoPaQ format was already finalized, and it is not necessary for every archive to have all (or any) of the extended attributes. If an archive contains a given attribute, there will be an instance of that attribute for every block in the block table, although the attribute will be meaningless if the block is not a file. The order of the attributes for blocks correspond to the order of the blocks in the block table, and are of the same number. The attributes are stored in parallel arrays in the "(attributes)" file (default language and platform), in the archive. The attributes corresponding to this file need not be valid (and logically cannot be). Unlike all the other structures in the MoPaQ format, entries in the extended attributes are NOT guaranteed to be aligned. Also note that in some archives, malicious zeroing of the attributes has been observed, perhaps with the intent of breaking archive viewers. This file is structured as follows: - -00h: int32 Version : Specifies the extended attributes format version. For now, must be 100. -04h: int32 AttributesPresent : Bit mask of the extended attributes present in the archive: -	00000001h: File CRC32s. -	00000002h: File timestamps. -	00000004h: File MD5s. -08h: int32(BlockTableEntries) CRC32s : CRC32s of the (uncompressed) file data for each block in the archive. Omitted if the archive does not have CRC32s. -immediately after CRC32s: FILETIME(BlockTableEntries) Timestamps : Timestamps for each block in the archive. The format is that of the Windows FILETIME structure. Omitted if the archive does not have timestamps. -immediately after Timestamps: MD5(BlockTableEntries) MD5s : MD5s of the (uncompressed) file data for each block in the archive. Omitted if the archive does not have MD5s. - -2.9 WEAK DIGITAL SIGNATURE -The weak digital signature is a digital signature using Microsoft CryptoAPI. It is an implimentation of the RSASSA-PKCS1-v1_5 digital signature protocol, using the MD5 hashing algorithm and a 512-bit (weak) RSA key (for more information about this protocol, see the RSA Labs PKCS1 specification). The public key and exponent are stored in a resource in Storm, the private key is stored in a separate file, whose filename is passed to MPQAPI (the private key is not stored in MPQAPI). The signature is stored uncompressed, unencrypted in the file "(signature)" (default language and platform) in the archive. The archive is hashed from the beginning of the archive (ArchiveOffset in the containing file) to the end of the archive (the length indicated by ArchiveSize, or calculated in the Burning Crusade MoPaQ format); the signature file is added to the archive before signing, and the space occupied by the file is considered to be all binary 0s during signing/verification. This file is structured as follows: - -00h: int32 Unknown : Must be 0. -04h: int32 Unknown : Must be 0. -08h: int512 Signature : The digital signature. Like all other numbers in the MoPaQ format, this is stored in little-endian order. The structure of this, when decrypted, follows the RSASSA-PKCS1-v1_5 specification; this format is rather icky to work with (I wrote a program to verify this signature using nothing but an MD5 function and huge integer functions; it wasn't pleasant), and best left to an encryption library such as Cryto++. - -2.10 STRONG DIGITAL SIGNATURE -The strong digital signature uses a simple proprietary implementation of RSA signing, using the SHA-1 hashing algorithm and a 2048-bit (strong) RSA key. The default public key and exponent are stored in Storm, but other keys may be used as well. The strong digital signature is stored immediately after the archive, in the containing file; the entire archive (ArchiveSize bytes, starting at ArchiveOffset in the containing file) is hashed as a single block. The signature has the following format: - -00h: char(4) Magic : Indicates the presence of a digital signature. Must be "NGIS" ("SIGN" backwards). -04h: int2048 Signature : The digital signature, stored in little-endian format. - -When the Signature field is decrypted with the public key and exponent, and the resulting large integer is stored in little-endian order, it is structured as follows: - -00h: byte Padding : Must be 0Bh. -01h: byte(235) Padding : Must be BBh. -ECh: byte(20) SHA-1 : SHA-1 hash of the archive, in standard SHA-1 byte order. - -3. ALGORITHM SOURCE CODE -All of the sample code here assumes little endian machine byte order, that the short type is 16 bits, that the long type is 32 bits, and that the long long type is 64 bits. Adjustments must be made if these assumptions are not correct on a given platform. All code not credited otherwise was written by myself in the writing of this specification. - -3.1 ENCRYPTION/DECRYPTION -Based on code from StormLib. - -unsigned long dwCryptTable[0x500]; - -// The encryption and hashing functions use a number table in their procedures. This table must be initialized before the functions are called the first time. -void InitializeCryptTable() -{ -    unsigned long seed   = 0x00100001; -    unsigned long index1 = 0; -    unsigned long index2 = 0; -    int   i; - -    for (index1 = 0; index1 < 0x100; index1++) -    { -        for (index2 = index1, i = 0; i < 5; i++, index2 += 0x100) -        { -            unsigned long temp1, temp2; - -            seed  = (seed * 125 + 3) % 0x2AAAAB; -            temp1 = (seed & 0xFFFF) << 0x10; - -            seed  = (seed * 125 + 3) % 0x2AAAAB; -            temp2 = (seed & 0xFFFF); - -            dwCryptTable[index2] = (temp1 | temp2); -        } -    } -} - -void EncryptData(void *lpbyBuffer, unsigned long dwLength, unsigned long dwKey) -{ -    assert(lpbyBuffer); - -    unsigned long *lpdwBuffer = (unsigned long *)lpbyBuffer; -    unsigned long seed = 0xEEEEEEEE; -    unsigned long ch; - -    dwLength /= sizeof(unsigned long); - -    while(dwLength-- > 0) -    { -        seed += dwCryptTable[0x400 + (dwKey & 0xFF)]; -        ch = *lpdwBuffer ^ (dwKey + seed); - -        dwKey = ((~dwKey << 0x15) + 0x11111111) | (dwKey >> 0x0B); -        seed = *lpdwBuffer + seed + (seed << 5) + 3; - -		*lpdwBuffer++ = ch; -    } -} - -void DecryptData(void *lpbyBuffer, unsigned long dwLength, unsigned long dwKey) -{ -    assert(lpbyBuffer); - -    unsigned long *lpdwBuffer = (unsigned long *)lpbyBuffer; -    unsigned long seed = 0xEEEEEEEEL; -    unsigned long ch; - -    dwLength /= sizeof(unsigned long); - -    while(dwLength-- > 0) -    { -        seed += dwCryptTable[0x400 + (dwKey & 0xFF)]; -        ch = *lpdwBuffer ^ (dwKey + seed); - -        dwKey = ((~dwKey << 0x15) + 0x11111111L) | (dwKey >> 0x0B); -        seed = ch + seed + (seed << 5) + 3; - -		*lpdwBuffer++ = ch; -    } -} - -3.2 HASHING AND FILE KEY COMPUTATION -These functions may have been derived from StormLib code at some point in the very distant past. It was so long ago that I don't remember for certain. - -// Different types of hashes to make with HashString -#define MPQ_HASH_TABLE_OFFSET	0 -#define MPQ_HASH_NAME_A	1 -#define MPQ_HASH_NAME_B	2 -#define MPQ_HASH_FILE_KEY	3 - -// Based on code from StormLib. -unsigned long HashString(const char *lpszString, unsigned long dwHashType) -{ -    assert(lpszString); -    assert(dwHashType <= MPQ_HASH_FILE_KEY); -     -    unsigned long  seed1 = 0x7FED7FEDL; -    unsigned long  seed2 = 0xEEEEEEEEL; -    int    ch; - -    while (*lpszString != 0) -    { -        ch = toupper(*lpszString++); - -        seed1 = dwCryptTable[(dwHashType * 0x100) + ch] ^ (seed1 + seed2); -        seed2 = ch + seed1 + seed2 + (seed2 << 5) + 3; -    } -    return seed1; -} - -#define BLOCK_OFFSET_ADJUSTED_KEY 0x00020000L - -unsigned long ComputeFileKey(const char *lpszFilePath, const BlockTableEntry &blockEntry, unsigned long nArchiveOffset) -{ -	assert(lpszFilePath); -	 -	// Find the file name part of the path -	const char *lpszFileName = strrchr(lpszFilePath, '\\'); -	if (lpszFileName) -		lpszFileName++;	// Skip the \ -	else -		lpszFileName = lpszFilePath; -		 -	// Hash the name to get the base key -	unsigned long nFileKey = HashString(lpszFileName, MPQ_HASH_FILE_KEY); -	 -	// Offset-adjust the key if necessary -	if (blockEntry.Flags & BLOCK_OFFSET_ADJUSTED_KEY) -		nFileKey = (nFileKey + blockEntry.BlockOffset) ^ blockEntry.FileSize; -		 -	return nFileKey; -} - -3.3 FINDING FILES - -#define MPQ_HASH_ENTRY_EMPTY 0xFFFFFFFFL -#define MPQ_HASH_ENTRY_DELETED 0xFFFFFFFEL - -bool FindFileInHashTable(const HashTableEntry *lpHashTable, unsigned long nHashTableSize, const char *lpszFilePath, unsigned short nLang, unsigned char nPlatform, unsigned long &iFileHashEntry) -{ -	assert(lpHashTable); -	assert(nHashTableSize); -	assert(lpszFilePath); -	 -	// Find the home entry in the hash table for the file -	unsigned long iInitEntry = HashString(lpszFilePath, MPQ_HASH_TABLE_OFFSET) & (nHashTableSize - 1); -		 -	// Is there anything there at all? -	if (lpHashTable[iInitEntry].FileBlockIndex == MPQ_HASH_ENTRY_EMPTY) -		return false; -		 -	// Compute the hashes to compare the hash table entry against -	unsigned long nNameHashA = HashString(lpszFilePath, MPQ_HASH_NAME_A), -		nNameHashB = HashString(lpszFilePath, MPQ_HASH_NAME_B), -		iCurEntry = iInitEntry; -		 -	// Check each entry in the hash table till a termination point is reached -	do -	{ -		if (lpHashTable[iCurEntry].FileBlockIndex != MPQ_HASH_ENTRY_DELETED) -		{ -			if (lpHashTable[iCurEntry].FilePathHashA == nNameHashA  -				&& lpHashTable[iCurEntry].FilePathHashB == nNameHashB -				&& lpHashTable[iCurEntry].Language == nLang -				&& lpHashTable[iCurEntry].Platform == nPlatform) -			{ -				iFileHashEntry = iCurEntry; -				 -				return true; -			} -		} -			 -		iCurEntry = (iCurEntry + 1) & (nHashTableSize - 1); -	} while (iCurEntry != iInitEntry && lpHashTable[iCurEntry].FileBlockIndex != MPQ_HASH_ENTRY_EMPTY); -	 -	return false; -} - -3.4 DELETING FILES - -bool DeleteFile(HashTableEntry *lpHashTable, unsigned long nHashTableSize, BlockTableEntry *lpBlockTable, const char *lpszFilePath, unsigned short nLang, unsigned char nPlatform) -{ -	assert(lpHashTable); -	assert(nHashTableSize); -	assert(lpBlockTable); -	 -	// Find the file in the hash table -	unsigned long iFileHashEntry; -	 -	if (!FindFileInHashTable(lpHashTable, nHashTableSize, lpszFilePath, nLang, nPlatform, iFileHashEntry)) -		return false; -	 -	// Get the block table index before we nuke the hash table entry -	unsigned long iFileBlockEntry = lpHashTable[iFileHashEntry].FileBlockIndex; -	 -	// Delete the file's entry in the hash table -	memset(&lpHashTable[iFileHashEntry], 0xFF, sizeof(HashTableEntry)); -	 -	// If the next entry is empty, mark this one as empty; otherwise, mark this as deleted. -	if (lpHashTable[(iFileHashEntry + 1) & (nHashTableSize - 1)].FileBlockIndex == MPQ_HASH_ENTRY_EMPTY) -		lpHashTable[iFileHashEntry].FileBlockIndex = MPQ_HASH_ENTRY_EMPTY; -	else -		lpHashTable[iFileHashEntry].FileBlockIndex = MPQ_HASH_ENTRY_DELETED; -	 -	// If the block occupies space, mark the block as free space; otherwise, clear the block table entry. -	if (lpBlockTable[iFileBlockEntry].BlockSize > 0) -	{ -		lpBlockTable[iFileBlockEntry].FileSize = 0; -		lpBlockTable[iFileBlockEntry].Flags = 0; -	} -	else -		memset(&lpBlockTable[iFileBlockEntry], 0, sizeof(BlockTableEntry); -		 -	return true; -} - -3.5 CONVERSION OF FILETIME AND time_t -This code assumes that the base ("zero") date for time_t is 01/01/1970. This is true on Windows, Unix System V systems, and Mac OS X. It is unknown whether this is true on all other platforms. You'll need to research this yourself, if you plan on porting it somewhere else. - -#define EPOCH_OFFSET 116444736000000000ULL	// Number of 100 ns units between 01/01/1601 and 01/01/1970 - -bool GetTimeFromFileTime(const FILETIME &fileTime, time_t &time) -{ -	// The FILETIME represents a 64-bit integer: the number of 100 ns units since January 1, 1601 -	unsigned long long nTime = ((unsigned long long)fileTime.dwHighDateTime << 32) + fileTime.dwLowDateTime; - -	if (nTime < EPOCH_OFFSET) -		return false; - -	nTime -= EPOCH_OFFSET;	// Convert the time base from 01/01/1601 to 01/01/1970 -	nTime /= 10000000ULL;	// Convert 100 ns to sec - -	time = (time_t)nTime; - -	// Test for overflow (FILETIME is 64 bits, time_t is 32 bits) -	if ((nTime - (unsigned long long)time) > 0) -		return false; - -	return true; -} - -void GetFileTimeFromTime(const time_t &time, FILETIME &fileTime) -{ -	unsigned long long nTime = (unsigned long long)time; - -	nTime *= 10000000ULL; -	nTime += EPOCH_OFFSET; - -	fileTime.dwLowDateTime = (DWORD)nTime; -	fileTime.dwHighDateTime = (DWORD)(nTime >> 32); -} - -3.6 FORMING A 64-BIT LARGE ARCHIVE OFFSET FROM 32-BIT AND 16-BIT COMPONENTS -unsigned long long MakeLargeArchiveOffset(unsigned long nOffsetLow, unsigned short nOffsetHigh) -{ -	return ((unsigned long long)nOffsetHigh << 32) + (unsigned long long)nOffsetLow; -} - -4. REVISION HISTORY -1.0 -	- Updated to include most of the changes found in the Burning Crusade Friends and Family beta - -0.91. -	- Updated several structure member descriptions -	- Listed the full set of characters that can separate list file entries -	- Noted that (attributes), (listfile), and (signature) use the default language and platform codes -	- Redid part of the file data specs to clarify the format of sectors -	- Enhanced descriptions of the different kinds of block table entries -	- Added ComputeFileKey, FindFileInHashTable, and DeleteFile source
\ No newline at end of file diff --git a/contrib/vmap_extractor_v2/stormlib/Makefile b/contrib/vmap_extractor_v2/stormlib/Makefile deleted file mode 100644 index e3b19e36d6f..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/Makefile +++ /dev/null @@ -1,58 +0,0 @@ -######################################################################## -# -# Makefile for compiling StormLib under linux -# -# Author: Marko Friedemann <marko.friedemann@bmx-chemnitz.de> -# Created at: Mon Jan 29 18:26:01 CEST 2001 -# Computer: whiplash.flachland-chemnitz.de  -# System: Linux 2.4.0 on i686 -#     -# Copyright (c) 2001 BMX-Chemnitz.DE All rights reserved. -# -######################################################################## - -FILES.cpp = SCommon.cpp SCompression.cpp SFileCompactArchive.cpp \ -	SFileCreateArchiveEx.cpp SFileExtractFile.cpp SFileFindFile.cpp \ -	SListFile.cpp SFileOpenArchive.cpp SFileOpenFileEx.cpp SFileReadFile.cpp \ -	StormPortLinux.cpp wave/wave.cpp huffman/huff.cpp \ -	pklib/crc32.cpp pklib/explode.cpp pklib/implode.cpp  -FILES.o = $(FILES.cpp:.cpp=.o) - -LIB = libStorm.so - -CXX = g++ -CFLAGS = -Wall -s -D__SYS_ZLIB -I_FLAGS =  -LDFLAGS = -lz -lbz2 - -all: $(LIB) - -$(LIB): $(FILES.o) -	$(LD) -shared $(LDFLAGS) -o $(LIB) $(FILES.o) - -%.o: %.cpp -	$(CXX) $(CFLAGS) -c $< -o $@ - -clean: -	$(RM) $(FILES.o) $(LIB) - -new: clean all - -mrproper: clean -	$(RM) Makefile.deps - -mrnew: mrproper new - -install: $(LIB) -	install $(I_FLAGS) $(LIB) /usr/local/lib -	mkdir -p /usr/local/include/StormLib -	cp Storm.h /usr/local/include/StormLib -	cp StormPort.h /usr/local/include/StormLib -	ldconfig - -deps: -	$(CXX) -MM $(CFLAGS) $(FILES.cpp) > Makefile.deps -	 --include Makefile.deps - -.PHONY: all clean new mrpoper mrnew install deps diff --git a/contrib/vmap_extractor_v2/stormlib/bzip2/Makefile b/contrib/vmap_extractor_v2/stormlib/bzip2/Makefile deleted file mode 100644 index eea329a626e..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/bzip2/Makefile +++ /dev/null @@ -1,205 +0,0 @@ - -SHELL=/bin/sh - -# To assist in cross-compiling -CC=gcc -AR=ar -RANLIB=ranlib -LDFLAGS= - -BIGFILES=-D_FILE_OFFSET_BITS=64 -CFLAGS=-Wall -Winline -O -g $(BIGFILES) - -# Where you want it installed when you do 'make install' -PREFIX=/usr - - -OBJS= blocksort.o  \ -      huffman.o    \ -      crctable.o   \ -      randtable.o  \ -      compress.o   \ -      decompress.o \ -      bzlib.o - -all: libbz2.a bzip2 bzip2recover test - -bzip2: libbz2.a bzip2.o -	$(CC) $(CFLAGS) $(LDFLAGS) -o bzip2 bzip2.o -L. -lbz2 - -bzip2recover: bzip2recover.o -	$(CC) $(CFLAGS) $(LDFLAGS) -o bzip2recover bzip2recover.o - -libbz2.a: $(OBJS) -	rm -f libbz2.a -	$(AR) cq libbz2.a $(OBJS) -	@if ( test -f $(RANLIB) -o -f /usr/bin/ranlib -o \ -		-f /bin/ranlib -o -f /usr/ccs/bin/ranlib ) ; then \ -		echo $(RANLIB) libbz2.a ; \ -		$(RANLIB) libbz2.a ; \ -	fi - -check: test -test: bzip2 -	@cat words1 -	./bzip2 -1  < sample1.ref > sample1.rb2 -	./bzip2 -2  < sample2.ref > sample2.rb2 -	./bzip2 -3  < sample3.ref > sample3.rb2 -	./bzip2 -d  < sample1.bz2 > sample1.tst -	./bzip2 -d  < sample2.bz2 > sample2.tst -	./bzip2 -ds < sample3.bz2 > sample3.tst -	cmp sample1.bz2 sample1.rb2  -	cmp sample2.bz2 sample2.rb2 -	cmp sample3.bz2 sample3.rb2 -	cmp sample1.tst sample1.ref -	cmp sample2.tst sample2.ref -	cmp sample3.tst sample3.ref -	@cat words3 - -install: bzip2 bzip2recover -	if ( test ! -d $(PREFIX)/bin ) ; then mkdir -p $(PREFIX)/bin ; fi -	if ( test ! -d $(PREFIX)/lib ) ; then mkdir -p $(PREFIX)/lib ; fi -	if ( test ! -d $(PREFIX)/man ) ; then mkdir -p $(PREFIX)/man ; fi -	if ( test ! -d $(PREFIX)/man/man1 ) ; then mkdir -p $(PREFIX)/man/man1 ; fi -	if ( test ! -d $(PREFIX)/include ) ; then mkdir -p $(PREFIX)/include ; fi -	cp -f bzip2 $(PREFIX)/bin/bzip2 -	cp -f bzip2 $(PREFIX)/bin/bunzip2 -	cp -f bzip2 $(PREFIX)/bin/bzcat -	cp -f bzip2recover $(PREFIX)/bin/bzip2recover -	chmod a+x $(PREFIX)/bin/bzip2 -	chmod a+x $(PREFIX)/bin/bunzip2 -	chmod a+x $(PREFIX)/bin/bzcat -	chmod a+x $(PREFIX)/bin/bzip2recover -	cp -f bzip2.1 $(PREFIX)/man/man1 -	chmod a+r $(PREFIX)/man/man1/bzip2.1 -	cp -f bzlib.h $(PREFIX)/include -	chmod a+r $(PREFIX)/include/bzlib.h -	cp -f libbz2.a $(PREFIX)/lib -	chmod a+r $(PREFIX)/lib/libbz2.a -	cp -f bzgrep $(PREFIX)/bin/bzgrep -	ln $(PREFIX)/bin/bzgrep $(PREFIX)/bin/bzegrep -	ln $(PREFIX)/bin/bzgrep $(PREFIX)/bin/bzfgrep -	chmod a+x $(PREFIX)/bin/bzgrep -	cp -f bzmore $(PREFIX)/bin/bzmore -	ln $(PREFIX)/bin/bzmore $(PREFIX)/bin/bzless -	chmod a+x $(PREFIX)/bin/bzmore -	cp -f bzdiff $(PREFIX)/bin/bzdiff -	ln $(PREFIX)/bin/bzdiff $(PREFIX)/bin/bzcmp -	chmod a+x $(PREFIX)/bin/bzdiff -	cp -f bzgrep.1 bzmore.1 bzdiff.1 $(PREFIX)/man/man1 -	chmod a+r $(PREFIX)/man/man1/bzgrep.1 -	chmod a+r $(PREFIX)/man/man1/bzmore.1 -	chmod a+r $(PREFIX)/man/man1/bzdiff.1 -	echo ".so man1/bzgrep.1" > $(PREFIX)/man/man1/bzegrep.1 -	echo ".so man1/bzgrep.1" > $(PREFIX)/man/man1/bzfgrep.1 -	echo ".so man1/bzmore.1" > $(PREFIX)/man/man1/bzless.1 -	echo ".so man1/bzdiff.1" > $(PREFIX)/man/man1/bzcmp.1 - -clean:  -	rm -f *.o libbz2.a bzip2 bzip2recover \ -	sample1.rb2 sample2.rb2 sample3.rb2 \ -	sample1.tst sample2.tst sample3.tst - -blocksort.o: blocksort.c -	@cat words0 -	$(CC) $(CFLAGS) -c blocksort.c -huffman.o: huffman.c -	$(CC) $(CFLAGS) -c huffman.c -crctable.o: crctable.c -	$(CC) $(CFLAGS) -c crctable.c -randtable.o: randtable.c -	$(CC) $(CFLAGS) -c randtable.c -compress.o: compress.c -	$(CC) $(CFLAGS) -c compress.c -decompress.o: decompress.c -	$(CC) $(CFLAGS) -c decompress.c -bzlib.o: bzlib.c -	$(CC) $(CFLAGS) -c bzlib.c -bzip2.o: bzip2.c -	$(CC) $(CFLAGS) -c bzip2.c -bzip2recover.o: bzip2recover.c -	$(CC) $(CFLAGS) -c bzip2recover.c - - -distclean: clean -	rm -f manual.ps manual.html manual.pdf - -DISTNAME=bzip2-1.0.3 -dist: check manual -	rm -f $(DISTNAME) -	ln -sf . $(DISTNAME) -	tar cvf $(DISTNAME).tar \ -	   $(DISTNAME)/blocksort.c \ -	   $(DISTNAME)/huffman.c \ -	   $(DISTNAME)/crctable.c \ -	   $(DISTNAME)/randtable.c \ -	   $(DISTNAME)/compress.c \ -	   $(DISTNAME)/decompress.c \ -	   $(DISTNAME)/bzlib.c \ -	   $(DISTNAME)/bzip2.c \ -	   $(DISTNAME)/bzip2recover.c \ -	   $(DISTNAME)/bzlib.h \ -	   $(DISTNAME)/bzlib_private.h \ -	   $(DISTNAME)/Makefile \ -	   $(DISTNAME)/LICENSE \ -	   $(DISTNAME)/bzip2.1 \ -	   $(DISTNAME)/bzip2.1.preformatted \ -	   $(DISTNAME)/bzip2.txt \ -	   $(DISTNAME)/words0 \ -	   $(DISTNAME)/words1 \ -	   $(DISTNAME)/words2 \ -	   $(DISTNAME)/words3 \ -	   $(DISTNAME)/sample1.ref \ -	   $(DISTNAME)/sample2.ref \ -	   $(DISTNAME)/sample3.ref \ -	   $(DISTNAME)/sample1.bz2 \ -	   $(DISTNAME)/sample2.bz2 \ -	   $(DISTNAME)/sample3.bz2 \ -	   $(DISTNAME)/dlltest.c \ -	   $(DISTNAME)/manual.html \ -	   $(DISTNAME)/manual.pdf \ -	   $(DISTNAME)/manual.ps \ -	   $(DISTNAME)/README \ -	   $(DISTNAME)/README.COMPILATION.PROBLEMS \ -	   $(DISTNAME)/README.XML.STUFF \ -	   $(DISTNAME)/CHANGES \ -	   $(DISTNAME)/libbz2.def \ -	   $(DISTNAME)/libbz2.dsp \ -	   $(DISTNAME)/dlltest.dsp \ -	   $(DISTNAME)/makefile.msc \ -	   $(DISTNAME)/Y2K_INFO \ -	   $(DISTNAME)/unzcrash.c \ -	   $(DISTNAME)/spewG.c \ -	   $(DISTNAME)/mk251.c \ -	   $(DISTNAME)/bzdiff \ -	   $(DISTNAME)/bzdiff.1 \ -	   $(DISTNAME)/bzmore \ -	   $(DISTNAME)/bzmore.1 \ -	   $(DISTNAME)/bzgrep \ -	   $(DISTNAME)/bzgrep.1 \ -	   $(DISTNAME)/Makefile-libbz2_so \ -	   $(DISTNAME)/bz-common.xsl \ -	   $(DISTNAME)/bz-fo.xsl \ -	   $(DISTNAME)/bz-html.xsl \ -	   $(DISTNAME)/bzip.css \ -	   $(DISTNAME)/entities.xml \ -	   $(DISTNAME)/manual.xml \ -	   $(DISTNAME)/format.pl \ -	   $(DISTNAME)/xmlproc.sh -	gzip -v $(DISTNAME).tar - -# For rebuilding the manual from sources on my SuSE 9.1 box - -MANUAL_SRCS= 	bz-common.xsl bz-fo.xsl bz-html.xsl bzip.css \ -		entities.xml manual.xml  - -manual: manual.html manual.ps manual.pdf - -manual.ps: $(MANUAL_SRCS) -	./xmlproc.sh -ps manual.xml - -manual.pdf: $(MANUAL_SRCS) -	./xmlproc.sh -pdf manual.xml - -manual.html: $(MANUAL_SRCS) -	./xmlproc.sh -html manual.xml diff --git a/contrib/vmap_extractor_v2/stormlib/zlib/Makefile b/contrib/vmap_extractor_v2/stormlib/zlib/Makefile deleted file mode 100644 index 531562b2ef1..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/zlib/Makefile +++ /dev/null @@ -1,175 +0,0 @@ -# Makefile for zlib -# Copyright (C) 1995-2002 Jean-loup Gailly. -# For conditions of distribution and use, see copyright notice in zlib.h  - -# To compile and test, type: -#   ./configure; make test -# The call of configure is optional if you don't have special requirements -# If you wish to build zlib as a shared library, use: ./configure -s - -# To install /usr/local/lib/libz.* and /usr/local/include/zlib.h, type: -#    make install -# To install in $HOME instead of /usr/local, use: -#    make install prefix=$HOME - -CC=cc - -CFLAGS=-O -#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7 -#CFLAGS=-g -DDEBUG -#CFLAGS=-O3 -Wall -Wwrite-strings -Wpointer-arith -Wconversion \ -#           -Wstrict-prototypes -Wmissing-prototypes - -LDFLAGS=-L. -lz -LDSHARED=$(CC) -CPP=$(CC) -E - -VER=1.1.4 -LIBS=libz.a -SHAREDLIB=libz.so - -AR=ar rc -RANLIB=ranlib -TAR=tar -SHELL=/bin/sh - -prefix = /usr/local -exec_prefix = ${prefix} -libdir = ${exec_prefix}/lib -includedir = ${prefix}/include - -OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \ -       zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o - -OBJA = -# to use the asm code: make OBJA=match.o - -TEST_OBJS = example.o minigzip.o - -DISTFILES = README FAQ INDEX ChangeLog configure Make*[a-z0-9] *.[ch] *.mms \ -  algorithm.txt zlib.3 zlib.html \ -  msdos/Make*[a-z0-9] msdos/zlib.def msdos/zlib.rc \ -  nt/Make*[a-z0-9] nt/zlib.dnt amiga/Make*.??? os2/M*.os2 os2/zlib.def \ -  contrib/RE*.contrib contrib/*.txt contrib/asm386/*.asm contrib/asm386/*.c \ -  contrib/asm386/*.bat contrib/asm386/zlibvc.d?? contrib/asm[56]86/*.?86 \ -  contrib/asm[56]86/*.S contrib/iostream/*.cpp \ -  contrib/iostream/*.h  contrib/iostream2/*.h contrib/iostream2/*.cpp \ -  contrib/untgz/Makefile contrib/untgz/*.c contrib/untgz/*.w32 \ -  contrib/minizip/[CM]*[pe] contrib/minizip/*.[ch] contrib/minizip/*.[td]?? \ -  contrib/delphi*/*.??? - -all: example minigzip - -test: all -	@LD_LIBRARY_PATH=.:$(LD_LIBRARY_PATH) ; export LD_LIBRARY_PATH; \ -	echo hello world | ./minigzip | ./minigzip -d || \ -	  echo '		*** minigzip test FAILED ***' ; \ -	if ./example; then \ -	  echo '		*** zlib test OK ***'; \ -	else \ -	  echo '		*** zlib test FAILED ***'; \ -	fi - -libz.a: $(OBJS) $(OBJA) -	$(AR) $@ $(OBJS) $(OBJA) -	-@ ($(RANLIB) $@ || true) >/dev/null 2>&1 - -match.o: match.S -	$(CPP) match.S > _match.s -	$(CC) -c _match.s -	mv _match.o match.o -	rm -f _match.s - -$(SHAREDLIB).$(VER): $(OBJS) -	$(LDSHARED) -o $@ $(OBJS) -	rm -f $(SHAREDLIB) $(SHAREDLIB).1 -	ln -s $@ $(SHAREDLIB) -	ln -s $@ $(SHAREDLIB).1 - -example: example.o $(LIBS) -	$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS) - -minigzip: minigzip.o $(LIBS) -	$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS) - -install: $(LIBS) -	-@if [ ! -d $(includedir)  ]; then mkdir $(includedir); fi -	-@if [ ! -d $(libdir) ]; then mkdir $(libdir); fi -	cp zlib.h zconf.h $(includedir) -	chmod 644 $(includedir)/zlib.h $(includedir)/zconf.h -	cp $(LIBS) $(libdir) -	cd $(libdir); chmod 755 $(LIBS) -	-@(cd $(libdir); $(RANLIB) libz.a || true) >/dev/null 2>&1 -	cd $(libdir); if test -f $(SHAREDLIB).$(VER); then \ -	  rm -f $(SHAREDLIB) $(SHAREDLIB).1; \ -	  ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB); \ -	  ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB).1; \ -	  (ldconfig || true)  >/dev/null 2>&1; \ -	fi -# The ranlib in install is needed on NeXTSTEP which checks file times -# ldconfig is for Linux - -uninstall: -	cd $(includedir); \ -	v=$(VER); \ -	if test -f zlib.h; then \ -	  v=`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`; \ -          rm -f zlib.h zconf.h; \ -	fi; \ -	cd $(libdir); rm -f libz.a; \ -	if test -f $(SHAREDLIB).$$v; then \ -	  rm -f $(SHAREDLIB).$$v $(SHAREDLIB) $(SHAREDLIB).1; \ -	fi - -clean: -	rm -f *.o *~ example minigzip libz.a libz.so* foo.gz so_locations \ -	   _match.s maketree - -distclean:	clean - -zip: -	mv Makefile Makefile~; cp -p Makefile.in Makefile -	rm -f test.c ztest*.c contrib/minizip/test.zip -	v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\ -	zip -ul9 zlib$$v $(DISTFILES) -	mv Makefile~ Makefile - -dist: -	mv Makefile Makefile~; cp -p Makefile.in Makefile -	rm -f test.c ztest*.c contrib/minizip/test.zip -	d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\ -	rm -f $$d.tar.gz; \ -	if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \ -	files=""; \ -	for f in $(DISTFILES); do files="$$files $$d/$$f"; done; \ -	cd ..; \ -	GZIP=-9 $(TAR) chofz $$d/$$d.tar.gz $$files; \ -	if test ! -d $$d; then rm -f $$d; fi -	mv Makefile~ Makefile - -tags:	 -	etags *.[ch] - -depend: -	makedepend -- $(CFLAGS) -- *.[ch] - -# DO NOT DELETE THIS LINE -- make depend depends on it. - -adler32.o: zlib.h zconf.h -compress.o: zlib.h zconf.h -crc32.o: zlib.h zconf.h -deflate.o: deflate.h zutil.h zlib.h zconf.h -example.o: zlib.h zconf.h -gzio.o: zutil.h zlib.h zconf.h -infblock.o: infblock.h inftrees.h infcodes.h infutil.h zutil.h zlib.h zconf.h -infcodes.o: zutil.h zlib.h zconf.h -infcodes.o: inftrees.h infblock.h infcodes.h infutil.h inffast.h -inffast.o: zutil.h zlib.h zconf.h inftrees.h -inffast.o: infblock.h infcodes.h infutil.h inffast.h -inflate.o: zutil.h zlib.h zconf.h infblock.h -inftrees.o: zutil.h zlib.h zconf.h inftrees.h -infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h -minigzip.o:  zlib.h zconf.h  -trees.o: deflate.h zutil.h zlib.h zconf.h trees.h -uncompr.o: zlib.h zconf.h -zutil.o: zutil.h zlib.h zconf.h   diff --git a/contrib/vmap_extractor_v2/stormlib/zlib/Makefile.in b/contrib/vmap_extractor_v2/stormlib/zlib/Makefile.in deleted file mode 100644 index 531562b2ef1..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/zlib/Makefile.in +++ /dev/null @@ -1,175 +0,0 @@ -# Makefile for zlib -# Copyright (C) 1995-2002 Jean-loup Gailly. -# For conditions of distribution and use, see copyright notice in zlib.h  - -# To compile and test, type: -#   ./configure; make test -# The call of configure is optional if you don't have special requirements -# If you wish to build zlib as a shared library, use: ./configure -s - -# To install /usr/local/lib/libz.* and /usr/local/include/zlib.h, type: -#    make install -# To install in $HOME instead of /usr/local, use: -#    make install prefix=$HOME - -CC=cc - -CFLAGS=-O -#CFLAGS=-O -DMAX_WBITS=14 -DMAX_MEM_LEVEL=7 -#CFLAGS=-g -DDEBUG -#CFLAGS=-O3 -Wall -Wwrite-strings -Wpointer-arith -Wconversion \ -#           -Wstrict-prototypes -Wmissing-prototypes - -LDFLAGS=-L. -lz -LDSHARED=$(CC) -CPP=$(CC) -E - -VER=1.1.4 -LIBS=libz.a -SHAREDLIB=libz.so - -AR=ar rc -RANLIB=ranlib -TAR=tar -SHELL=/bin/sh - -prefix = /usr/local -exec_prefix = ${prefix} -libdir = ${exec_prefix}/lib -includedir = ${prefix}/include - -OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \ -       zutil.o inflate.o infblock.o inftrees.o infcodes.o infutil.o inffast.o - -OBJA = -# to use the asm code: make OBJA=match.o - -TEST_OBJS = example.o minigzip.o - -DISTFILES = README FAQ INDEX ChangeLog configure Make*[a-z0-9] *.[ch] *.mms \ -  algorithm.txt zlib.3 zlib.html \ -  msdos/Make*[a-z0-9] msdos/zlib.def msdos/zlib.rc \ -  nt/Make*[a-z0-9] nt/zlib.dnt amiga/Make*.??? os2/M*.os2 os2/zlib.def \ -  contrib/RE*.contrib contrib/*.txt contrib/asm386/*.asm contrib/asm386/*.c \ -  contrib/asm386/*.bat contrib/asm386/zlibvc.d?? contrib/asm[56]86/*.?86 \ -  contrib/asm[56]86/*.S contrib/iostream/*.cpp \ -  contrib/iostream/*.h  contrib/iostream2/*.h contrib/iostream2/*.cpp \ -  contrib/untgz/Makefile contrib/untgz/*.c contrib/untgz/*.w32 \ -  contrib/minizip/[CM]*[pe] contrib/minizip/*.[ch] contrib/minizip/*.[td]?? \ -  contrib/delphi*/*.??? - -all: example minigzip - -test: all -	@LD_LIBRARY_PATH=.:$(LD_LIBRARY_PATH) ; export LD_LIBRARY_PATH; \ -	echo hello world | ./minigzip | ./minigzip -d || \ -	  echo '		*** minigzip test FAILED ***' ; \ -	if ./example; then \ -	  echo '		*** zlib test OK ***'; \ -	else \ -	  echo '		*** zlib test FAILED ***'; \ -	fi - -libz.a: $(OBJS) $(OBJA) -	$(AR) $@ $(OBJS) $(OBJA) -	-@ ($(RANLIB) $@ || true) >/dev/null 2>&1 - -match.o: match.S -	$(CPP) match.S > _match.s -	$(CC) -c _match.s -	mv _match.o match.o -	rm -f _match.s - -$(SHAREDLIB).$(VER): $(OBJS) -	$(LDSHARED) -o $@ $(OBJS) -	rm -f $(SHAREDLIB) $(SHAREDLIB).1 -	ln -s $@ $(SHAREDLIB) -	ln -s $@ $(SHAREDLIB).1 - -example: example.o $(LIBS) -	$(CC) $(CFLAGS) -o $@ example.o $(LDFLAGS) - -minigzip: minigzip.o $(LIBS) -	$(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS) - -install: $(LIBS) -	-@if [ ! -d $(includedir)  ]; then mkdir $(includedir); fi -	-@if [ ! -d $(libdir) ]; then mkdir $(libdir); fi -	cp zlib.h zconf.h $(includedir) -	chmod 644 $(includedir)/zlib.h $(includedir)/zconf.h -	cp $(LIBS) $(libdir) -	cd $(libdir); chmod 755 $(LIBS) -	-@(cd $(libdir); $(RANLIB) libz.a || true) >/dev/null 2>&1 -	cd $(libdir); if test -f $(SHAREDLIB).$(VER); then \ -	  rm -f $(SHAREDLIB) $(SHAREDLIB).1; \ -	  ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB); \ -	  ln -s $(SHAREDLIB).$(VER) $(SHAREDLIB).1; \ -	  (ldconfig || true)  >/dev/null 2>&1; \ -	fi -# The ranlib in install is needed on NeXTSTEP which checks file times -# ldconfig is for Linux - -uninstall: -	cd $(includedir); \ -	v=$(VER); \ -	if test -f zlib.h; then \ -	  v=`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`; \ -          rm -f zlib.h zconf.h; \ -	fi; \ -	cd $(libdir); rm -f libz.a; \ -	if test -f $(SHAREDLIB).$$v; then \ -	  rm -f $(SHAREDLIB).$$v $(SHAREDLIB) $(SHAREDLIB).1; \ -	fi - -clean: -	rm -f *.o *~ example minigzip libz.a libz.so* foo.gz so_locations \ -	   _match.s maketree - -distclean:	clean - -zip: -	mv Makefile Makefile~; cp -p Makefile.in Makefile -	rm -f test.c ztest*.c contrib/minizip/test.zip -	v=`sed -n -e 's/\.//g' -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\ -	zip -ul9 zlib$$v $(DISTFILES) -	mv Makefile~ Makefile - -dist: -	mv Makefile Makefile~; cp -p Makefile.in Makefile -	rm -f test.c ztest*.c contrib/minizip/test.zip -	d=zlib-`sed -n '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`;\ -	rm -f $$d.tar.gz; \ -	if test ! -d ../$$d; then rm -f ../$$d; ln -s `pwd` ../$$d; fi; \ -	files=""; \ -	for f in $(DISTFILES); do files="$$files $$d/$$f"; done; \ -	cd ..; \ -	GZIP=-9 $(TAR) chofz $$d/$$d.tar.gz $$files; \ -	if test ! -d $$d; then rm -f $$d; fi -	mv Makefile~ Makefile - -tags:	 -	etags *.[ch] - -depend: -	makedepend -- $(CFLAGS) -- *.[ch] - -# DO NOT DELETE THIS LINE -- make depend depends on it. - -adler32.o: zlib.h zconf.h -compress.o: zlib.h zconf.h -crc32.o: zlib.h zconf.h -deflate.o: deflate.h zutil.h zlib.h zconf.h -example.o: zlib.h zconf.h -gzio.o: zutil.h zlib.h zconf.h -infblock.o: infblock.h inftrees.h infcodes.h infutil.h zutil.h zlib.h zconf.h -infcodes.o: zutil.h zlib.h zconf.h -infcodes.o: inftrees.h infblock.h infcodes.h infutil.h inffast.h -inffast.o: zutil.h zlib.h zconf.h inftrees.h -inffast.o: infblock.h infcodes.h infutil.h inffast.h -inflate.o: zutil.h zlib.h zconf.h infblock.h -inftrees.o: zutil.h zlib.h zconf.h inftrees.h -infutil.o: zutil.h zlib.h zconf.h infblock.h inftrees.h infcodes.h infutil.h -minigzip.o:  zlib.h zconf.h  -trees.o: deflate.h zutil.h zlib.h zconf.h trees.h -uncompr.o: zlib.h zconf.h -zutil.o: zutil.h zlib.h zconf.h   diff --git a/contrib/vmap_extractor_v2/stormlib/zlib/configure b/contrib/vmap_extractor_v2/stormlib/zlib/configure deleted file mode 100644 index e8942359bc1..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/zlib/configure +++ /dev/null @@ -1,212 +0,0 @@ -#!/bin/sh -# configure script for zlib. This script is needed only if -# you wish to build a shared library and your system supports them, -# of if you need special compiler, flags or install directory. -# Otherwise, you can just use directly "make test; make install" -# -# To create a shared library, use "configure --shared"; by default a static -# library is created. If the primitive shared library support provided here -# does not work, use ftp://prep.ai.mit.edu/pub/gnu/libtool-*.tar.gz -# -# To impose specific compiler or flags or install directory, use for example: -#    prefix=$HOME CC=cc CFLAGS="-O4" ./configure -# or for csh/tcsh users: -#    (setenv prefix $HOME; setenv CC cc; setenv CFLAGS "-O4"; ./configure) -# LDSHARED is the command to be used to create a shared library - -# Incorrect settings of CC or CFLAGS may prevent creating a shared library. -# If you have problems, try without defining CC and CFLAGS before reporting -# an error. - -LIBS=libz.a -SHAREDLIB=libz.so -VER=`sed -n -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h` -AR=${AR-"ar rc"} -RANLIB=${RANLIB-"ranlib"} -prefix=${prefix-/usr/local} -exec_prefix=${exec_prefix-'${prefix}'} -libdir=${libdir-'${exec_prefix}/lib'} -includedir=${includedir-'${prefix}/include'} -shared_ext='.so' -shared=0 -gcc=0 -old_cc="$CC" -old_cflags="$CFLAGS" - -while test $# -ge 1 -do -case "$1" in -    -h* | --h*) -      echo 'usage:' -      echo '  configure [--shared] [--prefix=PREFIX]  [--exec_prefix=EXPREFIX]' -      echo '     [--libdir=LIBDIR] [--includedir=INCLUDEDIR]' -        exit 0;; -    -p*=* | --p*=*) prefix=`echo $1 | sed 's/[-a-z_]*=//'`; shift;; -    -e*=* | --e*=*) exec_prefix=`echo $1 | sed 's/[-a-z_]*=//'`; shift;; -    -l*=* | --libdir=*) libdir=`echo $1 | sed 's/[-a-z_]*=//'`; shift;; -    -i*=* | --includedir=*) includedir=`echo $1 | sed 's/[-a-z_]*=//'`;shift;; -    -p* | --p*) prefix="$2"; shift; shift;; -    -e* | --e*) exec_prefix="$2"; shift; shift;; -    -l* | --l*) libdir="$2"; shift; shift;; -    -i* | --i*) includedir="$2"; shift; shift;; -    -s* | --s*) shared=1; shift;; -    esac -done - -test=ztest$$ -cat > $test.c <<EOF -extern int getchar(); -int hello() {return getchar();} -EOF - -test -z "$CC" && echo Checking for gcc... -cc=${CC-gcc} -cflags=${CFLAGS-"-O3"} -# to force the asm version use: CFLAGS="-O3 -DASMV" ./configure -case "$cc" in -  *gcc*) gcc=1;; -esac - -if test "$gcc" -eq 1 && ($cc -c $cflags $test.c) 2>/dev/null; then -  CC="$cc" -  SFLAGS=${CFLAGS-"-fPIC -O3"} -  CFLAGS="$cflags" -  case `(uname -s || echo unknown) 2>/dev/null` in -  Linux | linux) LDSHARED=${LDSHARED-"gcc -shared -Wl,-soname,libz.so.1"};; -  *)             LDSHARED=${LDSHARED-"gcc -shared"};; -  esac -else -  # find system name and corresponding cc options -  CC=${CC-cc} -  case `(uname -sr || echo unknown) 2>/dev/null` in -  HP-UX*)    SFLAGS=${CFLAGS-"-O +z"} -	     CFLAGS=${CFLAGS-"-O"} -#	     LDSHARED=${LDSHARED-"ld -b +vnocompatwarnings"} -	     LDSHARED=${LDSHARED-"ld -b"} -	     shared_ext='.sl' -	     SHAREDLIB='libz.sl';; -  IRIX*)     SFLAGS=${CFLAGS-"-ansi -O2 -rpath ."} -	     CFLAGS=${CFLAGS-"-ansi -O2"} -	     LDSHARED=${LDSHARED-"cc -shared"};; -  OSF1\ V4*) SFLAGS=${CFLAGS-"-O -std1"} -	     CFLAGS=${CFLAGS-"-O -std1"} -	     LDSHARED=${LDSHARED-"cc -shared  -Wl,-soname,$SHAREDLIB -Wl,-msym -Wl,-rpath,$(libdir) -Wl,-set_version,${VER}:1.0"};; -  OSF1*)     SFLAGS=${CFLAGS-"-O -std1"} -	     CFLAGS=${CFLAGS-"-O -std1"} -	     LDSHARED=${LDSHARED-"cc -shared"};; -  QNX*)      SFLAGS=${CFLAGS-"-4 -O"} -             CFLAGS=${CFLAGS-"-4 -O"} -	     LDSHARED=${LDSHARED-"cc"} -             RANLIB=${RANLIB-"true"} -             AR="cc -A";; -  SCO_SV\ 3.2*) SFLAGS=${CFLAGS-"-O3 -dy -KPIC "} -	     CFLAGS=${CFLAGS-"-O3"} -	     LDSHARED=${LDSHARED-"cc -dy -KPIC -G"};; -  SunOS\ 5*) SFLAGS=${CFLAGS-"-fast -xcg89 -KPIC -R."} -             CFLAGS=${CFLAGS-"-fast -xcg89"} -	     LDSHARED=${LDSHARED-"cc -G"};; -  SunOS\ 4*) SFLAGS=${CFLAGS-"-O2 -PIC"} -	     CFLAGS=${CFLAGS-"-O2"} -	     LDSHARED=${LDSHARED-"ld"};; -  UNIX_System_V\ 4.2.0)  -	     SFLAGS=${CFLAGS-"-KPIC -O"} -	     CFLAGS=${CFLAGS-"-O"} -	     LDSHARED=${LDSHARED-"cc -G"};; -  UNIX_SV\ 4.2MP) -	     SFLAGS=${CFLAGS-"-Kconform_pic -O"} -	     CFLAGS=${CFLAGS-"-O"} -	     LDSHARED=${LDSHARED-"cc -G"};; -  # send working options for other systems to support@gzip.org -  *)         SFLAGS=${CFLAGS-"-O"} -	     CFLAGS=${CFLAGS-"-O"} -	     LDSHARED=${LDSHARED-"cc -shared"};; -  esac -fi - -if test $shared -eq 1; then -  echo Checking for shared library support... -  # we must test in two steps (cc then ld), required at least on SunOS 4.x -  if test "`($CC -c $SFLAGS $test.c) 2>&1`" = "" && -     test "`($LDSHARED -o $test$shared_ext $test.o) 2>&1`" = ""; then -    CFLAGS="$SFLAGS" -    LIBS="$SHAREDLIB.$VER" -    echo Building shared library $SHAREDLIB.$VER with $CC. -  elif test -z "$old_cc" -a -z "$old_cflags"; then -    echo No shared library suppport. -    shared=0; -  else -    echo 'No shared library suppport; try without defining CC and CFLAGS' -    shared=0; -  fi -fi -if test $shared -eq 0; then -  LDSHARED="$CC" -  echo Building static library $LIBS version $VER with $CC. -fi - -cat > $test.c <<EOF -#include <unistd.h> -int main() { return 0; } -EOF -if test "`($CC -c $CFLAGS $test.c) 2>&1`" = ""; then -  CFLAGS="$CFLAGS -DHAVE_UNISTD_H" -  echo "Checking for unistd.h... Yes." -else -  echo "Checking for unistd.h... No." -fi - -cat > $test.c <<EOF -#include <errno.h> -int main() { return 0; } -EOF -if test "`($CC -c $CFLAGS $test.c) 2>&1`" = ""; then -  echo "Checking for errno.h...	 Yes." -else -  echo "Checking for errno.h...	 No." -  CFLAGS="$CFLAGS -DNO_ERRNO_H" -fi - -cat > $test.c <<EOF -#include <sys/types.h> -#include <sys/mman.h> -#include <sys/stat.h> -caddr_t hello() { -  return mmap((caddr_t)0, (off_t)0, PROT_READ, MAP_SHARED, 0, (off_t)0);  -} -EOF -if test "`($CC -c $CFLAGS $test.c) 2>&1`" = ""; then -  CFLAGS="$CFLAGS -DUSE_MMAP" -  echo Checking for mmap support... Yes. -else -  echo Checking for mmap support... No. -fi - -CPP=${CPP-"$CC -E"} -case $CFLAGS in -  *ASMV*) -    if test "`nm $test.o | grep _hello`" = ""; then -      CPP="$CPP -DNO_UNDERLINE" -      echo Checking for underline in external names... No. -    else -      echo Checking for underline in external names... Yes. -    fi;; -esac - -rm -f $test.[co] $test$shared_ext - -# udpate Makefile -sed < Makefile.in " -/^CC *=/s%=.*%=$CC% -/^CFLAGS *=/s%=.*%=$CFLAGS% -/^CPP *=/s%=.*%=$CPP% -/^LDSHARED *=/s%=.*%=$LDSHARED% -/^LIBS *=/s%=.*%=$LIBS% -/^SHAREDLIB *=/s%=.*%=$SHAREDLIB% -/^AR *=/s%=.*%=$AR% -/^RANLIB *=/s%=.*%=$RANLIB% -/^VER *=/s%=.*%=$VER% -/^prefix *=/s%=.*%=$prefix% -/^exec_prefix *=/s%=.*%=$exec_prefix% -/^libdir *=/s%=.*%=$libdir% -/^includedir *=/s%=.*%=$includedir% -" > Makefile diff --git a/contrib/vmap_extractor_v2/stormlib/zlib/contrib/minizip/Makefile b/contrib/vmap_extractor_v2/stormlib/zlib/contrib/minizip/Makefile deleted file mode 100644 index a1dfc161437..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/zlib/contrib/minizip/Makefile +++ /dev/null @@ -1,25 +0,0 @@ -CC=cc -CFLAGS=-O -I../.. - -UNZ_OBJS = miniunz.o unzip.o ../../libz.a -ZIP_OBJS = minizip.o zip.o   ../../libz.a - -.c.o: -	$(CC) -c $(CFLAGS) $*.c - -all: miniunz minizip - -miniunz:  $(UNZ_OBJS) -	$(CC) $(CFLAGS) -o $@ $(UNZ_OBJS) - -minizip:  $(ZIP_OBJS) -	$(CC) $(CFLAGS) -o $@ $(ZIP_OBJS) - -test:	miniunz minizip -	./minizip test readme.txt -	./miniunz -l test.zip -	mv readme.txt readme.old -	./miniunz test.zip - -clean: -	/bin/rm -f *.o *~ minizip miniunz diff --git a/contrib/vmap_extractor_v2/stormlib/zlib/contrib/untgz/Makefile b/contrib/vmap_extractor_v2/stormlib/zlib/contrib/untgz/Makefile deleted file mode 100644 index 409b4bdeaae..00000000000 --- a/contrib/vmap_extractor_v2/stormlib/zlib/contrib/untgz/Makefile +++ /dev/null @@ -1,14 +0,0 @@ -CC=cc -CFLAGS=-g - -untgz: untgz.o  ../../libz.a -	$(CC) $(CFLAGS) -o untgz  untgz.o -L../.. -lz - -untgz.o: untgz.c ../../zlib.h -	$(CC) $(CFLAGS) -c -I../.. untgz.c - -../../libz.a: -	cd ../..; make - -clean: -	rm -f untgz untgz.o *~ diff --git a/contrib/vmap_extractor_v2/vmapextract/model.cpp b/contrib/vmap_extractor_v2/vmapextract/model.cpp index 2bf5e8b5200..e5106dca65a 100644 --- a/contrib/vmap_extractor_v2/vmapextract/model.cpp +++ b/contrib/vmap_extractor_v2/vmapextract/model.cpp @@ -1,11 +1,7 @@ -//#include "common.h"  #include "model.h" -//#include "world.h"  #include <cassert>  #include <algorithm> -//int globalTime = 0; -  Model::Model(std::string &filename) : filename(filename)  {  } @@ -16,7 +12,7 @@ bool Model::open()      ok = !f.isEof(); -    if (!ok) +    if (!ok)       {          f.close();          printf("Error loading model %s\n", filename.c_str()); @@ -24,121 +20,31 @@ bool Model::open()      }      memcpy(&header, f.getBuffer(), sizeof(ModelHeader)); -    if(header.nBoundingTriangles > 0) { - -#if 0 -        animated = isAnimated(f); -        if(animated) -        { -            f.close(); -            return false; -        } -#endif -        trans = 1.0f; -        origVertices = (ModelVertex*)(f.getBuffer() + header.ofsVertices); - -        vertices = new Vec3D[header.nVertices]; -        normals = new Vec3D[header.nVertices]; - -        for (size_t i=0; i<header.nVertices; i++) -        { -            origVertices[i].pos = fixCoordSystem(origVertices[i].pos); -            origVertices[i].normal = fixCoordSystem(origVertices[i].normal); -            vertices[i] = origVertices[i].pos; -            normals[i] = origVertices[i].normal.normalize(); -        } - -        ModelView *view = (ModelView*)(f.getBuffer() + header.ofsViews); - -        uint16 *indexLookup = (uint16*)(f.getBuffer() + view->ofsIndex); -        uint16 *triangles = (uint16*)(f.getBuffer() + view->ofsTris); - -        nIndices = view->nTris; -        indices = new uint16[nIndices]; -        for (size_t i = 0; i<nIndices; i++) +    if(header.nBoundingTriangles > 0)  +    { +        f.seek(0); +		f.seekRelative(header.ofsBoundingVertices); +		vertices = new Vec3D[header.nBoundingVertices]; +		f.read(vertices,header.nBoundingVertices*12); +        for (uint32 i=0; i<header.nBoundingVertices; i++)          { -            indices[i] = indexLookup[triangles[i]]; +            vertices[i] = fixCoordSystem(vertices[i]);          } +        f.seek(0); +		f.seekRelative(header.ofsBoundingTriangles); +		indices = new uint16[header.nBoundingTriangles]; +		f.read(indices,header.nBoundingTriangles*2);          f.close(); -    } else { +    }  +    else  +    {          //printf("not included %s\n", filename.c_str()); +        f.close();          return false;      }      return true; -  } -bool Model::isAnimated(MPQFile &f) -{ -    // see if we have any animated bones -    ModelBoneDef *bo = (ModelBoneDef*)(f.getBuffer() + header.ofsBones); - -    animGeometry = false; -    animBones = false; -    ind = false; - -    ModelVertex *verts = (ModelVertex*)(f.getBuffer() + header.ofsVertices); -    for (size_t i=0; i<header.nVertices && !animGeometry; i++) { -        for (size_t b=0; b<4; b++) { -            if (verts[i].weights[b]>0) { -                ModelBoneDef &bb = bo[verts[i].bones[b]]; -                if (bb.translation.type || bb.rotation.type || bb.scaling.type || (bb.flags&8)) { -                    if (bb.flags&8) { -                        // if we have billboarding, the model will need per-instance animation -                        ind = true; -                    } -                    animGeometry = true; -                    break; -                } -            } -        } -    } - -    if (animGeometry) animBones = true; -    else { -        for (size_t i=0; i<header.nBones; i++) { -            ModelBoneDef &bb = bo[i]; -            if (bb.translation.type || bb.rotation.type || bb.scaling.type) { -                animBones = true; -                break; -            } -        } -    } - -    animTextures = header.nTexAnims > 0; - -    bool animMisc = header.nCameras>0 || // why waste time, pretty much all models with cameras need animation -        header.nLights>0 || // same here -        header.nParticleEmitters>0 || -        header.nRibbonEmitters>0; - -    if (animMisc) animBones = true; - -    // animated colors -    if (header.nColors) { -        ModelColorDef *cols = (ModelColorDef*)(f.getBuffer() + header.ofsColors); -        for (size_t i=0; i<header.nColors; i++) { -            if (cols[i].color.type!=0 || cols[i].opacity.type!=0) { -                animMisc = true; -                break; -            } -        } -    } - -    // animated opacity -    if (header.nTransparency && !animMisc) { -        ModelTransDef *trs = (ModelTransDef*)(f.getBuffer() + header.ofsTransparency); -        for (size_t i=0; i<header.nTransparency; i++) { -            if (trs[i].trans.type!=0) { -                animMisc = true; -                break; -            } -        } -    } - -    // guess not... -    return animGeometry || animTextures || animMisc; -}  bool Model::ConvertToVMAPModel(char * outfilename)  { @@ -151,7 +57,8 @@ bool Model::ConvertToVMAPModel(char * outfilename)          return false;      }      fwrite("VMAP002",8,1,output); -    int nVertices = header.nVertices; +    uint32 nVertices = 0; +    nVertices = header.nBoundingVertices;      fwrite(&nVertices, sizeof(int), 1, output);      uint32 nofgroups = 1;      fwrite(&nofgroups,sizeof(uint32), 1, output); @@ -162,23 +69,24 @@ bool Model::ConvertToVMAPModel(char * outfilename)      wsize = sizeof(branches) + sizeof(uint32) * branches;      fwrite(&wsize, sizeof(int), 1, output);      fwrite(&branches,sizeof(branches), 1, output); -    uint32 nIdexes = (uint32) nIndices; -    fwrite(&nIndices,sizeof(uint32), 1, output); +    uint32 nIndexes = 0; +    nIndexes = header.nBoundingTriangles; +    fwrite(&nIndexes,sizeof(uint32), 1, output);      fwrite("INDX",4, 1, output); -    wsize = sizeof(uint32) + sizeof(unsigned short) * nIdexes; +    wsize = sizeof(uint32) + sizeof(unsigned short) * nIndexes;      fwrite(&wsize, sizeof(int), 1, output); -    fwrite(&nIdexes, sizeof(uint32), 1, output); -    if(nIdexes >0) +    fwrite(&nIndexes, sizeof(uint32), 1, output); +    if(nIndexes >0)       { -        fwrite(indices, sizeof(unsigned short), nIdexes, output); +        fwrite(indices, sizeof(unsigned short), nIndexes, output);      }      fwrite("VERT",4, 1, output);      wsize = sizeof(int) + sizeof(float) * 3 * nVertices;      fwrite(&wsize, sizeof(int), 1, output);      fwrite(&nVertices, sizeof(int), 1, output); -    if(nVertices >0) +    if(nVertices >0)       { -        for(int vpos=0; vpos <nVertices; ++vpos) +        for(uint32 vpos=0; vpos <nVertices; ++vpos)          {              float sy = vertices[vpos].y;              vertices[vpos].y = vertices[vpos].z; @@ -189,7 +97,6 @@ bool Model::ConvertToVMAPModel(char * outfilename)      delete[] vertices;      delete[] indices; -    delete[] normals;      fclose(output); @@ -231,15 +138,15 @@ ModelInstance::ModelInstance(MPQFile &f,const char* ModelInstName,const char*Map          return;      }      fseek(input, 8, SEEK_SET); // get the correct no of vertices -    int nVertices; -    fread(&nVertices, sizeof (int), 1, input); -    fclose(input); +	int nVertices; +	fread(&nVertices, sizeof (int), 1, input); +	fclose(input);      if(nVertices == 0)      {          return;      } -    if(pDirfile) +    if(pDirfile)       {          int realx1 = (int) ((float) pos.x / 533.333333f);          int realy1 = (int) ((float) pos.z / 533.333333f); @@ -256,7 +163,7 @@ ModelInstance::ModelInstance(MPQFile &f,const char* ModelInstName,const char*Map              nVertices,              realx1, realy1,              realx2, realy2 -            ); +            );				      }  } diff --git a/contrib/vmap_extractor_v2/vmapextract/model.h b/contrib/vmap_extractor_v2/vmapextract/model.h index d655587bfab..4e1a37328f3 100644 --- a/contrib/vmap_extractor_v2/vmapextract/model.h +++ b/contrib/vmap_extractor_v2/vmapextract/model.h @@ -4,7 +4,6 @@  #include "vec3d.h"  #include "mpq.h"  #include "modelheaders.h" -//#include "quaternion.h"  #include <vector>  class Model; @@ -16,61 +15,45 @@ Vec3D fixCoordSystem(Vec3D v);  class Model -{ +{   public: -    ModelHeader header; -    ModelAnimation *anims; -    int *globalSequences; +	ModelHeader header; +	  public: -    bool animGeometry,animTextures,animBones; -    bool animated; - -    bool isAnimated(MPQFile &f); -    ModelVertex *origVertices; -    Vec3D *vertices, *normals; -    uint16 *indices; -    size_t nIndices; -    bool open(); -    bool ConvertToVMAPModel(char * outfilename); +	uint32 offsBB_vertices, offsBB_indices; +	Vec3D *BB_vertices, *vertices; +	uint16 *BB_indices, *indices; +	size_t nIndices; +	 +	bool open(); +	bool ConvertToVMAPModel(char * outfilename);  public: -    bool ok; -    bool ind; - -    float rad; -    float trans; -    bool animcalc; -    int anim, animtime; - -    Model(std::string &filename); -    ~Model(); +	bool ok; +	Model(std::string &filename); +	~Model(); +	  private: -    std::string filename; -    char outfilename; +	std::string filename; +	char outfilename;  }; -class ModelInstance +class ModelInstance   {  public: -    Model *model; - -    int id; - -    Vec3D pos, rot; -    unsigned int d1, scale; - -    float frot,w,sc; +	Model *model; -    int light; -    Vec3D ldir; -    Vec3D lcol; +	int id; +	Vec3D pos, rot; +	unsigned int d1, scale; +	float w,sc; -    ModelInstance() {} -    ModelInstance(MPQFile &f,const char* ModelInstName,const char*MapName, FILE *pDirfile); +	ModelInstance() {} +	ModelInstance(MPQFile &f,const char* ModelInstName,const char*MapName, FILE *pDirfile);  }; diff --git a/contrib/vmap_extractor_v2/vmapextract/modelheaders.h b/contrib/vmap_extractor_v2/vmapextract/modelheaders.h index 09dc24f14ab..30adf61801f 100644 --- a/contrib/vmap_extractor_v2/vmapextract/modelheaders.h +++ b/contrib/vmap_extractor_v2/vmapextract/modelheaders.h @@ -11,293 +11,71 @@ typedef int int32;  #pragma pack(push,1)  struct ModelHeader { -    char id[4]; -    uint8 version[4]; -    uint32 nameLength; -    uint32 nameOfs; -    uint32 type; - -    uint32 nGlobalSequences; -    uint32 ofsGlobalSequences; -    uint32 nAnimations; -    uint32 ofsAnimations; -    uint32 nC; -    uint32 ofsC; -    uint32 nD; -    uint32 ofsD; +	char id[4]; +	uint8 version[4]; +	uint32 nameLength; +	uint32 nameOfs; +	uint32 type;	 +	uint32 nGlobalSequences; +	uint32 ofsGlobalSequences; +	uint32 nAnimations; +	uint32 ofsAnimations; +    uint32 nAnimationLookup; +    uint32 ofsAnimationLookup;      uint32 nBones;      uint32 ofsBones; -    uint32 nF; -    uint32 ofsF; - -    uint32 nVertices; -    uint32 ofsVertices; -    uint32 nViews; -    uint32 ofsViews; - -    uint32 nColors; -    uint32 ofsColors; - -    uint32 nTextures; -    uint32 ofsTextures; - -    uint32 nTransparency; // H -    uint32 ofsTransparency; -    uint32 nI;   // always unused ? -    uint32 ofsI; -    uint32 nTexAnims;   // J -    uint32 ofsTexAnims; -    uint32 nK; -    uint32 ofsK; - -    uint32 nTexFlags; -    uint32 ofsTexFlags; -    uint32 nY; -    uint32 ofsY; - -    uint32 nTexLookup; -    uint32 ofsTexLookup; - -    uint32 nTexUnitLookup;      // L -    uint32 ofsTexUnitLookup; -    uint32 nTransparencyLookup; // M -    uint32 ofsTransparencyLookup; -    uint32 nTexAnimLookup; -    uint32 ofsTexAnimLookup; - -    float floats[14]; - -    uint32 nBoundingTriangles; -    uint32 ofsBoundingTriangles; -    uint32 nBoundingVertices; -    uint32 ofsBoundingVertices; -    uint32 nBoundingNormals; -    uint32 ofsBoundingNormals; - -    uint32 nO; -    uint32 ofsO; -    uint32 nP; -    uint32 ofsP; -    uint32 nQ; -    uint32 ofsQ; -    uint32 nLights; // R -    uint32 ofsLights; -    uint32 nCameras; // S -    uint32 ofsCameras; -    uint32 nT; -    uint32 ofsT; -    uint32 nRibbonEmitters; // U -    uint32 ofsRibbonEmitters; -    uint32 nParticleEmitters; // V -    uint32 ofsParticleEmitters; - -}; - -// block B - animations -struct ModelAnimation { -    uint32 animID; -    uint32 timeStart; -    uint32 timeEnd; - -    float moveSpeed; - -    uint32 loopType; -    uint32 flags; -    uint32 d1; -    uint32 d2; -    uint32 playSpeed;  // note: this can't be play speed because it's 0 for some models - -    Vec3D boxA, boxB; -    float rad; - -    int16 s[2]; -}; - - -// sub-block in block E - animation data -struct AnimationBlock { -    int16 type;     // interpolation type (0=none, 1=linear, 2=hermite) -    int16 seq;      // global sequence id or -1 -    uint32 nRanges; -    uint32 ofsRanges; -    uint32 nTimes; -    uint32 ofsTimes; -    uint32 nKeys; -    uint32 ofsKeys; +	uint32 nKeyBoneLookup; +	uint32 ofsKeyBoneLookup; +	uint32 nVertices; +	uint32 ofsVertices; +	uint32 nViews; +	uint32 nColors; +	uint32 ofsColors; +	uint32 nTextures; +	uint32 ofsTextures; +	uint32 nTransparency; +	uint32 ofsTransparency; +	uint32 nTextureanimations; +	uint32 ofsTextureanimations; +	uint32	nTexReplace; +	uint32	ofsTexReplace; +	uint32	nRenderFlags; +	uint32	ofsRenderFlags; +	uint32	nBoneLookupTable; +	uint32	ofsBoneLookupTable; +	uint32	nTexLookup; +	uint32	ofsTexLookup; +	uint32	nTexUnits; +	uint32	ofsTexUnits; +	uint32	nTransLookup; +	uint32	ofsTransLookup; +	uint32	nTexAnimLookup; +	uint32	ofsTexAnimLookup; +	float	floats[14]; +	uint32	nBoundingTriangles; +	uint32	ofsBoundingTriangles; +	uint32	nBoundingVertices; +	uint32	ofsBoundingVertices; +	uint32	nBoundingNormals; +	uint32	ofsBoundingNormals; +	uint32	nAttachments; +	uint32	ofsAttachments; +	uint32	nAttachLookup; +	uint32	ofsAttachLookup; +	uint32	nAttachments_2; +	uint32	ofsAttachments_2; +	uint32	nLights; +	uint32	ofsLights; +	uint32	nCameras; +	uint32	ofsCameras;	 +	uint32	nCameraLookup; +	uint32	ofsCameraLookup; +	uint32	nRibbonEmitters; +	uint32	ofsRibbonEmitters; +	uint32	nParticleEmitters; +	uint32	ofsParticleEmitters;  }; -// block E - bones -struct ModelBoneDef { -    int32 animid; -    int32 flags; -    int16 parent; // parent bone index -    int16 geoid; -    // new int added to the bone definitions.  Added in WoW 2.0 -    int32 unknown; -    AnimationBlock translation; -    AnimationBlock rotation; -    AnimationBlock scaling; -    Vec3D pivot; -}; - -struct ModelTexAnimDef { -    AnimationBlock trans, rot, scale; -}; - -struct ModelVertex { -    Vec3D pos; -    uint8 weights[4]; -    uint8 bones[4]; -    Vec3D normal; -    Vec2D texcoords; -    int unk1, unk2; // always 0,0 so this is probably unused -}; - -struct ModelView { -    uint32 nIndex, ofsIndex; // Vertices in this model (index into vertices[]) -    uint32 nTris, ofsTris;   // indices -    uint32 nProps, ofsProps; // additional vtx properties -    uint32 nSub, ofsSub;     // materials/renderops/submeshes -    uint32 nTex, ofsTex;     // material properties/textures -    int32 lod;               // LOD bias? -}; - - -/// One material + render operation -struct ModelGeoset { -    uint16 d1;      // mesh part id? -    uint16 d2;      // ? -    uint16 vstart;  // first vertex -    uint16 vcount;  // num vertices -    uint16 istart;  // first index -    uint16 icount;  // num indices -    uint16 d3;      // number of bone indices -    uint16 d4;      // offset into bone index list -    uint16 d5;      // ? -    uint16 d6;      // root bone? -    Vec3D v; -    float unknown[4];   // Added in WoW 2.0? -}; - -/// A texture unit (sub of material) -struct ModelTexUnit{ -    // probably the texture units -    // size always >=number of materials it seems -    uint16 flags;       // Flags -    uint16 order;       // ? -    uint16 op;          // Material this texture is part of (index into mat) -    uint16 op2;         // Always same as above? -    int16 colorIndex;   // color or -1 -    uint16 flagsIndex;  // more flags... -    uint16 texunit;     // Texture unit (0 or 1) -    uint16 d4;          // ? (seems to be always 1) -    uint16 textureid;   // Texture id (index into global texture list) -    uint16 texunit2;    // copy of texture unit value? -    uint16 transid;     // transparency id (index into transparency list) -    uint16 texanimid;   // texture animation id -}; - -// block X - render flags -struct ModelRenderFlags { -    uint16 flags; -    uint16 blend; -}; - -// block G - color defs -struct ModelColorDef { -    AnimationBlock color; -    AnimationBlock opacity; -}; - -// block H - transp defs -struct ModelTransDef { -    AnimationBlock trans; -}; - -struct ModelTextureDef { -    uint32 type; -    uint32 flags; -    uint32 nameLen; -    uint32 nameOfs; -}; - -struct ModelLightDef { -    int16 type; -    int16 bone; -    Vec3D pos; -    AnimationBlock ambColor; -    AnimationBlock ambIntensity; -    AnimationBlock color; -    AnimationBlock intensity; -    AnimationBlock attStart; -    AnimationBlock attEnd; -    AnimationBlock unk1; -}; - -struct ModelCameraDef { -    int32 id; -    float fov, farclip, nearclip; -    AnimationBlock transPos; -    Vec3D pos; -    AnimationBlock transTarget; -    Vec3D target; -    AnimationBlock rot; -}; - - -struct ModelParticleParams { -    float mid; -    uint32 colors[3]; -    float sizes[3]; -    int16 d[10]; -    float unk[3]; -    float scales[3]; -    float slowdown; -    float rotation; -    float f2[16]; -}; - -struct ModelParticleEmitterDef { -    int32 id; -    int32 flags; -    Vec3D pos; -    int16 bone; -    int16 texture; -    int32 nZero1; -    int32 ofsZero1; -    int32 nZero2; -    int32 ofsZero2; -    int16 blend; -    int16 type; -    int16 s1; -    int16 s2; -    int16 cols; -    int16 rows; -    AnimationBlock params[10]; -    ModelParticleParams p; -    AnimationBlock unk; -}; - - -struct ModelRibbonEmitterDef { -    int32 id; -    int32 bone; -    Vec3D pos; -    int32 nTextures; -    int32 ofsTextures; -    int32 nUnknown; -    int32 ofsUnknown; -    AnimationBlock color; -    AnimationBlock opacity; -    AnimationBlock above; -    AnimationBlock below; -    float res, length, unk; -    int16 s1, s2; -    AnimationBlock unk1; -    AnimationBlock unk2; -}; - -  #pragma pack(pop) diff --git a/contrib/vmap_extractor_v2/vmapextract/vmapexport.cpp b/contrib/vmap_extractor_v2/vmapextract/vmapexport.cpp index cc16c9a7176..3dd58a4e3d5 100644 --- a/contrib/vmap_extractor_v2/vmapextract/vmapexport.cpp +++ b/contrib/vmap_extractor_v2/vmapextract/vmapexport.cpp @@ -421,6 +421,10 @@ bool fillArchiveNameVector(std::vector<std::string>& pArchiveNames) {      // open expansion and common files      printf("Opening data files from data directory.\n"); +    sprintf(path, "%slichking.mpq", input_path); +    pArchiveNames.push_back(path); +    sprintf(path, "%scommon-2.mpq", input_path); +    pArchiveNames.push_back(path);      sprintf(path, "%sexpansion.mpq", input_path);      pArchiveNames.push_back(path);      sprintf(path, "%scommon.mpq", input_path); @@ -432,6 +436,8 @@ bool fillArchiveNameVector(std::vector<std::string>& pArchiveNames) {      for (std::vector<std::string>::iterator i = locales.begin(); i != locales.end(); i++)      {          printf("Locale: %s\n", i->c_str()); +        sprintf(path, "%s%s\\lichking-locale-%s.mpq", input_path, i->c_str(), i->c_str()); +        pArchiveNames.push_back(path);          sprintf(path, "%s%s\\expansion-locale-%s.mpq", input_path, i->c_str(), i->c_str());          pArchiveNames.push_back(path);          sprintf(path, "%s%s\\locale-%s.mpq", input_path, i->c_str(), i->c_str()); diff --git a/contrib/vmap_extractor_v2/vmapextract/wmo.cpp b/contrib/vmap_extractor_v2/vmapextract/wmo.cpp index f1868ccf64a..9d8b8f79770 100644 --- a/contrib/vmap_extractor_v2/vmapextract/wmo.cpp +++ b/contrib/vmap_extractor_v2/vmapextract/wmo.cpp @@ -241,205 +241,209 @@ bool WMOGroup::open()  //----------------------------------------------------------------------------  int WMOGroup::ConvertToVMAPGroupWmo(FILE *output, bool pPreciseVectorData)  { -    if(pPreciseVectorData) { -        fwrite(&liquflags,sizeof(uint32),1,output); -        char GRP[] = "GRP "; -        fwrite(GRP,1,4,output); - -        int k = 0; -        int moba_batch = moba_size/12; -        MobaEx = new int[moba_batch*4]; -        for(int i=8; i<moba_size; i+=12) -        { -            MobaEx[k++] = MOBA[i]; -        } -        delete [] MOBA; -        int moba_size_grp = moba_batch*4+4; -        fwrite(&moba_size_grp,4,1,output); -        fwrite(&moba_batch,4,1,output); -        fwrite(MobaEx,4,k,output); -        delete [] MobaEx; - -        uint32 nIdexes = nTriangles * 3; - -        if(fwrite("INDX",4, 1, output) != 1) { printf("Error while writing file nbraches ID"); exit(0); } -        int wsize = sizeof(uint32) + sizeof(unsigned short) * nIdexes; -        if(fwrite(&wsize, sizeof(int), 1, output) != 1) { printf("Error while writing file wsize"); } -        if(fwrite(&nIdexes, sizeof(uint32), 1, output) != 1) { printf("Error while writing file nIndexes"); exit(0); } -        if(nIdexes >0) { -            if(fwrite(MOVI, sizeof(unsigned short), nIdexes, output) != nIdexes) { printf("Error while writing file indexarray"); exit(0); } -        } - -        if(fwrite("VERT",4, 1, output) != 1) { printf("Error while writing file nbraches ID"); exit(0); } -        wsize = sizeof(int) + sizeof(float) * 3 * nVertices; -        if(fwrite(&wsize, sizeof(int), 1, output) != 1) { printf("Error while writing file wsize"); } -        if(fwrite(&nVertices, sizeof(int), 1, output) != 1) { printf("Error while writing file nVertices"); exit(0); } -        if(nVertices >0) { -            if(fwrite(MOVT, sizeof(float)*3, nVertices, output) != nVertices) { printf("Error while writing file vectors"); exit(0); } -        } - -        if(LiquEx_size != 0) -        { -            int LIQU_h[] = {0x5551494C,LiquEx_size+8,hlq_xverts,hlq_yverts};// "LIQU" -            fwrite(LIQU_h,4,4,output); -            fwrite(LiquEx,4,LiquEx_size/4,output); -            delete [] LiquEx; -        } - -        return nTriangles; -    }   else { -        //printf("Convert GroupWmo...\n"); -        //-------GRP ------------------------------------- -        fwrite(&liquflags,sizeof(uint32),1,output); -        char GRP[] = "GRP "; -        fwrite(GRP,1,4,output); -        int k = 0; -        int moba_batch = moba_size/12; -        MobaEx = new int[moba_batch*4]; -        for(int i=8; i<moba_size; i+=12) -        { -            MobaEx[k++] = MOBA[i]; -        } -        delete [] MOBA; -        int moba_size_grp = moba_batch*4+4; -        fwrite(&moba_size_grp,4,1,output); -        fwrite(&moba_batch,4,1,output); -        fwrite(MobaEx,4,k,output); -        delete [] MobaEx; - -        //-------INDX------------------------------------ -        //-------MOPY-------- -        int n = 0; -        int j = 0; -        MopyEx = new char[mopy_size]; -        IndexExTr = new int[mopy_size]; -        for (int i=0; i<mopy_size; i+=2) -        { -            if ((int)MOPY[i]==0x00000008 ||(int)MOPY[i]==0x00000009 ||(int)MOPY[i]==0x00000020 ||(int)MOPY[i]==0x00000021 ||(int)MOPY[i]==0x00000022 ||(int)MOPY[i]==0x00000048 ||(int)MOPY[i]==0x00000049 ||(int)MOPY[i]==0x00000060 ||(int)MOPY[i]==0x00000061 ||(int)MOPY[i]==0x00000062 ||(int)MOPY[i]==0x0000000A ||(int)MOPY[i]==0x0000004A) -            { -                MopyEx[n] = MOPY[i]; -                MopyEx[(n+1)] = MOPY[(i+1)]; -                IndexExTr[j] = i/2; -                j+=1; -                n+=2; -            } -        } -        MopyEx_size = n; -        IndexExTr_size = j; -        delete [] MOPY; -        delete [] MopyEx; - -        //---------MOVI----------- -        MoviEx = new uint16[IndexExTr_size*3]; -        int m = 0; -        for (int i=0; i<IndexExTr_size; i++) -        { -            int n = 0; -            n = IndexExTr[i]*3; -            for (int x=0; x<3; x++) -            { -                MoviEx[m] = MOVI[n]; -                n++; -                m++; -            } -        } -        delete [] MOVI; - -        MoviExSort = new uint16[IndexExTr_size*3]; -        for(int y=0; y<IndexExTr_size*3; y++) -        { -            MoviExSort[y]=MoviEx[y]; -        } - -        uint16 hold; -        for (int pass = 1; pass < IndexExTr_size*3; pass++) -        { -            for (int i=0; i < IndexExTr_size*3-1; i++) -            { -                if (MoviExSort[i] > MoviExSort[i+1]) -                { -                    hold = MoviExSort[i]; -                    MoviExSort[i] = MoviExSort[i+1]; -                    MoviExSort[i+1] = hold; -                } -                //double = 65535 -                else -                    if (MoviExSort[i] == MoviExSort[i+1]) -                        MoviExSort[i+1] = 65535; -            } -        } -        // double delet -        uint16 s = 0; -        for (int i=0; i < IndexExTr_size*3; i++) -        { -            if (MoviExSort[i]!=65535) -            { -                MoviExSort[s] = MoviExSort[i]; -                s++; -            } -        } -        MovtExSort = new uint16[s]; -        for (int i=0; i < s; i++) -        { -            MovtExSort[i] = MoviExSort[i]; -        } - -        for (int i=0; i < IndexExTr_size*3; i++) -        { -            uint16 b = MoviEx[i]; -            for (uint16 x = 0; x < s; x++) -            { -                if(MoviExSort[x] == b) -                { - -                    MoviEx[i] = x; -                    break; -                } -            } - -        } -        int INDX[] = {0x58444E49,IndexExTr_size*6+4,IndexExTr_size*3}; -        fwrite(INDX,4,3,output); -        fwrite(MoviEx,2,IndexExTr_size*3,output); - -        delete [] MoviEx; -        delete [] MoviExSort; -        delete [] IndexExTr; - -        //----------VERT--------- -        //-----MOVT---------- -        int d = 0; -        MovtEx = new float[s*3]; -        for (uint16 i=0; i<s; i++) -        { -            int c=0;//!!!!data in MovtExSort[i] more uint16 in great group wmo files!!!! -            c = MovtExSort[i]*3; -            for (int y=0; y<3; y++) -            { -                MovtEx[d] = MOVT[c]; -                c++; -                d++; -            } -        } -        int VERT[] = {0x54524556,d*4+4,d*4/12};// "VERT" -        fwrite(VERT,4,3,output); -        fwrite(MovtEx,4,d,output); -        //------LIQU------------------------ -        if(LiquEx_size != 0) -        { -            int LIQU_h[] = {0x5551494C,LiquEx_size+8,hlq_xverts,hlq_yverts};// "LIQU" -            fwrite(LIQU_h,4,4,output); -            fwrite(LiquEx,4,LiquEx_size/4,output); -            delete [] LiquEx; -        } - -        delete [] MOVT; -        delete [] MovtEx; -        delete [] MovtExSort; - -        //--------------------------------------------- -        return IndexExTr_size; -    } +	if(pPreciseVectorData) { +		fwrite(&liquflags,sizeof(uint32),1,output);  +		char GRP[] = "GRP "; +		fwrite(GRP,1,4,output); + +		int k = 0; +		int moba_batch = moba_size/12; +		MobaEx = new int[moba_batch*4]; +		for(int i=8; i<moba_size; i+=12) +		{ +			MobaEx[k++] = MOBA[i]; +		} +		delete [] MOBA; +		int moba_size_grp = moba_batch*4+4; +		fwrite(&moba_size_grp,4,1,output);  +		fwrite(&moba_batch,4,1,output); +		fwrite(MobaEx,4,k,output); +		delete [] MobaEx; + +		uint32 nIdexes = nTriangles * 3; + +		if(fwrite("INDX",4, 1, output) != 1) { printf("Error while writing file nbraches ID"); exit(0); } +		int wsize = sizeof(uint32) + sizeof(unsigned short) * nIdexes; +		if(fwrite(&wsize, sizeof(int), 1, output) != 1) { printf("Error while writing file wsize"); } +		if(fwrite(&nIdexes, sizeof(uint32), 1, output) != 1) { printf("Error while writing file nIndexes"); exit(0); } +		if(nIdexes >0) { +			if(fwrite(MOVI, sizeof(unsigned short), nIdexes, output) != nIdexes) { printf("Error while writing file indexarray"); exit(0); } +		} + +		if(fwrite("VERT",4, 1, output) != 1) { printf("Error while writing file nbraches ID"); exit(0); } +		wsize = sizeof(int) + sizeof(float) * 3 * nVertices; +		if(fwrite(&wsize, sizeof(int), 1, output) != 1) { printf("Error while writing file wsize"); } +		if(fwrite(&nVertices, sizeof(int), 1, output) != 1) { printf("Error while writing file nVertices"); exit(0); } +		if(nVertices >0) { +			if(fwrite(MOVT, sizeof(float)*3, nVertices, output) != nVertices) { printf("Error while writing file vectors"); exit(0); } +		} + +		if(LiquEx_size != 0) +		{ +			int LIQU_h[] = {0x5551494C,LiquEx_size+8,hlq_xverts,hlq_yverts};// "LIQU"	 +			fwrite(LIQU_h,4,4,output); +			fwrite(LiquEx,4,LiquEx_size/4,output);	 +			delete [] LiquEx; +		} + +		return nTriangles; +	} 	else { +		//printf("Convert GroupWmo...\n"); +		//-------GRP ------------------------------------- +		fwrite(&liquflags,sizeof(uint32),1,output);  +		char GRP[] = "GRP "; +		fwrite(GRP,1,4,output); +		int k = 0; +		int moba_batch = moba_size/12; +		MobaEx = new int[moba_batch*4]; +		for(int i=8; i<moba_size; i+=12) +		{ +			MobaEx[k++] = MOBA[i]; +		} +		delete [] MOBA; +		int moba_size_grp = moba_batch*4+4; +		fwrite(&moba_size_grp,4,1,output);  +		fwrite(&moba_batch,4,1,output); +		fwrite(MobaEx,4,k,output); +		delete [] MobaEx; + +		//-------INDX------------------------------------ +		//-------MOPY-------- +		int n = 0; +		int j = 0; +		MopyEx = new char[mopy_size]; +		IndexExTr = new int[mopy_size]; +		for (int i=0; i<mopy_size; i+=2) +		{ +            // Skip no collision triangles +            if ((int)MOPY[i]&WMO_MATERIAL_NO_COLLISION) +                continue; +            // Use only this triangles +            if ((int)MOPY[i]&(WMO_MATERIAL_HINT|WMO_MATERIAL_COLLIDE_HIT)) +			{     +				MopyEx[n] = MOPY[i]; +				MopyEx[(n+1)] = MOPY[(i+1)]; +				IndexExTr[j] = i/2; +				j+=1;         +				n+=2; +			}     +		} +		MopyEx_size = n; +		IndexExTr_size = j; +		delete [] MOPY; +		delete [] MopyEx; + +		//---------MOVI----------- +		MoviEx = new uint16[IndexExTr_size*3]; +		int m = 0; +		for (int i=0; i<IndexExTr_size; i++) +		{ +			int n = 0; +			n = IndexExTr[i]*3; +			for (int x=0; x<3; x++) +			{ +				MoviEx[m] = MOVI[n]; +				n++; +				m++; +			} +		} +		delete [] MOVI; + +		MoviExSort = new uint16[IndexExTr_size*3]; +		for(int y=0; y<IndexExTr_size*3; y++) +		{ +			MoviExSort[y]=MoviEx[y];		 +		} + +		uint16 hold; +		for (int pass = 1; pass < IndexExTr_size*3; pass++) +		{ +			for (int i=0; i < IndexExTr_size*3-1; i++) +			{ +				if (MoviExSort[i] > MoviExSort[i+1])  +				{ +					hold = MoviExSort[i]; +					MoviExSort[i] = MoviExSort[i+1]; +					MoviExSort[i+1] = hold; +				} +				//double = 65535	 +				else +					if (MoviExSort[i] == MoviExSort[i+1]) +						MoviExSort[i+1] = 65535;	 +			} +		} +		// double delet +		uint16 s = 0; +		for (int i=0; i < IndexExTr_size*3; i++) +		{ +			if (MoviExSort[i]!=65535) +			{ +				MoviExSort[s] = MoviExSort[i]; +				s++; +			} +		} +		MovtExSort = new uint16[s]; +		for (int i=0; i < s; i++) +		{ +			MovtExSort[i] = MoviExSort[i]; +		} + +		for (int i=0; i < IndexExTr_size*3; i++) +		{ +			uint16 b = MoviEx[i]; +			for (uint16 x = 0; x < s; x++) +			{ +				if(MoviExSort[x] == b) +				{ + +					MoviEx[i] = x; +					break; +				} +			}	 + +		} +		int INDX[] = {0x58444E49,IndexExTr_size*6+4,IndexExTr_size*3}; +		fwrite(INDX,4,3,output); +		fwrite(MoviEx,2,IndexExTr_size*3,output); + +		delete [] MoviEx; +		delete [] MoviExSort; +		delete [] IndexExTr; + +		//----------VERT--------- +		//-----MOVT---------- +		int d = 0; +		MovtEx = new float[s*3]; +		for (uint16 i=0; i<s; i++) +		{ +			int c=0;//!!!!data in MovtExSort[i] more uint16 in great group wmo files!!!! +			c = MovtExSort[i]*3; +			for (int y=0; y<3; y++) +			{ +				MovtEx[d] = MOVT[c]; +				c++; +				d++; +			} +		} +		int VERT[] = {0x54524556,d*4+4,d*4/12};// "VERT" +		fwrite(VERT,4,3,output); +		fwrite(MovtEx,4,d,output);	 +		//------LIQU------------------------ +		if(LiquEx_size != 0) +		{ +			int LIQU_h[] = {0x5551494C,LiquEx_size+8,hlq_xverts,hlq_yverts};// "LIQU"	 +			fwrite(LIQU_h,4,4,output); +			fwrite(LiquEx,4,LiquEx_size/4,output);	 +			delete [] LiquEx; +		} + +		delete [] MOVT; +		delete [] MovtEx; +		delete [] MovtExSort; + +		//---------------------------------------------	 +		return IndexExTr_size; +	}  }  WMOGroup::~WMOGroup() diff --git a/contrib/vmap_extractor_v2/vmapextract/wmo.h b/contrib/vmap_extractor_v2/vmapextract/wmo.h index 832f9265434..436aa1ac60e 100644 --- a/contrib/vmap_extractor_v2/vmapextract/wmo.h +++ b/contrib/vmap_extractor_v2/vmapextract/wmo.h @@ -10,6 +10,14 @@  #include <set>  #include "mpq.h" +// MOPY flags +#define WMO_MATERIAL_NOCAMCOLLIDE    0x01 +#define WMO_MATERIAL_DETAIL          0x02 +#define WMO_MATERIAL_NO_COLLISION    0x04 +#define WMO_MATERIAL_HINT            0x08 +#define WMO_MATERIAL_RENDER          0x10 +#define WMO_MATERIAL_COLLIDE_HIT     0x20 +#define WMO_MATERIAL_WALL_SURFACE    0x40  class WMOInstance;  class WMOManager; | 
