Hash :
f0401f0c
Author :
Thomas de Grivel
Date :
2024-03-04T14:19:12
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
/* c3
* Copyright 2022-2024 kmx.io <contact@kmx.io>
*
* Permission is hereby granted to use this software granted the above
* copyright notice and this permission paragraph are included in all
* copies and substantial portions of this software.
*
* THIS SOFTWARE IS PROVIDED "AS-IS" WITHOUT ANY GUARANTEE OF
* PURPOSE AND PERFORMANCE. IN NO EVENT WHATSOEVER SHALL THE
* AUTHOR BE CONSIDERED LIABLE FOR THE USE AND PERFORMANCE OF
* THIS SOFTWARE.
*/
#include "assert.h"
#include "facts_spec_cursor.h"
s_facts_spec_cursor *
facts_spec_cursor_init (s_facts_spec_cursor *cursor,
p_facts_spec spec)
{
assert(cursor);
assert(spec);
cursor->spec = spec;
cursor->subject = spec[0];
cursor->pos = 1;
return cursor;
}
bool facts_spec_cursor_next (s_facts_spec_cursor *cursor,
s_fact *fact)
{
const s_tag *predicate;
const s_tag *object;
assert(cursor);
assert(fact);
do {
if (!cursor->subject)
return false;
predicate = cursor->spec[cursor->pos];
if (! predicate) {
cursor->subject = cursor->spec[cursor->pos + 1];
cursor->pos += 2;
}
} while (! predicate);
object = cursor->spec[cursor->pos + 1];
if (! object) {
err_puts("facts_spec_cursor_next: NULL object");
assert(! "facts_spec_cursor_next: NULL object");
return false;
}
cursor->pos += 2;
fact->subject = cursor->subject;
fact->predicate = predicate;
fact->object = object;
return true;
}