diff options
| author | 2022-03-11 00:03:09 -0800 | |
|---|---|---|
| committer | 2022-03-11 00:03:09 -0800 | |
| commit | 44b0c8153a7092f97c36c5aab82b692f672c3ddf (patch) | |
| tree | 5554a3e9e69bd689739c77745cb4a4bf87e98fd6 /src/string_immutable.zig | |
| parent | c8f6337f1f9f22b48286c8bed1e47d44f0657cd0 (diff) | |
| download | bun-44b0c8153a7092f97c36c5aab82b692f672c3ddf.tar.gz bun-44b0c8153a7092f97c36c5aab82b692f672c3ddf.tar.zst bun-44b0c8153a7092f97c36c5aab82b692f672c3ddf.zip | |
Source Maps for client-side errors & columns
Diffstat (limited to '')
| -rw-r--r-- | src/string_immutable.zig | 13 | 
1 files changed, 13 insertions, 0 deletions
| diff --git a/src/string_immutable.zig b/src/string_immutable.zig index 409ded4f1..a5e3e7104 100644 --- a/src/string_immutable.zig +++ b/src/string_immutable.zig @@ -12,6 +12,19 @@ pub inline fn containsChar(self: string, char: u8) bool {  pub inline fn contains(self: string, str: string) bool {      return std.mem.indexOf(u8, self, str) != null;  } +pub inline fn containsComptime(self: string, comptime str: string) bool { +    var remain = self; +    const Int = std.meta.Int(.unsigned, str.len * 8); + +    while (remain.len >= comptime str.len) { +        if (@bitCast(Int, remain.ptr[0..str.len].*) == @bitCast(Int, str.ptr[0..str.len].*)) { +            return true; +        } +        remain = remain[str.len..]; +    } + +    return false; +}  pub const includes = contains;  pub inline fn containsAny(in: anytype, target: string) bool { | 
