summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksey Veresov <aleksey@veresov.pro>2020-01-31 17:36:15 +0300
committerAleksey Veresov <aleksey@veresov.pro>2020-01-31 17:36:15 +0300
commiteac37c6a45837f7ea717c9fed8cb21e2d5665618 (patch)
treed09a2c645baf2ab043762856aacc9111be221f99
parent0be032c6998e712dc2c9f2ed97c3491d89eb05af (diff)
downloadxift-eac37c6a45837f7ea717c9fed8cb21e2d5665618.tar
xift-eac37c6a45837f7ea717c9fed8cb21e2d5665618.tar.xz
xift-eac37c6a45837f7ea717c9fed8cb21e2d5665618.zip
[xift] Working.
-rw-r--r--deps.mk8
-rw-r--r--examples/Makefile4
-rw-r--r--examples/error.cpp5
-rw-r--r--examples/filter.cpp5
-rw-r--r--src/attribute.cpp46
-rw-r--r--src/attribute.hpp47
-rw-r--r--src/attribute.obin4456 -> 0 bytes
-rw-r--r--src/exporter.obin2488 -> 0 bytes
-rw-r--r--src/file.obin2992 -> 0 bytes
-rw-r--r--src/str.obin3328 -> 0 bytes
-rw-r--r--src/tag.cpp22
-rw-r--r--src/tag.hpp41
-rw-r--r--src/tag.obin6832 -> 0 bytes
-rw-r--r--src/utils.obin1856 -> 0 bytes
-rw-r--r--src/xift.cpp48
-rw-r--r--src/xift.hpp2
16 files changed, 107 insertions, 121 deletions
diff --git a/deps.mk b/deps.mk
deleted file mode 100644
index 327e510..0000000
--- a/deps.mk
+++ /dev/null
@@ -1,8 +0,0 @@
-attribute.o: src/attribute.cpp src/attribute.hpp src/utils.hpp
-exporter.o: src/exporter.cpp src/exporter.hpp
-file.o: src/file.cpp src/file.hpp src/exporter.hpp
-str.o: src/str.cpp src/str.hpp src/exporter.hpp src/utils.hpp
-tag.o: src/tag.cpp src/tag.hpp src/attribute.hpp src/utils.hpp
-utils.o: src/utils.cpp src/utils.hpp
-xift.o: src/xift.cpp src/xift.hpp src/exporter.hpp src/tag.hpp \
- src/attribute.hpp src/utils.hpp
diff --git a/examples/Makefile b/examples/Makefile
index 3f40167..60df4ff 100644
--- a/examples/Makefile
+++ b/examples/Makefile
@@ -12,9 +12,9 @@ CPPFLAGS += -O3
endif
INCLUDE = -I../src
-LFLAGS = -L.. -lxenophage
+LFLAGS = -L.. -lxift
-XENOPHAGE = ../libxenophage.a
+XENOPHAGE = ../libxift.a
default: $(EXAMPLES)
diff --git a/examples/error.cpp b/examples/error.cpp
index 54bb17d..72c5bfe 100644
--- a/examples/error.cpp
+++ b/examples/error.cpp
@@ -7,13 +7,14 @@ int main()
XiftFile exporter(stdout);
Xift xift(exporter);
- xift.permitted.Tag("p").Attribute("class");
+ xift.Tag("p").Attribute("class");
xift.PutFile("error.html");
if (!xift.End()) {
printf("Error on %d line, %d column:\n%s",
- xift.ErrorLine(), xift.ErrorColumn(), xift.Error());
+ xift.ErrorLine(), xift.ErrorColumn(),
+ xift_error_message(xift.GetError()));
}
return 0;
diff --git a/examples/filter.cpp b/examples/filter.cpp
index 6e786c9..48d0a6a 100644
--- a/examples/filter.cpp
+++ b/examples/filter.cpp
@@ -8,7 +8,7 @@ int main()
Xift xift(exporter);
xift.Tag("a").Attribute("href");
- XiftTags::Tag &p = xift.Tag("p");
+ XiftTag &p = xift.Tag("p");
p.Attribute("class");
p.Attribute("hidden");
p.Attribute("id");
@@ -21,7 +21,8 @@ int main()
if (!xift.End()) {
printf("Error on %d line, %d column:\n%s",
- xift.ErrorLine(), xift.ErrorColumn(), xift.Error());
+ xift.ErrorLine(), xift.ErrorColumn(),
+ xift_error_message(xift.GetError()));
}
return 0;
diff --git a/src/attribute.cpp b/src/attribute.cpp
index 4458713..d6f928a 100644
--- a/src/attribute.cpp
+++ b/src/attribute.cpp
@@ -5,6 +5,23 @@
#include <string.h>
+XiftAttribute::XiftAttribute():
+ name(0), nlen(0), nsize(0), value(0), vlen(0), vsize(0)
+{}
+
+XiftAttribute::~XiftAttribute()
+{
+ if (name) free(name);
+ if (value) free(value);
+}
+
+
+bool XiftAttribute::MatchesForm(const XiftAttribute &form) const
+{
+ return !strcmp(name, form.name);
+}
+
+
XiftAttributes::XiftAttributes(): stack(0)
{}
@@ -18,7 +35,7 @@ XiftAttributes::~XiftAttributes()
}
-XiftAttributes::Attr &XiftAttributes::Attribute(const char *name)
+XiftAttribute &XiftAttributes::Attribute(const char *name)
{
Stack *current = stack;
while (current) {
@@ -27,7 +44,7 @@ XiftAttributes::Attr &XiftAttributes::Attribute(const char *name)
}
current = current->next;
}
- Attr &res = New();
+ XiftAttribute &res = New();
res.nlen = strlen(name);
res.name = xift_str_create_copy(name, name + res.nlen);
res.nsize = res.nlen + 1;
@@ -49,24 +66,7 @@ void XiftAttributes::Remove(const char *name)
}
-XiftAttributes::Attr::Attr():
- name(0), nlen(0), nsize(0), value(0), vlen(0), vsize(0)
-{}
-
-XiftAttributes::Attr::~Attr()
-{
- if (name) free(name);
- if (value) free(value);
-}
-
-
-bool XiftAttributes::Attr::MatchesForm(const XiftAttributes::Attr &form) const
-{
- return !strcmp(name, form.name);
-}
-
-
-XiftAttributes::Attr *XiftAttributes::Top()
+XiftAttribute *XiftAttributes::Top()
{
if (stack) {
return &stack->item;
@@ -84,7 +84,7 @@ void XiftAttributes::Pop()
}
}
-XiftAttributes::Attr &XiftAttributes::New()
+XiftAttribute &XiftAttributes::New()
{
Stack *old = stack;
stack = new Stack;
@@ -92,9 +92,7 @@ XiftAttributes::Attr &XiftAttributes::New()
return stack->item;
}
-bool XiftAttributes::ContainsMatchedForm(
- const XiftAttributes::Attr &attribute
-) const
+bool XiftAttributes::ContainsMatchedForm(const XiftAttribute &attribute) const
{
Stack *current = stack;
while (current) {
diff --git a/src/attribute.hpp b/src/attribute.hpp
index d54d5a3..d3323a4 100644
--- a/src/attribute.hpp
+++ b/src/attribute.hpp
@@ -2,44 +2,41 @@
#define XIFT_INCLUDED_ATTRIBUTE
-class XiftAttributes {
-public:
- class Attr {
- friend class XiftAttributes;
-
- Attr();
- ~Attr();
+struct XiftAttribute {
+ XiftAttribute();
+ ~XiftAttribute();
- bool MatchesForm(const Attr &form) const;
+ bool MatchesForm(const XiftAttribute &form) const;
- char *name;
- int nlen;
- int nsize;
- char *value;
- int vlen;
- int vsize;
+ char *name;
+ int nlen;
+ int nsize;
+ char *value;
+ int vlen;
+ int vsize;
- char value_quota;
- };
+ char value_quota;
+};
+class XiftAttributes {
+public:
XiftAttributes();
~XiftAttributes();
- Attr &Attribute(const char *name);
- void Remove(const char *name);
+ XiftAttribute &Attribute(const char *name);
+ void Remove(const char *name);
-protected:
- Attr *Top();
- void Pop();
- Attr &New();
+ XiftAttribute *Top();
+ void Pop();
+ XiftAttribute &New();
- bool ContainsMatchedForm(const Attr &attribute) const;
+ bool ContainsMatchedForm(const XiftAttribute &attribute) const;
bool MatchesForm(const XiftAttributes &form) const;
private:
struct Stack {
- Stack *next;
- Attr item;
+ Stack *next;
+ XiftAttribute item;
} *stack;
};
diff --git a/src/attribute.o b/src/attribute.o
deleted file mode 100644
index 88d99c2..0000000
--- a/src/attribute.o
+++ /dev/null
Binary files differ
diff --git a/src/exporter.o b/src/exporter.o
deleted file mode 100644
index 18565b9..0000000
--- a/src/exporter.o
+++ /dev/null
Binary files differ
diff --git a/src/file.o b/src/file.o
deleted file mode 100644
index 857e72e..0000000
--- a/src/file.o
+++ /dev/null
Binary files differ
diff --git a/src/str.o b/src/str.o
deleted file mode 100644
index 0ebee34..0000000
--- a/src/str.o
+++ /dev/null
Binary files differ
diff --git a/src/tag.cpp b/src/tag.cpp
index 2f4bbcb..308a7d2 100644
--- a/src/tag.cpp
+++ b/src/tag.cpp
@@ -5,16 +5,16 @@
#include <string.h>
-XiftTags::Item::Item(): name(0), len(0), size(0)
+XiftTag::XiftTag(): name(0), len(0), size(0)
{}
-XiftTags::Item::~Item()
+XiftTag::~XiftTag()
{
if (name) free(name);
}
-bool XiftTags::Item::MatchesForm(const XiftTags::Item &form) const
+bool XiftTag::MatchesForm(const XiftTag &form) const
{
return !strcmp(name, form.name) && XiftAttributes::MatchesForm(form);
}
@@ -34,7 +34,7 @@ XiftTags::~XiftTags()
}
-XiftTags::Item &XiftTags::Tag(const char *name)
+XiftTag &XiftTags::Tag(const char *name)
{
Stack *current = stack;
while (current) {
@@ -43,7 +43,7 @@ XiftTags::Item &XiftTags::Tag(const char *name)
}
current = current->next;
}
- Item &res = New();
+ XiftTag &res = New();
res.len = strlen(name);
res.name = xift_str_create_copy(name, name + res.len);
res.size = res.len + 1;
@@ -66,7 +66,7 @@ void XiftTags::Remove(const char *name)
}
-XiftTags::Item *XiftTags::Top()
+XiftTag *XiftTags::Top()
{
if (stack) {
return stack->item;
@@ -85,9 +85,9 @@ void XiftTags::Pop()
}
}
-XiftTags::Item *XiftTags::PopToBeDeleted()
+XiftTag *XiftTags::PopToBeDeleted()
{
- XiftTags::Item *res = 0;
+ XiftTag *res = 0;
if (stack) {
Stack *old = stack;
res = stack->item;
@@ -97,17 +97,17 @@ XiftTags::Item *XiftTags::PopToBeDeleted()
return res;
}
-XiftTags::Item &XiftTags::New()
+XiftTag &XiftTags::New()
{
Stack *old = stack;
stack = new Stack;
- stack->item = new XiftTags::Item;
+ stack->item = new XiftTag;
stack->next = old;
return *stack->item;
}
-bool XiftTags::ContainsMatchedForm(const XiftTags::Item & tag) const
+bool XiftTags::ContainsMatchedForm(const XiftTag & tag) const
{
Stack *current = stack;
while (current) {
diff --git a/src/tag.hpp b/src/tag.hpp
index 469c4fd..75e5f59 100644
--- a/src/tag.hpp
+++ b/src/tag.hpp
@@ -4,39 +4,36 @@
#include "attribute.hpp"
-class XiftTags {
-public:
- class Item: public XiftAttributes {
- friend class XiftTags;
-
- Item();
- ~Item();
+struct XiftTag: public XiftAttributes {
+ XiftTag();
+ ~XiftTag();
- bool MatchesForm(const Item & form) const;
+ bool MatchesForm(const XiftTag & form) const;
- char *name;
- int len;
- int size;
- };
+ char *name;
+ int len;
+ int size;
+};
+class XiftTags {
+public:
XiftTags();
~XiftTags();
- Item &Tag(const char *name);
- void Remove(const char *name);
+ XiftTag &Tag(const char *name);
+ void Remove(const char *name);
-protected:
- Item *Top();
- void Pop();
- Item *PopToBeDeleted();
- Item &New();
+ XiftTag *Top();
+ void Pop();
+ XiftTag *PopToBeDeleted();
+ XiftTag &New();
- bool ContainsMatchedForm(const Item &tag) const;
+ bool ContainsMatchedForm(const XiftTag &tag) const;
private:
struct Stack {
- Stack *next;
- Item *item;
+ Stack *next;
+ XiftTag *item;
} *stack;
};
diff --git a/src/tag.o b/src/tag.o
deleted file mode 100644
index 00a8cac..0000000
--- a/src/tag.o
+++ /dev/null
Binary files differ
diff --git a/src/utils.o b/src/utils.o
deleted file mode 100644
index 7531793..0000000
--- a/src/utils.o
+++ /dev/null
Binary files differ
diff --git a/src/xift.cpp b/src/xift.cpp
index 8b703cb..2ee127b 100644
--- a/src/xift.cpp
+++ b/src/xift.cpp
@@ -4,15 +4,15 @@
#include <ctype.h>
-const char *XiftErrorMessage(XiftError error)
+const char *xift_error_message(XiftError error)
{
switch (error) {
- case xift_ok: return "";
case xift_wrong_char: return "Wrong character in tag.";
case xift_attr_sep: return "Attribute separator missed.";
case xift_something_after_close: return "Met something after tag close.";
case xift_close_selfclose: return "Tag is closing and self-closing.";
case xift_unwanted_close: return "Closing not opened tag.";
+ default: return "";
}
}
@@ -101,7 +101,7 @@ void Xift::ReadText(char c)
void Xift::OpenTag(char c)
{
- Item &t = opened.New();
+ XiftTag &t = opened.New();
if (c == '/') {
is_closing = true;
state = reading_name;
@@ -117,7 +117,7 @@ void Xift::OpenTag(char c)
void Xift::ReadName(char c)
{
if (AllowedInToken(c)) {
- Item &t = *opened.Top();
+ XiftTag &t = *opened.Top();
xift_str_add(t.name, t.len, t.size, c);
} else if (IsWhitespace(c)) {
state = waiting_attr;
@@ -133,7 +133,7 @@ void Xift::ReadName(char c)
void Xift::WaitAttr(char c)
{
if (AllowedInTokenStart(c)) {
- Item::Attr &a = opened.Top()->New();
+ XiftAttribute &a = opened.Top()->New();
xift_str_add(a.name, a.nlen, a.nsize, c);
state = reading_attr_name;
} else if (c == '/') {
@@ -151,13 +151,13 @@ void Xift::WaitAttr(char c)
void Xift::ReadAttrName(char c)
{
if (AllowedInToken(c)) {
- Item::Attr &a = *opened.Top()->Top();
+ XiftAttribute &a = *opened.Top()->Top();
xift_str_add(a.name, a.nlen, a.nsize, c);
} else if (c == '=') {
state = waiting_attr_value;
} else if (c == '>') {
- Item::Attr &a = *opened.Top()->Top();
- a.value = xift_str_create_copy(a.name, a.name + a.len);
+ XiftAttribute &a = *opened.Top()->Top();
+ a.value = xift_str_create_copy(a.name, a.name + a.nlen);
a.vlen = a.nlen;
a.vsize = a.vlen + 1;
a.value_quota = '\'';
@@ -176,20 +176,20 @@ void Xift::WaitAttrSep(char c)
if (c == '=') {
state = waiting_attr_value;
} else if (c == '>') {
- Item::Attr &a = *opened.Top()->Top();
- a.value = xift_str_create_copy(a.name, a.name + a.len);
+ XiftAttribute &a = *opened.Top()->Top();
+ a.value = xift_str_create_copy(a.name, a.name + a.nlen);
a.vlen = a.nlen;
a.vsize = a.vlen + 1;
a.value_quota = '\'';
CompleteCurrent();
state = reading_text;
} else if (AllowedInTokenStart(c)) {
- Item::Attr &a = *opened.Top()->Top();
- a.value = xift_str_create_copy(a.name, a.name + a.len);
+ XiftAttribute &a = *opened.Top()->Top();
+ a.value = xift_str_create_copy(a.name, a.name + a.nlen);
a.vlen = a.nlen;
a.vsize = a.vlen + 1;
a.value_quota = '\'';
- Item::Attr &n = opened.Top()->New();
+ XiftAttribute &n = opened.Top()->New();
xift_str_add(n.name, n.nlen, n.nsize, c);
state = reading_attr_name;
} else if (!IsWhitespace(c)) {
@@ -205,7 +205,7 @@ void Xift::WaitAttrValue(char c)
value_quota = c;
state = reading_attr_value;
} else if (AllowedInTokenStart(c)) {
- Item::Attr &a = *opened.Top()->Top();
+ XiftAttribute &a = *opened.Top()->Top();
a.value_quota = '\'';
xift_str_add(a.value, a.vlen, a.vsize, c);
value_quota = 0;
@@ -222,7 +222,7 @@ void Xift::ReadAttrValue(char c)
if (c == value_quota) {
state = waiting_attr;
} else {
- Item::Attr &a = *opened.Top()->Top();
+ XiftAttribute &a = *opened.Top()->Top();
xift_str_add(a.value, a.vlen, a.vsize, c);
}
} else {
@@ -231,7 +231,7 @@ void Xift::ReadAttrValue(char c)
state = reading_text;
}
if (AllowedInToken(c)) {
- Item::Attr &a = *opened.Top()->Top();
+ XiftAttribute &a = *opened.Top()->Top();
xift_str_add(a.value, a.vlen, a.vsize, c);
} else if (IsWhitespace(c)) {
state = waiting_attr;
@@ -249,7 +249,7 @@ void Xift::CloseTag(char c)
state = reading_text;
} else if (!IsWhitespace(c)) {
state = state_error;
- error = something_after_close;
+ error = xift_something_after_close;
}
}
@@ -297,7 +297,7 @@ void Xift::CloseTop()
opened.Pop();
}
-void Xift::CloseName(const ScriptVariable &name)
+void Xift::CloseName(const char *name)
{
exporter.Put("</");
exporter.Put(name);
@@ -306,11 +306,11 @@ void Xift::CloseName(const ScriptVariable &name)
void Xift::SelfcloseCurrent()
{
- Item &t = *opened.Top();
+ XiftTag &t = *opened.Top();
exporter.Put('<');
exporter.Put(t.name);
- Item::Attr *a;
- while (a = t.Top()) {
+ XiftAttribute *a;
+ for (a = t.Top(); a; a = t.Top()) {
exporter.Put(' ');
exporter.Put(a->name);
exporter.Put('=');
@@ -325,11 +325,11 @@ void Xift::SelfcloseCurrent()
void Xift::PutCurrent()
{
- Item &t = *opened.Top();
+ XiftTag &t = *opened.Top();
exporter.Put('<');
exporter.Put(t.name);
- Item::Attr *a;
- while (a = t.Top()) {
+ XiftAttribute *a;
+ for (a = t.Top(); a; a = t.Top()) {
exporter.Put(' ');
exporter.Put(a->name);
exporter.Put('=');
diff --git a/src/xift.hpp b/src/xift.hpp
index a37f1c2..674f737 100644
--- a/src/xift.hpp
+++ b/src/xift.hpp
@@ -15,7 +15,7 @@ enum XiftError {
xift_unwanted_close
};
-const char *XiftErrorMessage(XiftError error);
+const char *xift_error_message(XiftError error);
class Xift: public XiftTags {