Skip to content

Commit

Permalink
Take the absolute value of tag type before casting
Browse files Browse the repository at this point in the history
In [my fork](https://github.com/small-tech/tree-sitter-nodekit/tree/nodekit) I added a `GET` element/tag (which includes JavaScript code that’s executed on the server) and this caused some of the other tests to fail.

Looking into the issue, I was able to narrow it down to the `compareTags()` call in the `scan_end_tag_name` in src/scanner.c failing and resulting in `ERRORNEOUS_END_TAG_NAME` errors whenever a custom tag was encounter. Looking deeper, I saw that the comparison of `a->type` and `b->type` in `compareTags` was failing with `-128 != 128`. Given `TagType` should be unsigned, I started wondering where a negative value could have crept in and looked for any casts that might be happening, which led me to the one in the `vc_vector_resize()` function in this pull request.

Taking the absolute value of the value in the buffer before casting it seems to have solved the issue and all my tests are passing again.

This doesn’t affect the tree-sitter-svelte codebase as it stands currently but it should arise if you were to add another tag to `TagType` in the future.
  • Loading branch information
aral authored Jul 8, 2022
1 parent ed9fb88 commit 6726d38
Showing 1 changed file with 1 addition and 1 deletion.
2 changes: 1 addition & 1 deletion src/scanner.c
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ void deserialize(Scanner *scanner, const char *buffer, unsigned length) {
vc_vector_resize(scanner->tags, tag_count, initTag(scanner->A));
for (unsigned j = 0; j < serialized_tag_count; j++) {
Tag *tag = vc_vector_at(scanner->tags, j);
tag->type = (TagType)(buffer[i++]);
tag->type = (TagType)(abs(buffer[i++]));
if (tag->type == CUSTOM) {
uint16_t name_length = (uint8_t)(buffer[i++]);
tag->custom_tag_name =
Expand Down

0 comments on commit 6726d38

Please sign in to comment.