herb 0.4.0-x86_64-linux-musl → 0.4.2-x86_64-linux-musl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +6 -6
- data/ext/herb/error_helpers.c +1 -1
- data/ext/herb/error_helpers.h +1 -1
- data/ext/herb/nodes.c +2 -2
- data/ext/herb/nodes.h +1 -1
- data/lib/herb/3.0/herb.so +0 -0
- data/lib/herb/3.1/herb.so +0 -0
- data/lib/herb/3.2/herb.so +0 -0
- data/lib/herb/3.3/herb.so +0 -0
- data/lib/herb/3.4/herb.so +0 -0
- data/lib/herb/ast/nodes.rb +1 -1
- data/lib/herb/errors.rb +1 -1
- data/lib/herb/version.rb +1 -1
- data/lib/herb/visitor.rb +1 -1
- data/sig/serialized_ast_errors.rbs +1 -1
- data/sig/serialized_ast_nodes.rbs +1 -1
- data/src/analyze.c +20 -5
- data/src/analyze_helpers.c +6 -2
- data/src/ast_nodes.c +1 -1
- data/src/ast_pretty_print.c +1 -1
- data/src/errors.c +1 -1
- data/src/include/analyze_helpers.h +1 -1
- data/src/include/ast_nodes.h +1 -1
- data/src/include/ast_pretty_print.h +1 -1
- data/src/include/errors.h +1 -1
- data/src/include/token_struct.h +1 -0
- data/src/include/version.h +1 -1
- data/src/lexer.c +1 -0
- data/src/token.c +1 -0
- data/src/visitor.c +1 -1
- metadata +2 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 3b2d298dc8d57da5985d8cea605fe26126b20cabed0d3d7c15d2a1ebcae9785d
         | 
| 4 | 
            +
              data.tar.gz: 4953d0e0c3eb0031173a05b1b1fda2e3ab8ee8a431d74c0d1628e9be6927e66e
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 0ebbd638edf6340857a758b3457610dcae42bfe0882578e222a88b098668f01262653c672ab9b524aa88b3985b3a684c716907757d0f0cb4e475d3b54aa53b4e
         | 
| 7 | 
            +
              data.tar.gz: dc8469be05e3beeb6f26daab33f627a70827143547c7535d5496d788a385c9fa8e28732b08ef8d7d41383889e8454ecebee8ac74ce6eee4c52fd5ca02acc9f56
         | 
    
        data/README.md
    CHANGED
    
    | @@ -33,21 +33,21 @@ Herb provides a complete ecosystem of HTML+ERB tooling, designed to simplify and | |
