tree-sitter/spec/compiler/rules/character_set_spec.cpp

114 lines
4.1 KiB
C++
Raw Normal View History

#include "compiler_spec_helper.h"
2014-02-18 09:07:00 -08:00
#include "rules/character_set.h"
using namespace rules;
START_TEST
describe("character sets", []() {
2014-02-08 15:26:10 -08:00
char max_char = 255;
2014-03-09 19:49:35 -07:00
2014-02-08 15:26:10 -08:00
describe("computing the complement", [&]() {
it("works for the set containing only the null character", [&]() {
CharacterSet set1({ '\0' });
auto set2 = set1.complement();
AssertThat(set2, Equals(CharacterSet({
{ 1, max_char }
})));
AssertThat(set2.complement(), Equals(set1));
});
2014-02-08 15:26:10 -08:00
it("works for single character sets", [&]() {
CharacterSet set1({ 'b' });
auto set2 = set1.complement();
AssertThat(set2, Equals(CharacterSet({
{ 0, 'a' },
2014-02-08 15:26:10 -08:00
{ 'c', max_char },
})));
AssertThat(set2.complement(), Equals(set1));
});
});
2014-03-09 19:49:35 -07:00
2014-02-08 15:26:10 -08:00
describe("computing unions", [&]() {
it("works for disjoint sets", [&]() {
CharacterSet set({ {'a', 'z'} });
set.add_set(CharacterSet({ {'A', 'Z'} }));
AssertThat(set, Equals(CharacterSet({ {'a', 'z'}, {'A', 'Z'} })));
});
2014-03-09 19:49:35 -07:00
2014-02-08 15:26:10 -08:00
it("works for sets with adjacent ranges", [&]() {
CharacterSet set({ CharacterRange('a', 'r') });
set.add_set(CharacterSet({ CharacterRange('s', 'z') }));
AssertThat(set, Equals(CharacterSet({ {'a', 'z'} })));
set = CharacterSet({ 'c' });
auto c = set.complement();
2014-02-07 12:57:35 -08:00
set.add_set(c);
AssertThat(set, Equals(CharacterSet({ {0, max_char} })));
});
2014-03-09 19:49:35 -07:00
it("works when the result becomes a continuous range", []() {
CharacterSet set({ {'a', 'd'}, {'f', 'z'} });
set.add_set(CharacterSet({ {'c', 'g'} }));
AssertThat(set, Equals(CharacterSet({ {'a', 'z'} })));
});
2014-03-09 19:49:35 -07:00
2014-02-08 15:26:10 -08:00
it("does nothing for the set of all characters", [&]() {
2014-02-06 12:58:00 -08:00
CharacterSet set({ 'a' });
2014-02-07 12:57:35 -08:00
set.add_set(set.complement());
AssertThat(set, Equals(CharacterSet({ {'\0', max_char} })));
});
});
2014-03-09 19:49:35 -07:00
2014-02-07 12:57:35 -08:00
describe("computing differences", []() {
it("works for disjoint sets", []() {
CharacterSet set1({ {'a','z'} });
set1.remove_set(CharacterSet({ {'A','Z'} }));
AssertThat(set1, Equals(CharacterSet({ {'a', 'z'} })));
2014-02-07 12:57:35 -08:00
});
2014-03-09 19:49:35 -07:00
2014-02-07 12:57:35 -08:00
it("works when one set spans the other", []() {
CharacterSet set1({ {'a','z'} });
set1.remove_set(CharacterSet({ {'d','s'} }));
2014-02-07 12:57:35 -08:00
AssertThat(set1, Equals(CharacterSet({ {'a', 'c'}, {'t', 'z'} })));
});
2014-03-09 19:49:35 -07:00
2014-02-07 12:57:35 -08:00
it("works for sets that overlap", []() {
CharacterSet set1({ {'a','s'} });
set1.remove_set(CharacterSet({ {'m','z'} }));
AssertThat(set1, Equals(CharacterSet({ {'a', 'l'} })));
2014-02-07 12:57:35 -08:00
CharacterSet set2({ {'m','z'} });
set2.remove_set(CharacterSet({ {'a','s'} }));
AssertThat(set2, Equals(CharacterSet({ {'t', 'z'} })));
2014-02-07 12:57:35 -08:00
});
2014-03-09 19:49:35 -07:00
2014-02-07 12:57:35 -08:00
it("works for sets with multiple ranges", []() {
CharacterSet set1({ {'a','d'}, {'m', 'z'} });
set1.remove_set(CharacterSet({ {'c','o'}, {'s','x'} }));
AssertThat(set1, Equals(CharacterSet({ {'a', 'b'}, {'p','r'}, {'y','z'} })));
});
});
2014-03-09 19:49:35 -07:00
2014-02-08 15:26:10 -08:00
describe("computing intersections", []() {
it("returns an empty set for disjoint sets", []() {
CharacterSet set1({ {'a','d'} });
CharacterSet set2({ {'e','x'} });
2014-02-08 15:26:10 -08:00
AssertThat(set1.intersect(set2), Equals(CharacterSet()));
});
2014-03-09 19:49:35 -07:00
2014-02-08 15:26:10 -08:00
it("works for sets with a single overlapping range", []() {
CharacterSet set1({ {'a','e'} });
CharacterSet set2({ {'c','x'} });
AssertThat(set1.intersect(set2), Equals(CharacterSet({ {'c', 'e'} })));
2014-02-08 15:26:10 -08:00
});
it("works for sets with two overlapping ranges", []() {
CharacterSet set1({ {'a','e'}, {'w','z'} });
CharacterSet set2({ {'c','y'} });
2014-02-08 15:26:10 -08:00
AssertThat(set1.intersect(set2), Equals(CharacterSet({ {'c', 'e'}, {'w', 'y'} })));
});
});
});
END_TEST