mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-01 07:12:50 -06:00
restore the sharing of sequences. Shrinks the grammar by ~45%
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
void PgfFlag::release(ref<PgfFlag> flag)
|
||||
{
|
||||
pgf_literal_free(flag->value);
|
||||
PgfDB::free(flag);
|
||||
}
|
||||
|
||||
void PgfAbsFun::release(ref<PgfAbsFun> absfun)
|
||||
@@ -12,11 +13,14 @@ void PgfAbsFun::release(ref<PgfAbsFun> absfun)
|
||||
if (absfun->bytecode != 0) {
|
||||
PgfDB::free(absfun->bytecode);
|
||||
}
|
||||
|
||||
PgfDB::free(absfun);
|
||||
}
|
||||
|
||||
void PgfAbsCat::release(ref<PgfAbsCat> abscat)
|
||||
{
|
||||
pgf_context_free(abscat->context);
|
||||
PgfDB::free(abscat);
|
||||
}
|
||||
|
||||
void PgfPGF::release(ref<PgfPGF> pgf)
|
||||
@@ -27,6 +31,7 @@ void PgfPGF::release(ref<PgfPGF> pgf)
|
||||
namespace_release(pgf->abstract.funs);
|
||||
namespace_release(pgf->abstract.cats);
|
||||
namespace_release(pgf->concretes);
|
||||
PgfDB::free(pgf);
|
||||
}
|
||||
|
||||
void PgfConcr::release(ref<PgfConcr> concr)
|
||||
@@ -35,6 +40,7 @@ void PgfConcr::release(ref<PgfConcr> concr)
|
||||
namespace_release(concr->lins);
|
||||
namespace_release(concr->lincats);
|
||||
namespace_release(concr->printnames);
|
||||
PgfDB::free(concr);
|
||||
}
|
||||
|
||||
void PgfConcrLincat::release(ref<PgfConcrLincat> lincat)
|
||||
@@ -44,6 +50,29 @@ void PgfConcrLincat::release(ref<PgfConcrLincat> lincat)
|
||||
}
|
||||
|
||||
PgfDB::free(lincat->fields);
|
||||
|
||||
for (size_t i = 0; i < lincat->args->len; i++) {
|
||||
PgfDB::free(vector_elem(lincat->args, i)->param);
|
||||
}
|
||||
PgfDB::free(lincat->args);
|
||||
|
||||
for (size_t i = 0; i < lincat->res->len; i++) {
|
||||
ref<PgfPResult> res = *vector_elem(lincat->res, i);
|
||||
if (res->vars != 0)
|
||||
PgfDB::free(res->vars);
|
||||
PgfDB::free(res);
|
||||
}
|
||||
PgfDB::free(lincat->res);
|
||||
|
||||
for (size_t i = 0; i < lincat->seqs->len; i++) {
|
||||
ref<PgfSequence> seq = *vector_elem(lincat->seqs, i);
|
||||
if (!(--seq->ref_count)) {
|
||||
PgfSequence::release(seq);
|
||||
}
|
||||
}
|
||||
PgfDB::free(lincat->seqs);
|
||||
|
||||
PgfDB::free(lincat);
|
||||
}
|
||||
|
||||
PGF_INTERNAL
|
||||
@@ -52,9 +81,9 @@ void pgf_symbol_free(PgfSymbol sym)
|
||||
switch (ref<PgfSymbol>::get_tag(sym)) {
|
||||
case PgfSymbolKP::tag: {
|
||||
auto sym_kp = ref<PgfSymbolKP>::untagged(sym);
|
||||
pgf_symbols_free(sym_kp->default_form);
|
||||
PgfSequence::release(sym_kp->default_form);
|
||||
for (size_t i = 0; i < sym_kp->alts.len; i++) {
|
||||
pgf_symbols_free(sym_kp->alts.data[i].form);
|
||||
PgfSequence::release(sym_kp->alts.data[i].form);
|
||||
for (size_t j = 0; j < sym_kp->alts.data[i].prefixes->len; j++) {
|
||||
ref<PgfText> prefix = *vector_elem(sym_kp->alts.data[i].prefixes, j);
|
||||
PgfDB::free(prefix);
|
||||
@@ -75,14 +104,13 @@ void pgf_symbol_free(PgfSymbol sym)
|
||||
}
|
||||
}
|
||||
|
||||
PGF_INTERNAL
|
||||
void pgf_symbols_free(ref<Vector<PgfSymbol>> syms)
|
||||
void PgfSequence::release(ref<PgfSequence> seq)
|
||||
{
|
||||
for (size_t i = 0; i < syms->len; i++) {
|
||||
PgfSymbol sym = *vector_elem(syms, i);
|
||||
for (size_t i = 0; i < seq->syms.len; i++) {
|
||||
PgfSymbol sym = *vector_elem(&seq->syms, i);
|
||||
pgf_symbol_free(sym);
|
||||
}
|
||||
PgfDB::free(syms);
|
||||
PgfDB::free(seq);
|
||||
}
|
||||
|
||||
void PgfConcrLin::release(ref<PgfConcrLin> lin)
|
||||
@@ -101,17 +129,18 @@ void PgfConcrLin::release(ref<PgfConcrLin> lin)
|
||||
PgfDB::free(lin->res);
|
||||
|
||||
for (size_t i = 0; i < lin->seqs->len; i++) {
|
||||
ref<Vector<PgfSymbol>> syms = *vector_elem(lin->seqs, i);
|
||||
for (size_t j = 0; j < syms->len; j++) {
|
||||
PgfSymbol sym = *vector_elem(syms, j);
|
||||
pgf_symbol_free(sym);
|
||||
}
|
||||
PgfDB::free(syms);
|
||||
ref<PgfSequence> seq = *vector_elem(lin->seqs, i);
|
||||
if (!(--seq->ref_count)) {
|
||||
PgfSequence::release(seq);
|
||||
}
|
||||
}
|
||||
PgfDB::free(lin->seqs);
|
||||
|
||||
PgfDB::free(lin);
|
||||
}
|
||||
|
||||
void PgfConcrPrintname::release(ref<PgfConcrPrintname> printname)
|
||||
{
|
||||
PgfDB::free(printname->printname);
|
||||
PgfDB::free(printname);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user