| 33 33 | 
             
            - **Herb Language Server** ([available now](https://herb-tools.dev/projects/language-server)):
         | 
| 34 34 | 
             
              Rich integration for editors like VS Code, Zed, Neovim, and more. It provides diagnostics and real-time feedback to keep your templates error-free.
         | 
| 35 35 |  | 
| 36 | 
            -
            - **Herb Formatter** ([ | 
| 37 | 
            -
              Automatic, consistent formatting for HTML+ERB files, reducing manual styling and enforcing a standard across projects.
         | 
| 36 | 
            +
            - **Herb Formatter** ([experimental preview](https://herb-tools.dev/projects/formatter)):
         | 
| 37 | 
            +
              Automatic, consistent formatting for HTML+ERB files, reducing manual styling and enforcing a standard across projects. Currently in experimental preview - use with caution on version-controlled files.
         | 
| 38 38 |  | 
| 39 | 
            -
            - **Herb Linter** ([ | 
| 40 | 
            -
              Static analysis for your HTML+ERB templates to enforce best practices and quickly identify common mistakes.
         | 
| 39 | 
            +
            - **Herb Linter** ([available now](https://herb-tools.dev/projects/linter)):  
         | 
| 40 | 
            +
              Static analysis for your HTML+ERB templates to enforce best practices and quickly identify common mistakes with 17 configurable rules.
         | 
| 41 41 |  | 
| 42 42 | 
             
            You can use Herb programmatically in **Ruby**, as well as in **JavaScript** via Node.js, WebAssembly, or directly in browsers.
         | 
| 43 43 |  | 
| 44 44 | 
             
            For a complete overview of all available tools, libraries, and integrations, visit the [**Projects page**](https://herb-tools.dev/projects) on our documentation site.
         | 
| 45 45 |  | 
| 46 | 
            -
            ##  | 
| 46 | 
            +
            ## Motivation
         | 
| 47 47 |  | 
| 48 48 | 
             
            HTML+ERB templates never really had good, accurate, and reliable tooling. While developer tooling for Ruby code improved significantly in the last few years (especially with the introduction of the new Prism parser), HTML+ERB files remained underserved, lacking fundamental support like syntax checking, auto-formatting, linting, and structural understanding.
         | 
| 49 49 |  | 
| 50 | 
            -
            At the same time, with the rise of tools like [Hotwire](https://hotwired.dev), [Stimulus](https://stimulus.hotwired.dev), [Turbo](https://turbo.hotwired.dev), [HTMX](https://htmx.org), [ | 
| 50 | 
            +
            At the same time, with the rise of tools like [Hotwire](https://hotwired.dev), [Stimulus](https://stimulus.hotwired.dev), [Turbo](https://turbo.hotwired.dev), [HTMX](https://htmx.org), [Unpoly](https://unpoly.com), and [Alpine.js](https://alpinejs.dev), advanced HTML templating became increasingly relevant (again). Developers expect modern, reliable, and precise tooling, especially given the robust ecosystem available to JavaScript frameworks and libraries.
         | 
| 51 51 |  | 
| 52 52 | 
             
            Herb was built to close this tooling gap, providing proper tooling for HTML+ERB that matches what modern developers expect in the age of language servers, LLMs, and AI-driven workflows.
         | 
| 53 53 |  | 
    
        data/ext/herb/error_helpers.c
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/ext/herb/error_helpers.c.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/ext/herb/error_helpers.c.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #include <ruby.h>
         | 
| 5 5 |  | 
    
        data/ext/herb/error_helpers.h
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/ext/herb/error_helpers.h.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/ext/herb/error_helpers.h.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #ifndef HERB_EXTENSION_ERROR_HELPERS_H
         | 
| 5 5 | 
             
            #define HERB_EXTENSION_ERROR_HELPERS_H
         | 
    
        data/ext/herb/nodes.c
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/ext/herb/nodes.c.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/ext/herb/nodes.c.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #include <ruby.h>
         | 
| 5 5 |  | 
| @@ -415,7 +415,7 @@ static VALUE rb_erb_content_node_from_c_struct(AST_ERB_CONTENT_NODE_T* erb_conte | |
| 415 415 | 
             
              VALUE erb_content_node_tag_opening = rb_token_from_c_struct(erb_content_node->tag_opening);
         | 
| 416 416 | 
             
              VALUE erb_content_node_content = rb_token_from_c_struct(erb_content_node->content);
         | 
| 417 417 | 
             
              VALUE erb_content_node_tag_closing = rb_token_from_c_struct(erb_content_node->tag_closing);
         | 
| 418 | 
            -
              /* #<Herb::Template::AnalyzedRubyField: | 
| 418 | 
            +
              /* #<Herb::Template::AnalyzedRubyField:0x00007fffe3368fb8 @name="analyzed_ruby", @options={kind: nil}> */
         | 
| 419 419 | 
             
              VALUE erb_content_node_analyzed_ruby = Qnil;
         | 
| 420 420 | 
             
              VALUE erb_content_node_parsed = (erb_content_node->parsed) ? Qtrue : Qfalse;
         | 
| 421 421 | 
             
              VALUE erb_content_node_valid = (erb_content_node->valid) ? Qtrue : Qfalse;
         | 
    
        data/ext/herb/nodes.h
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/ext/herb/nodes.h.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/ext/herb/nodes.h.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #ifndef HERB_EXTENSION_NODES_H
         | 
| 5 5 | 
             
            #define HERB_EXTENSION_NODES_H
         | 
    
        data/lib/herb/3.0/herb.so
    CHANGED
    
    | Binary file | 
    
        data/lib/herb/3.1/herb.so
    CHANGED
    
    | Binary file | 
    
        data/lib/herb/3.2/herb.so
    CHANGED
    
    | Binary file | 
    
        data/lib/herb/3.3/herb.so
    CHANGED
    
    | Binary file | 
    
        data/lib/herb/3.4/herb.so
    CHANGED
    
    | Binary file | 
    
        data/lib/herb/ast/nodes.rb
    CHANGED
    
    | @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            # typed: true
         | 
| 3 3 |  | 
| 4 4 | 
             
            # NOTE: This file is generated by the templates/template.rb script and should not be
         | 
| 5 | 
            -
            # modified manually. See /Users/marcoroth/Development/herb-release/templates/lib/herb/ast/nodes.rb.erb
         | 
| 5 | 
            +
            # modified manually. See /Users/marcoroth/Development/herb-release-6/templates/lib/herb/ast/nodes.rb.erb
         | 
| 6 6 |  | 
| 7 7 | 
             
            module Herb
         | 
| 8 8 | 
             
              module AST
         | 
    
        data/lib/herb/errors.rb
    CHANGED
    
    | @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            # typed: true
         | 
| 3 3 |  | 
| 4 4 | 
             
            # NOTE: This file is generated by the templates/template.rb script and should not be
         | 
| 5 | 
            -
            # modified manually. See /Users/marcoroth/Development/herb-release/templates/lib/herb/errors.rb.erb
         | 
| 5 | 
            +
            # modified manually. See /Users/marcoroth/Development/herb-release-6/templates/lib/herb/errors.rb.erb
         | 
| 6 6 |  | 
| 7 7 | 
             
            module Herb
         | 
| 8 8 | 
             
              module Errors
         | 
    
        data/lib/herb/version.rb
    CHANGED
    
    
    
        data/lib/herb/visitor.rb
    CHANGED
    
    | @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            # typed: true
         | 
| 3 3 |  | 
| 4 4 | 
             
            # NOTE: This file is generated by the templates/template.rb script and should not be
         | 
| 5 | 
            -
            # modified manually. See /Users/marcoroth/Development/herb-release/templates/lib/herb/visitor.rb.erb
         | 
| 5 | 
            +
            # modified manually. See /Users/marcoroth/Development/herb-release-6/templates/lib/herb/visitor.rb.erb
         | 
| 6 6 |  | 
| 7 7 | 
             
            module Herb
         | 
| 8 8 | 
             
              class Visitor
         | 
| @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            # typed: true
         | 
| 3 3 |  | 
| 4 4 | 
             
            # NOTE: This file is generated by the templates/template.rb script and should not be
         | 
| 5 | 
            -
            # modified manually. See /Users/marcoroth/Development/herb-release/templates/sig/serialized_ast_errors.rbs.erb
         | 
| 5 | 
            +
            # modified manually. See /Users/marcoroth/Development/herb-release-6/templates/sig/serialized_ast_errors.rbs.erb
         | 
| 6 6 |  | 
| 7 7 | 
             
            module Herb
         | 
| 8 8 | 
             
              type serialized_unexpected_error = serialized_error & {
         | 
| @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            # typed: true
         | 
| 3 3 |  | 
| 4 4 | 
             
            # NOTE: This file is generated by the templates/template.rb script and should not be
         | 
| 5 | 
            -
            # modified manually. See /Users/marcoroth/Development/herb-release/templates/sig/serialized_ast_nodes.rbs.erb
         | 
| 5 | 
            +
            # modified manually. See /Users/marcoroth/Development/herb-release-6/templates/sig/serialized_ast_nodes.rbs.erb
         | 
| 6 6 |  | 
| 7 7 | 
             
            module Herb
         | 
| 8 8 | 
             
              type serialized_document_node = serialized_node & {
         | 
    
        data/src/analyze.c
    CHANGED
    
    | @@ -39,7 +39,7 @@ static analyzed_ruby_T* herb_analyze_ruby(char* source) { | |
| 39 39 | 
             
              search_in_nodes(analyzed);
         | 
| 40 40 | 
             
              search_rescue_nodes(analyzed);
         | 
| 41 41 | 
             
              search_ensure_nodes(analyzed);
         | 
| 42 | 
            -
              search_yield_nodes(analyzed);
         | 
| 42 | 
            +
              search_yield_nodes(analyzed->root, analyzed);
         | 
| 43 43 | 
             
              search_block_closing_nodes(analyzed);
         | 
| 44 44 |  | 
| 45 45 | 
             
              return analyzed;
         | 
| @@ -95,8 +95,13 @@ static control_type_t detect_control_type(AST_ERB_CONTENT_NODE_T* erb_node) { | |
| 95 95 |  | 
| 96 96 | 
             
              if (!ruby) { return CONTROL_TYPE_UNKNOWN; }
         | 
| 97 97 |  | 
| 98 | 
            -
              if (ruby->valid) { | 
| 98 | 
            +
              if (ruby->valid) {
         | 
| 99 | 
            +
                if (has_yield_node(ruby)) { return CONTROL_TYPE_YIELD; }
         | 
| 100 | 
            +
                return CONTROL_TYPE_UNKNOWN;
         | 
| 101 | 
            +
              }
         | 
| 99 102 |  | 
| 103 | 
            +
              if (has_yield_node(ruby)) { return CONTROL_TYPE_YIELD; }
         | 
| 104 | 
            +
              if (has_block_node(ruby)) { return CONTROL_TYPE_BLOCK; }
         | 
| 100 105 | 
             
              if (has_if_node(ruby)) { return CONTROL_TYPE_IF; }
         | 
| 101 106 | 
             
              if (has_elsif_node(ruby)) { return CONTROL_TYPE_ELSIF; }
         | 
| 102 107 | 
             
              if (has_else_node(ruby)) { return CONTROL_TYPE_ELSE; }
         | 
| @@ -112,8 +117,6 @@ static control_type_t detect_control_type(AST_ERB_CONTENT_NODE_T* erb_node) { | |
| 112 117 | 
             
              if (has_while_node(ruby)) { return CONTROL_TYPE_WHILE; }
         | 
| 113 118 | 
             
              if (has_until_node(ruby)) { return CONTROL_TYPE_UNTIL; }
         | 
| 114 119 | 
             
              if (has_for_node(ruby)) { return CONTROL_TYPE_FOR; }
         | 
| 115 | 
            -
              if (has_block_node(ruby)) { return CONTROL_TYPE_BLOCK; }
         | 
| 116 | 
            -
              if (has_yield_node(ruby)) { return CONTROL_TYPE_YIELD; }
         | 
| 117 120 | 
             
              if (has_block_closing(ruby)) { return CONTROL_TYPE_BLOCK_CLOSE; }
         | 
| 118 121 |  | 
| 119 122 | 
             
              return CONTROL_TYPE_UNKNOWN;
         | 
| @@ -1020,10 +1023,22 @@ static array_T* rewrite_node_array(AST_NODE_T* node, array_T* array, analyze_rub | |
| 1020 1023 | 
             
                  case CONTROL_TYPE_UNTIL:
         | 
| 1021 1024 | 
             
                  case CONTROL_TYPE_FOR:
         | 
| 1022 1025 | 
             
                  case CONTROL_TYPE_BLOCK:
         | 
| 1023 | 
            -
                  case CONTROL_TYPE_YIELD:
         | 
| 1024 1026 | 
             
                    index = process_control_structure(node, array, index, new_array, context, type);
         | 
| 1025 1027 | 
             
                    continue;
         | 
| 1026 1028 |  | 
| 1029 | 
            +
                  case CONTROL_TYPE_YIELD: {
         | 
| 1030 | 
            +
                    AST_NODE_T* yield_node = create_control_node(erb_node, array_init(8), NULL, NULL, type);
         | 
| 1031 | 
            +
             | 
| 1032 | 
            +
                    if (yield_node) {
         | 
| 1033 | 
            +
                      array_append(new_array, yield_node);
         | 
| 1034 | 
            +
                    } else {
         | 
| 1035 | 
            +
                      array_append(new_array, item);
         | 
| 1036 | 
            +
                    }
         | 
| 1037 | 
            +
             | 
| 1038 | 
            +
                    index++;
         | 
| 1039 | 
            +
                    break;
         | 
| 1040 | 
            +
                  }
         | 
| 1041 | 
            +
             | 
| 1027 1042 | 
             
                  default:
         | 
| 1028 1043 | 
             
                    array_append(new_array, item);
         | 
| 1029 1044 | 
             
                    index++;
         | 
    
        data/src/analyze_helpers.c
    CHANGED
    
    | @@ -279,10 +279,14 @@ bool search_ensure_nodes(analyzed_ruby_T* analyzed) { | |
| 279 279 | 
             
              return false;
         | 
| 280 280 | 
             
            }
         | 
| 281 281 |  | 
| 282 | 
            -
            bool search_yield_nodes( | 
| 283 | 
            -
               | 
| 282 | 
            +
            bool search_yield_nodes(const pm_node_t* node, void* data) {
         | 
| 283 | 
            +
              analyzed_ruby_T* analyzed = (analyzed_ruby_T*) data;
         | 
| 284 | 
            +
             | 
| 285 | 
            +
              if (node->type == PM_YIELD_NODE) {
         | 
| 284 286 | 
             
                analyzed->has_yield_node = true;
         | 
| 285 287 | 
             
                return true;
         | 
| 288 | 
            +
              } else {
         | 
| 289 | 
            +
                pm_visit_child_nodes(node, search_yield_nodes, analyzed);
         | 
| 286 290 | 
             
              }
         | 
| 287 291 |  | 
| 288 292 | 
             
              return false;
         | 
    
        data/src/ast_nodes.c
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/ast_nodes.c.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/ast_nodes.c.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #include <stdio.h>
         | 
| 5 5 | 
             
            #include <stdbool.h>
         | 
    
        data/src/ast_pretty_print.c
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/ast_pretty_print.c.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/ast_pretty_print.c.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #include "include/ast_node.h"
         | 
| 5 5 | 
             
            #include "include/ast_nodes.h"
         | 
    
        data/src/errors.c
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/errors.c.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/errors.c.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #include "include/array.h"
         | 
| 5 5 | 
             
            #include "include/errors.h"
         | 
| @@ -44,6 +44,6 @@ bool search_when_nodes(analyzed_ruby_T* analyzed); | |
| 44 44 | 
             
            bool search_in_nodes(analyzed_ruby_T* analyzed);
         | 
| 45 45 | 
             
            bool search_rescue_nodes(analyzed_ruby_T* analyzed);
         | 
| 46 46 | 
             
            bool search_ensure_nodes(analyzed_ruby_T* analyzed);
         | 
| 47 | 
            -
            bool search_yield_nodes( | 
| 47 | 
            +
            bool search_yield_nodes(const pm_node_t* node, void* data);
         | 
| 48 48 |  | 
| 49 49 | 
             
            #endif
         | 
    
        data/src/include/ast_nodes.h
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/include/ast_nodes.h.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/include/ast_nodes.h.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #ifndef HERB_AST_NODES_H
         | 
| 5 5 | 
             
            #define HERB_AST_NODES_H
         | 
| @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/include/ast_pretty_print.h.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/include/ast_pretty_print.h.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #ifndef HERB_AST_PRETTY_PRINT_H
         | 
| 5 5 | 
             
            #define HERB_AST_PRETTY_PRINT_H
         | 
    
        data/src/include/errors.h
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/include/errors.h.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/include/errors.h.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #ifndef HERB_ERRORS_H
         | 
| 5 5 | 
             
            #define HERB_ERRORS_H
         | 
    
        data/src/include/token_struct.h
    CHANGED
    
    
    
        data/src/include/version.h
    CHANGED
    
    
    
        data/src/lexer.c
    CHANGED
    
    | @@ -269,6 +269,7 @@ token_T* lexer_next_token(lexer_T* lexer) { | |
| 269 269 | 
             
                case '>': return lexer_advance_current(lexer, TOKEN_HTML_TAG_END);
         | 
| 270 270 | 
             
                case '_': return lexer_advance_current(lexer, TOKEN_UNDERSCORE);
         | 
| 271 271 | 
             
                case ':': return lexer_advance_current(lexer, TOKEN_COLON);
         | 
| 272 | 
            +
                case '@': return lexer_advance_current(lexer, TOKEN_AT);
         | 
| 272 273 | 
             
                case ';': return lexer_advance_current(lexer, TOKEN_SEMICOLON);
         | 
| 273 274 | 
             
                case '&': return lexer_advance_current(lexer, TOKEN_AMPERSAND);
         | 
| 274 275 | 
             
                case '!': return lexer_advance_current(lexer, TOKEN_EXCLAMATION);
         | 
    
        data/src/token.c
    CHANGED
    
    | @@ -61,6 +61,7 @@ const char* token_type_to_string(const token_type_T type) { | |
| 61 61 | 
             
                case TOKEN_SLASH: return "TOKEN_SLASH";
         | 
| 62 62 | 
             
                case TOKEN_SEMICOLON: return "TOKEN_SEMICOLON";
         | 
| 63 63 | 
             
                case TOKEN_COLON: return "TOKEN_COLON";
         | 
| 64 | 
            +
                case TOKEN_AT: return "TOKEN_AT";
         | 
| 64 65 | 
             
                case TOKEN_LT: return "TOKEN_LT";
         | 
| 65 66 | 
             
                case TOKEN_PERCENT: return "TOKEN_PERCENT";
         | 
| 66 67 | 
             
                case TOKEN_AMPERSAND: return "TOKEN_AMPERSAND";
         | 
    
        data/src/visitor.c
    CHANGED
    
    | @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            // NOTE: This file is generated by the templates/template.rb script and should not
         | 
| 2 | 
            -
            // be modified manually. See /Users/marcoroth/Development/herb-release/templates/src/visitor.c.erb
         | 
| 2 | 
            +
            // be modified manually. See /Users/marcoroth/Development/herb-release-6/templates/src/visitor.c.erb
         | 
| 3 3 |  | 
| 4 4 | 
             
            #include <stdio.h>
         | 
| 5 5 |  | 
    
        metadata
    CHANGED
    
    | @@ -1,13 +1,13 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: herb
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0.4. | 
| 4 | 
            +
              version: 0.4.2
         | 
| 5 5 | 
             
            platform: x86_64-linux-musl
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Marco Roth
         | 
| 8 8 | 
             
            bindir: exe
         | 
| 9 9 | 
             
            cert_chain: []
         | 
| 10 | 
            -
            date: 2025-07- | 
| 10 | 
            +
            date: 2025-07-28 00:00:00.000000000 Z
         | 
| 11 11 | 
             
            dependencies: []
         | 
| 12 12 | 
             
            description: Powerful and seamless HTML-aware ERB parsing and tooling.
         | 
| 13 13 | 
             
            email:
         |