Initial community commit
This commit is contained in:
parent
537bcbc862
commit
fc06254474
16440 changed files with 4239995 additions and 2 deletions
4
Src/Wasabi/bfc/parse/Makefile.am
Normal file
4
Src/Wasabi/bfc/parse/Makefile.am
Normal file
|
@ -0,0 +1,4 @@
|
|||
INCLUDES = -I$(top_srcdir)/src $(all_includes)
|
||||
METASOURCES = AUTO
|
||||
noinst_HEADERS = hierarchyparser.h paramparser.h pathparse.h
|
||||
|
372
Src/Wasabi/bfc/parse/Makefile.in
Normal file
372
Src/Wasabi/bfc/parse/Makefile.in
Normal file
|
@ -0,0 +1,372 @@
|
|||
# Makefile.in generated automatically by automake 1.4-p6 from Makefile.am
|
||||
|
||||
# Copyright (C) 1994, 1995-8, 1999, 2001 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.
|
||||
|
||||
|
||||
SHELL = @SHELL@
|
||||
|
||||
srcdir = @srcdir@
|
||||
top_srcdir = @top_srcdir@
|
||||
VPATH = @srcdir@
|
||||
prefix = @prefix@
|
||||
exec_prefix = @exec_prefix@
|
||||
|
||||
bindir = @bindir@
|
||||
sbindir = @sbindir@
|
||||
libexecdir = @libexecdir@
|
||||
datadir = @datadir@
|
||||
sysconfdir = @sysconfdir@
|
||||
sharedstatedir = @sharedstatedir@
|
||||
localstatedir = @localstatedir@
|
||||
libdir = @libdir@
|
||||
infodir = @infodir@
|
||||
mandir = @mandir@
|
||||
includedir = @includedir@
|
||||
oldincludedir = /usr/include
|
||||
|
||||
DESTDIR =
|
||||
|
||||
pkgdatadir = $(datadir)/@PACKAGE@
|
||||
pkglibdir = $(libdir)/@PACKAGE@
|
||||
pkgincludedir = $(includedir)/@PACKAGE@
|
||||
|
||||
top_builddir = ../../..
|
||||
|
||||
ACLOCAL = @ACLOCAL@
|
||||
AUTOCONF = @AUTOCONF@
|
||||
AUTOMAKE = @AUTOMAKE@
|
||||
AUTOHEADER = @AUTOHEADER@
|
||||
|
||||
INSTALL = @INSTALL@
|
||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@ $(AM_INSTALL_PROGRAM_FLAGS)
|
||||
INSTALL_DATA = @INSTALL_DATA@
|
||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||
transform = @program_transform_name@
|
||||
|
||||
NORMAL_INSTALL = :
|
||||
PRE_INSTALL = :
|
||||
POST_INSTALL = :
|
||||
NORMAL_UNINSTALL = :
|
||||
PRE_UNINSTALL = :
|
||||
POST_UNINSTALL = :
|
||||
host_alias = @host_alias@
|
||||
host_triplet = @host@
|
||||
AR = @AR@
|
||||
AS = @AS@
|
||||
CC = @CC@
|
||||
CXX = @CXX@
|
||||
CXXCPP = @CXXCPP@
|
||||
DLLTOOL = @DLLTOOL@
|
||||
ECHO = @ECHO@
|
||||
EGREP = @EGREP@
|
||||
EXEEXT = @EXEEXT@
|
||||
F77 = @F77@
|
||||
GCJ = @GCJ@
|
||||
GCJFLAGS = @GCJFLAGS@
|
||||
HAVE_LIB = @HAVE_LIB@
|
||||
LIB = @LIB@
|
||||
LIBTOOL = @LIBTOOL@
|
||||
LN_S = @LN_S@
|
||||
LTLIB = @LTLIB@
|
||||
MAKEINFO = @MAKEINFO@
|
||||
OBJDUMP = @OBJDUMP@
|
||||
OBJEXT = @OBJEXT@
|
||||
PACKAGE = @PACKAGE@
|
||||
RANLIB = @RANLIB@
|
||||
RC = @RC@
|
||||
STRIP = @STRIP@
|
||||
VERSION = @VERSION@
|
||||
|
||||
INCLUDES = -I$(top_srcdir)/src $(all_includes)
|
||||
METASOURCES = AUTO
|
||||
noinst_LTLIBRARIES = libbfc_parse.la
|
||||
libbfc_parse_la_SOURCES = hierarchyparser.cpp paramparser.cpp pathparse.cpp
|
||||
noinst_HEADERS = hierarchyparser.h paramparser.h pathparse.h
|
||||
mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs
|
||||
CONFIG_HEADER = ../../../config.h
|
||||
CONFIG_CLEAN_FILES =
|
||||
LTLIBRARIES = $(noinst_LTLIBRARIES)
|
||||
|
||||
|
||||
DEFS = @DEFS@ -I. -I$(srcdir) -I../../..
|
||||
CPPFLAGS = @CPPFLAGS@
|
||||
LDFLAGS = @LDFLAGS@
|
||||
LIBS = @LIBS@
|
||||
libbfc_parse_la_LDFLAGS =
|
||||
libbfc_parse_la_LIBADD =
|
||||
libbfc_parse_la_OBJECTS = hierarchyparser.lo paramparser.lo \
|
||||
pathparse.lo
|
||||
CXXFLAGS = @CXXFLAGS@
|
||||
CXXCOMPILE = $(CXX) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
LTCXXCOMPILE = $(LIBTOOL) --mode=compile $(CXX) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)
|
||||
CXXLD = $(CXX)
|
||||
CXXLINK = $(LIBTOOL) --mode=link $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) $(LDFLAGS) -o $@
|
||||
HEADERS = $(noinst_HEADERS)
|
||||
|
||||
DIST_COMMON = Makefile.am Makefile.in
|
||||
|
||||
|
||||
DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST)
|
||||
|
||||
TAR = tar
|
||||
GZIP_ENV = --best
|
||||
DEP_FILES = .deps/hierarchyparser.P .deps/paramparser.P \
|
||||
.deps/pathparse.P
|
||||
SOURCES = $(libbfc_parse_la_SOURCES)
|
||||
OBJECTS = $(libbfc_parse_la_OBJECTS)
|
||||
|
||||
all: all-redirect
|
||||
.SUFFIXES:
|
||||
.SUFFIXES: .S .c .cpp .lo .o .obj .s
|
||||
$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4)
|
||||
cd $(top_srcdir) && $(AUTOMAKE) --gnu src/bfc/parse/Makefile
|
||||
|
||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status $(BUILT_SOURCES)
|
||||
cd $(top_builddir) \
|
||||
&& CONFIG_FILES=$(subdir)/$@ CONFIG_HEADERS= $(SHELL) ./config.status
|
||||
|
||||
|
||||
mostlyclean-noinstLTLIBRARIES:
|
||||
|
||||
clean-noinstLTLIBRARIES:
|
||||
-test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES)
|
||||
|
||||
distclean-noinstLTLIBRARIES:
|
||||
|
||||
maintainer-clean-noinstLTLIBRARIES:
|
||||
|
||||
# FIXME: We should only use cygpath when building on Windows,
|
||||
# and only if it is available.
|
||||
.c.obj:
|
||||
$(COMPILE) -c `cygpath -w $<`
|
||||
|
||||
.s.o:
|
||||
$(COMPILE) -c $<
|
||||
|
||||
.S.o:
|
||||
$(COMPILE) -c $<
|
||||
|
||||
mostlyclean-compile:
|
||||
-rm -f *.o core *.core
|
||||
-rm -f *.$(OBJEXT)
|
||||
|
||||
clean-compile:
|
||||
|
||||
distclean-compile:
|
||||
-rm -f *.tab.c
|
||||
|
||||
maintainer-clean-compile:
|
||||
|
||||
.s.lo:
|
||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
||||
|
||||
.S.lo:
|
||||
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
|
||||
|
||||
mostlyclean-libtool:
|
||||
-rm -f *.lo
|
||||
|
||||
clean-libtool:
|
||||
-rm -rf .libs _libs
|
||||
|
||||
distclean-libtool:
|
||||
|
||||
maintainer-clean-libtool:
|
||||
|
||||
libbfc_parse.la: $(libbfc_parse_la_OBJECTS) $(libbfc_parse_la_DEPENDENCIES)
|
||||
$(CXXLINK) $(libbfc_parse_la_LDFLAGS) $(libbfc_parse_la_OBJECTS) $(libbfc_parse_la_LIBADD) $(LIBS)
|
||||
.cpp.o:
|
||||
$(CXXCOMPILE) -c $<
|
||||
.cpp.obj:
|
||||
$(CXXCOMPILE) -c `cygpath -w $<`
|
||||
.cpp.lo:
|
||||
$(LTCXXCOMPILE) -c $<
|
||||
|
||||
tags: TAGS
|
||||
|
||||
ID: $(HEADERS) $(SOURCES) $(LISP)
|
||||
list='$(SOURCES) $(HEADERS)'; \
|
||||
unique=`for i in $$list; do echo $$i; done | \
|
||||
awk ' { files[$$0] = 1; } \
|
||||
END { for (i in files) print i; }'`; \
|
||||
here=`pwd` && cd $(srcdir) \
|
||||
&& mkid -f$$here/ID $$unique $(LISP)
|
||||
|
||||
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) $(LISP)
|
||||
tags=; \
|
||||
here=`pwd`; \
|
||||
list='$(SOURCES) $(HEADERS)'; \
|
||||
unique=`for i in $$list; do echo $$i; done | \
|
||||
awk ' { files[$$0] = 1; } \
|
||||
END { for (i in files) print i; }'`; \
|
||||
test -z "$(ETAGS_ARGS)$$unique$(LISP)$$tags" \
|
||||
|| (cd $(srcdir) && etags -o $$here/TAGS $(ETAGS_ARGS) $$tags $$unique $(LISP))
|
||||
|
||||
mostlyclean-tags:
|
||||
|
||||
clean-tags:
|
||||
|
||||
distclean-tags:
|
||||
-rm -f TAGS ID
|
||||
|
||||
maintainer-clean-tags:
|
||||
|
||||
distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir)
|
||||
|
||||
subdir = src/bfc/parse
|
||||
|
||||
distdir: $(DISTFILES)
|
||||
here=`cd $(top_builddir) && pwd`; \
|
||||
top_distdir=`cd $(top_distdir) && pwd`; \
|
||||
distdir=`cd $(distdir) && pwd`; \
|
||||
cd $(top_srcdir) \
|
||||
&& $(AUTOMAKE) --include-deps --build-dir=$$here --srcdir-name=$(top_srcdir) --output-dir=$$top_distdir --gnu src/bfc/parse/Makefile
|
||||
@for file in $(DISTFILES); do \
|
||||
d=$(srcdir); \
|
||||
if test -d $$d/$$file; then \
|
||||
cp -pr $$d/$$file $(distdir)/$$file; \
|
||||
else \
|
||||
test -f $(distdir)/$$file \
|
||||
|| ln $$d/$$file $(distdir)/$$file 2> /dev/null \
|
||||
|| cp -p $$d/$$file $(distdir)/$$file || :; \
|
||||
fi; \
|
||||
done
|
||||
|
||||
DEPS_MAGIC := $(shell mkdir .deps > /dev/null 2>&1 || :)
|
||||
|
||||
-include $(DEP_FILES)
|
||||
|
||||
mostlyclean-depend:
|
||||
|
||||
clean-depend:
|
||||
|
||||
distclean-depend:
|
||||
-rm -rf .deps
|
||||
|
||||
maintainer-clean-depend:
|
||||
|
||||
%.o: %.c
|
||||
@echo '$(COMPILE) -c $<'; \
|
||||
$(COMPILE) -Wp,-MD,.deps/$(*F).pp -c $<
|
||||
@-cp .deps/$(*F).pp .deps/$(*F).P; \
|
||||
tr ' ' '\012' < .deps/$(*F).pp \
|
||||
| sed -e 's/^\\$$//' -e '/^$$/ d' -e '/:$$/ d' -e 's/$$/ :/' \
|
||||
>> .deps/$(*F).P; \
|
||||
rm .deps/$(*F).pp
|
||||
|
||||
%.lo: %.c
|
||||
@echo '$(LTCOMPILE) -c $<'; \
|
||||
$(LTCOMPILE) -Wp,-MD,.deps/$(*F).pp -c $<
|
||||
@-sed -e 's/^\([^:]*\)\.o[ ]*:/\1.lo \1.o :/' \
|
||||
< .deps/$(*F).pp > .deps/$(*F).P; \
|
||||
tr ' ' '\012' < .deps/$(*F).pp \
|
||||
| sed -e 's/^\\$$//' -e '/^$$/ d' -e '/:$$/ d' -e 's/$$/ :/' \
|
||||
>> .deps/$(*F).P; \
|
||||
rm -f .deps/$(*F).pp
|
||||
|
||||
%.o: %.cpp
|
||||
@echo '$(CXXCOMPILE) -c $<'; \
|
||||
$(CXXCOMPILE) -Wp,-MD,.deps/$(*F).pp -c $<
|
||||
@-cp .deps/$(*F).pp .deps/$(*F).P; \
|
||||
tr ' ' '\012' < .deps/$(*F).pp \
|
||||
| sed -e 's/^\\$$//' -e '/^$$/ d' -e '/:$$/ d' -e 's/$$/ :/' \
|
||||
>> .deps/$(*F).P; \
|
||||
rm .deps/$(*F).pp
|
||||
|
||||
%.lo: %.cpp
|
||||
@echo '$(LTCXXCOMPILE) -c $<'; \
|
||||
$(LTCXXCOMPILE) -Wp,-MD,.deps/$(*F).pp -c $<
|
||||
@-sed -e 's/^\([^:]*\)\.o[ ]*:/\1.lo \1.o :/' \
|
||||
< .deps/$(*F).pp > .deps/$(*F).P; \
|
||||
tr ' ' '\012' < .deps/$(*F).pp \
|
||||
| sed -e 's/^\\$$//' -e '/^$$/ d' -e '/:$$/ d' -e 's/$$/ :/' \
|
||||
>> .deps/$(*F).P; \
|
||||
rm -f .deps/$(*F).pp
|
||||
info-am:
|
||||
info: info-am
|
||||
dvi-am:
|
||||
dvi: dvi-am
|
||||
check-am: all-am
|
||||
check: check-am
|
||||
installcheck-am:
|
||||
installcheck: installcheck-am
|
||||
install-exec-am:
|
||||
install-exec: install-exec-am
|
||||
|
||||
install-data-am:
|
||||
install-data: install-data-am
|
||||
|
||||
install-am: all-am
|
||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
||||
install: install-am
|
||||
uninstall-am:
|
||||
uninstall: uninstall-am
|
||||
all-am: Makefile $(LTLIBRARIES) $(HEADERS)
|
||||
all-redirect: all-am
|
||||
install-strip:
|
||||
$(MAKE) $(AM_MAKEFLAGS) AM_INSTALL_PROGRAM_FLAGS=-s install
|
||||
installdirs:
|
||||
|
||||
|
||||
mostlyclean-generic:
|
||||
|
||||
clean-generic:
|
||||
|
||||
distclean-generic:
|
||||
-rm -f Makefile $(CONFIG_CLEAN_FILES)
|
||||
-rm -f config.cache config.log stamp-h stamp-h[0-9]*
|
||||
|
||||
maintainer-clean-generic:
|
||||
mostlyclean-am: mostlyclean-noinstLTLIBRARIES mostlyclean-compile \
|
||||
mostlyclean-libtool mostlyclean-tags mostlyclean-depend \
|
||||
mostlyclean-generic
|
||||
|
||||
mostlyclean: mostlyclean-am
|
||||
|
||||
clean-am: clean-noinstLTLIBRARIES clean-compile clean-libtool \
|
||||
clean-tags clean-depend clean-generic mostlyclean-am
|
||||
|
||||
clean: clean-am
|
||||
|
||||
distclean-am: distclean-noinstLTLIBRARIES distclean-compile \
|
||||
distclean-libtool distclean-tags distclean-depend \
|
||||
distclean-generic clean-am
|
||||
-rm -f libtool
|
||||
|
||||
distclean: distclean-am
|
||||
|
||||
maintainer-clean-am: maintainer-clean-noinstLTLIBRARIES \
|
||||
maintainer-clean-compile maintainer-clean-libtool \
|
||||
maintainer-clean-tags maintainer-clean-depend \
|
||||
maintainer-clean-generic distclean-am
|
||||
@echo "This command is intended for maintainers to use;"
|
||||
@echo "it deletes files that may require special tools to rebuild."
|
||||
|
||||
maintainer-clean: maintainer-clean-am
|
||||
|
||||
.PHONY: mostlyclean-noinstLTLIBRARIES distclean-noinstLTLIBRARIES \
|
||||
clean-noinstLTLIBRARIES maintainer-clean-noinstLTLIBRARIES \
|
||||
mostlyclean-compile distclean-compile clean-compile \
|
||||
maintainer-clean-compile mostlyclean-libtool distclean-libtool \
|
||||
clean-libtool maintainer-clean-libtool tags mostlyclean-tags \
|
||||
distclean-tags clean-tags maintainer-clean-tags distdir \
|
||||
mostlyclean-depend distclean-depend clean-depend \
|
||||
maintainer-clean-depend info-am info dvi-am dvi check check-am \
|
||||
installcheck-am installcheck install-exec-am install-exec \
|
||||
install-data-am install-data install-am install uninstall-am uninstall \
|
||||
all-redirect all-am all installdirs mostlyclean-generic \
|
||||
distclean-generic clean-generic maintainer-clean-generic clean \
|
||||
mostlyclean distclean maintainer-clean
|
||||
|
||||
|
||||
# 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:
|
55
Src/Wasabi/bfc/parse/PathParseW.cpp
Normal file
55
Src/Wasabi/bfc/parse/PathParseW.cpp
Normal file
|
@ -0,0 +1,55 @@
|
|||
#include <bfc/bfc_assert.h>
|
||||
#include "pathparse.h"
|
||||
|
||||
PathParserW::PathParserW(const wchar_t *_str, const wchar_t *sep, int uniquestrs) :
|
||||
processed(FALSE), str(_str ? _str : L""), separators(sep), uniques(uniquestrs)
|
||||
{
|
||||
ASSERT(sep != NULL);
|
||||
}
|
||||
|
||||
int PathParserW::getNumStrings() {
|
||||
process();
|
||||
return strings.getNumItems();
|
||||
}
|
||||
|
||||
wchar_t *PathParserW::enumString(int i) {
|
||||
process();
|
||||
return strings[i];
|
||||
}
|
||||
|
||||
wchar_t *PathParserW::enumStringSafe(int i, wchar_t *def_val) {
|
||||
wchar_t *ret = enumString(i);
|
||||
if (ret == NULL) ret = def_val;
|
||||
return ret;
|
||||
}
|
||||
|
||||
void PathParserW::process() {
|
||||
if (processed) return;
|
||||
processed = 1;
|
||||
preProcess(str);
|
||||
wchar_t *nonconst = str.getNonConstVal();
|
||||
wchar_t *context=0;
|
||||
|
||||
wchar_t *pt = WCSTOK(nonconst, separators, &context);
|
||||
if (pt == NULL) return;
|
||||
postProcess(pt);
|
||||
strings.addItem(pt);
|
||||
for (;;) {
|
||||
wchar_t *pt = WCSTOK(NULL, separators, &context);
|
||||
if (pt == NULL) break;
|
||||
postProcess(pt);
|
||||
if (uniques) {
|
||||
int exists = 0;
|
||||
foreach(strings)
|
||||
if (!WCSICMP(strings.getfor(), pt))
|
||||
{
|
||||
exists=1;
|
||||
break;
|
||||
}
|
||||
endfor;
|
||||
if (exists) continue;
|
||||
}
|
||||
strings.addItem(pt);
|
||||
}
|
||||
}
|
||||
|
99
Src/Wasabi/bfc/parse/hierarchyparser.cpp
Normal file
99
Src/Wasabi/bfc/parse/hierarchyparser.cpp
Normal file
|
@ -0,0 +1,99 @@
|
|||
#include "precomp_wasabi_bfc.h"
|
||||
#include "hierarchyparser.h"
|
||||
#include <bfc/nsguid.h>
|
||||
#include <wchar.h>
|
||||
// This uses an AMAZINGLY inefficient algorithm! woo hoo!
|
||||
|
||||
HierarchyParser::HierarchyParser(const wchar_t *str, const wchar_t *_sibling, const wchar_t *_escape, const wchar_t *_parent_open, const wchar_t *_parent_close) {
|
||||
// Create a new rootnode.
|
||||
rootnode = new HPNode(str);
|
||||
// Parse the rootnode's contents into the rootnode's children.
|
||||
HierarchyParser downparse(rootnode, _sibling, _escape, _parent_open, _parent_close);
|
||||
// Set the actual name of the rootnode ("")
|
||||
(*rootnode)() = L"";
|
||||
// Mark that this was our allocation
|
||||
myalloc = 1;
|
||||
}
|
||||
|
||||
HierarchyParser::~HierarchyParser() {
|
||||
// If we alloc, we must delete.
|
||||
if (myalloc) {
|
||||
delete rootnode;
|
||||
}
|
||||
}
|
||||
|
||||
HPNode *HierarchyParser::findGuid(GUID g) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
HPNode *HierarchyParser::findString(const wchar_t *str) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
HierarchyParser::HierarchyParser(HPNode *_rootnode, const wchar_t *_sibling, const wchar_t *_escape, const wchar_t *_parent_open, const wchar_t *_parent_close) {
|
||||
// We did not alloc, we should not delete.
|
||||
rootnode = _rootnode;
|
||||
sibling = _sibling;
|
||||
escape = _escape;
|
||||
parent_open = _parent_open;
|
||||
parent_close = _parent_close;
|
||||
|
||||
myalloc = 0;
|
||||
|
||||
const wchar_t *parsestr = (*rootnode)();
|
||||
|
||||
size_t i, length = wcslen(parsestr), depth = 0;
|
||||
|
||||
StringW curr_sibling;
|
||||
|
||||
for (i = 0; i < length; i++ ) {
|
||||
wchar_t c = parsestr[i];
|
||||
|
||||
if (isEscape(c)) {
|
||||
// always add the next character
|
||||
curr_sibling += parsestr[++i];
|
||||
} else if (isSibling(c)) {
|
||||
// if we're not inside someone else,
|
||||
if (!depth) {
|
||||
// okay, we're done with the current sibling. ship him off.
|
||||
processSibling(curr_sibling);
|
||||
// on to the next sibling!
|
||||
curr_sibling = L"";
|
||||
} else {
|
||||
curr_sibling += c;
|
||||
}
|
||||
} else if (isParentOpen(c)) {
|
||||
// increment depth
|
||||
curr_sibling += c;
|
||||
depth++;
|
||||
} else if (isParentClose(c)) {
|
||||
// decrement depth
|
||||
curr_sibling += c;
|
||||
depth--;
|
||||
} else {
|
||||
curr_sibling += c;
|
||||
}
|
||||
}
|
||||
|
||||
// If there is anything left over, process it as a sibling.
|
||||
if (curr_sibling.len()) {
|
||||
processSibling(curr_sibling);
|
||||
}
|
||||
}
|
||||
|
||||
void HierarchyParser::processSibling(const wchar_t *sibstr) {
|
||||
StringW curr_sibling = sibstr;
|
||||
// slice the name out of the front of the string.
|
||||
StringW sibling_name = curr_sibling.lSpliceChar(parent_open);
|
||||
// curr_sibling will contain the children of this sibling (or nothing).
|
||||
curr_sibling.rSpliceChar(parent_close);
|
||||
// create a new child for our root node to contain the sibling's child info
|
||||
HPNode *child = new HPNode(curr_sibling, rootnode);
|
||||
// parse the child hierarchically for its children
|
||||
HierarchyParser childparser(child, sibling, escape, parent_open, parent_close);
|
||||
// once parsed. set its name to be this sibling
|
||||
(*child)() = sibling_name;
|
||||
// and lastly add him as a child to the root node.
|
||||
rootnode->addChild(child);
|
||||
}
|
||||
|
55
Src/Wasabi/bfc/parse/hierarchyparser.h
Normal file
55
Src/Wasabi/bfc/parse/hierarchyparser.h
Normal file
|
@ -0,0 +1,55 @@
|
|||
#ifndef __PARAMPARSE_H
|
||||
#define __PARAMPARSE_H
|
||||
|
||||
#include <bfc/parse/pathparse.h>
|
||||
#include <bfc/node.h>
|
||||
#include <bfc/string/StringW.h>
|
||||
|
||||
|
||||
// typedef NodeC<String> HPNode // OH YAH, YOU CAN'T FWD REF TYPEDEFS. STOOOOOOPID.
|
||||
class HPNode : public NodeC<StringW> {
|
||||
public:
|
||||
HPNode( const StringW & myPayload, NodeC<StringW> * myParent = NULL ) : NodeC<StringW>(myPayload, myParent) {}
|
||||
};
|
||||
|
||||
class HierarchyParser {
|
||||
public:
|
||||
HierarchyParser(const wchar_t *str = NULL, const wchar_t *_sibling=L";", const wchar_t *_escape=L"\\", const wchar_t *_parent_open=L"(", const wchar_t *_parent_close=L")") ;
|
||||
~HierarchyParser();
|
||||
|
||||
HPNode *findGuid(GUID g);
|
||||
HPNode *findString(const wchar_t *str);
|
||||
|
||||
int hasGuid(GUID g) { return findGuid(g) != NULL; }
|
||||
int hasString(const wchar_t *str) { return findString(str) != NULL; }
|
||||
|
||||
HPNode *rootNode() { return rootnode; }
|
||||
|
||||
private:
|
||||
HPNode *rootnode;
|
||||
int myalloc;
|
||||
|
||||
StringW sibling;
|
||||
StringW escape;
|
||||
StringW parent_open;
|
||||
StringW parent_close;
|
||||
|
||||
HierarchyParser(HPNode *_rootnode, const wchar_t *_sibling=L";", const wchar_t *_escape=L"\\", const wchar_t *_parent_open=L"(", const wchar_t *_parent_close=L")");
|
||||
void processSibling(const wchar_t *sibling);
|
||||
|
||||
|
||||
inline int isSibling(wchar_t c) {
|
||||
return sibling.lFindChar(c) != -1;
|
||||
}
|
||||
inline int isEscape(wchar_t c) {
|
||||
return escape.lFindChar(c) != -1;
|
||||
}
|
||||
inline int isParentOpen(wchar_t c) {
|
||||
return parent_open.lFindChar(c) != -1;
|
||||
}
|
||||
inline int isParentClose(wchar_t c) {
|
||||
return parent_close.lFindChar(c) != -1;
|
||||
}
|
||||
};
|
||||
|
||||
#endif
|
20
Src/Wasabi/bfc/parse/paramparser.cpp
Normal file
20
Src/Wasabi/bfc/parse/paramparser.cpp
Normal file
|
@ -0,0 +1,20 @@
|
|||
#include "precomp_wasabi_bfc.h"
|
||||
#include "paramparser.h"
|
||||
#include <bfc/nsguid.h>
|
||||
#include <bfc/wasabi_std.h>
|
||||
|
||||
int ParamParser::findGuid(GUID g) {
|
||||
for (int i=0;i<getNumItems();i++) {
|
||||
const wchar_t *e = enumItem(i);
|
||||
GUID eguid = nsGUID::fromCharW(e);
|
||||
if (g == eguid) return i;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
int ParamParser::findString(const wchar_t *str) {
|
||||
for (int i=0;i<getNumItems();i++) {
|
||||
if (!WCSICMP(str, enumItem(i))) return i;
|
||||
}
|
||||
return -1;
|
||||
}
|
23
Src/Wasabi/bfc/parse/paramparser.h
Normal file
23
Src/Wasabi/bfc/parse/paramparser.h
Normal file
|
@ -0,0 +1,23 @@
|
|||
#ifndef __PARAMPARSE_H
|
||||
#define __PARAMPARSE_H
|
||||
|
||||
#include <bfc/parse/pathparse.h>
|
||||
|
||||
class ParamParser : private PathParserW
|
||||
{
|
||||
public:
|
||||
|
||||
ParamParser(const wchar_t *str, const wchar_t *sep=L";", int unique=0) : PathParserW(str, sep, unique) {}
|
||||
|
||||
int findGuid(GUID g);
|
||||
int findString(const wchar_t *str);
|
||||
|
||||
int hasGuid(GUID g) { return findGuid(g) >= 0; }
|
||||
int hasString(const wchar_t *str) { return findString(str) >= 0; }
|
||||
|
||||
const wchar_t *enumItem(int element) { return enumString(element); }
|
||||
int getNumItems() { return getNumStrings(); }
|
||||
const wchar_t *getLastItem() { return getLastString(); }
|
||||
};
|
||||
|
||||
#endif
|
54
Src/Wasabi/bfc/parse/pathparse.cpp
Normal file
54
Src/Wasabi/bfc/parse/pathparse.cpp
Normal file
|
@ -0,0 +1,54 @@
|
|||
#include "precomp_wasabi_bfc.h"
|
||||
#include <bfc/wasabi_std.h>
|
||||
#include "pathparse.h"
|
||||
|
||||
PathParser::PathParser(const char *_str, const char *sep, int uniquestrs) :
|
||||
processed(FALSE), str(_str ? _str : ""), separators(sep), uniques(uniquestrs)
|
||||
{
|
||||
ASSERT(sep != NULL);
|
||||
}
|
||||
|
||||
int PathParser::getNumStrings() {
|
||||
process();
|
||||
return strings.getNumItems();
|
||||
}
|
||||
|
||||
char *PathParser::enumString(int i) {
|
||||
process();
|
||||
return strings[i];
|
||||
}
|
||||
|
||||
char *PathParser::enumStringSafe(int i, char *def_val) {
|
||||
char *ret = enumString(i);
|
||||
if (ret == NULL) ret = def_val;
|
||||
return ret;
|
||||
}
|
||||
|
||||
void PathParser::process() {
|
||||
if (processed) return;
|
||||
processed = 1;
|
||||
preProcess(str);
|
||||
char *nonconst = str.getNonConstVal();
|
||||
|
||||
char *pt = strtok(nonconst, separators);
|
||||
if (pt == NULL) return;
|
||||
postProcess(pt);
|
||||
strings.addItem(pt);
|
||||
for (;;) {
|
||||
char *pt = strtok(NULL, separators);
|
||||
if (pt == NULL) break;
|
||||
postProcess(pt);
|
||||
if (uniques) {
|
||||
int exists = 0;
|
||||
foreach(strings)
|
||||
if (STRCASEEQL(strings.getfor(), pt)) {
|
||||
exists=1;
|
||||
break;
|
||||
}
|
||||
endfor;
|
||||
if (exists) continue;
|
||||
}
|
||||
strings.addItem(pt);
|
||||
}
|
||||
}
|
||||
|
152
Src/Wasabi/bfc/parse/pathparse.h
Normal file
152
Src/Wasabi/bfc/parse/pathparse.h
Normal file
|
@ -0,0 +1,152 @@
|
|||
#ifndef _PATHPARSE_H
|
||||
#define _PATHPARSE_H
|
||||
|
||||
#include <bfc/ptrlist.h>
|
||||
#include <bfc/string/bfcstring.h>
|
||||
#include <bfc/string/StringW.h>
|
||||
|
||||
/**
|
||||
PathParser is a class that parses a DOS/Windows (example: C:\DOS)
|
||||
style path as well as a UNIX style path (example: /usr/local/bin/).
|
||||
|
||||
@short Path parser for Windows and UNIX style paths.
|
||||
@author Nullsoft
|
||||
@ver 1.0
|
||||
*/
|
||||
class PathParser
|
||||
{
|
||||
public:
|
||||
/**
|
||||
When PathParser is instantiated, the contructor takes the path to
|
||||
parse and the separators to use to parse the path. It will then
|
||||
parse the path using the separators and make the parsed elements
|
||||
available. If no separators are given \ and / are used.
|
||||
|
||||
@param str The path to parse.
|
||||
@param separators String that contains the separators to use. Single character separators only.
|
||||
No delimiters between separators in the string.
|
||||
*/
|
||||
PathParser(const char *_str, const char *sep = "\\/", int uniquestrs = 0);
|
||||
|
||||
void setString(const char *string, const char *separators = "\\/");
|
||||
|
||||
/**
|
||||
Gets the number of path elements found in the path.
|
||||
|
||||
@ret The number of path elements found.
|
||||
*/
|
||||
int getNumStrings();
|
||||
|
||||
/**
|
||||
Gets the number of path elements found in the path.
|
||||
|
||||
@ret The number of path elements found.
|
||||
*/
|
||||
char *enumString(int i);
|
||||
|
||||
char *enumStringSafe(int i, char *def_val="");
|
||||
|
||||
/**
|
||||
Gets the last path element from the parsed path.
|
||||
|
||||
@ret The last path element from the parsed path.
|
||||
*/
|
||||
char *getLastString() { return enumString(getNumStrings()-1); }
|
||||
|
||||
protected:
|
||||
/**
|
||||
Override available for pre-processing of the
|
||||
string before it's split. This is done at the start
|
||||
of the process() call.
|
||||
|
||||
@param str A reference to the string to pre-process.
|
||||
*/
|
||||
virtual void preProcess(String &str) { }
|
||||
|
||||
/**
|
||||
Override available for post-processing of the pieces
|
||||
of the command line that are obtained after it's
|
||||
been split.
|
||||
|
||||
@param str The command line piece to post-process.
|
||||
*/
|
||||
virtual void postProcess(char *str) { }
|
||||
|
||||
private:
|
||||
void process();
|
||||
int processed;
|
||||
String str;
|
||||
String separators;
|
||||
PtrList<char> strings;
|
||||
int uniques;
|
||||
};
|
||||
|
||||
class PathParserW
|
||||
{
|
||||
public:
|
||||
/**
|
||||
When PathParser is instantiated, the contructor takes the path to
|
||||
parse and the separators to use to parse the path. It will then
|
||||
parse the path using the separators and make the parsed elements
|
||||
available. If no separators are given \ and / are used.
|
||||
|
||||
@param str The path to parse.
|
||||
@param separators String that contains the separators to use. Single character separators only.
|
||||
No delimiters between separators in the string.
|
||||
*/
|
||||
PathParserW(const wchar_t *_str, const wchar_t *sep = L"\\/", int uniquestrs = 0);
|
||||
|
||||
void setString(const wchar_t *string, const wchar_t *separators = L"\\/");
|
||||
|
||||
/**
|
||||
Gets the number of path elements found in the path.
|
||||
|
||||
@ret The number of path elements found.
|
||||
*/
|
||||
int getNumStrings();
|
||||
|
||||
/**
|
||||
Gets the number of path elements found in the path.
|
||||
|
||||
@ret The number of path elements found.
|
||||
*/
|
||||
wchar_t *enumString(int i);
|
||||
|
||||
wchar_t *enumStringSafe(int i, wchar_t *def_val=L"");
|
||||
|
||||
/**
|
||||
Gets the last path element from the parsed path.
|
||||
|
||||
@ret The last path element from the parsed path.
|
||||
*/
|
||||
wchar_t *getLastString() { return enumString(getNumStrings()-1); }
|
||||
|
||||
protected:
|
||||
/**
|
||||
Override available for pre-processing of the
|
||||
string before it's split. This is done at the start
|
||||
of the process() call.
|
||||
|
||||
@param str A reference to the string to pre-process.
|
||||
*/
|
||||
virtual void preProcess(StringW &str) { }
|
||||
|
||||
/**
|
||||
Override available for post-processing of the pieces
|
||||
of the command line that are obtained after it's
|
||||
been split.
|
||||
|
||||
@param str The command line piece to post-process.
|
||||
*/
|
||||
virtual void postProcess(wchar_t *str) { }
|
||||
|
||||
private:
|
||||
void process();
|
||||
int processed;
|
||||
StringW str;
|
||||
StringW separators;
|
||||
PtrList<wchar_t> strings;
|
||||
int uniques;
|
||||
};
|
||||
|
||||
#endif
|
Loading…
Add table
Add a link
Reference in a new issue