aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2024-04-08 16:08:35 +0100
committergingerBill <bill@gingerbill.org>2024-04-08 16:08:35 +0100
commit810cf22e5ddd772ee214eec306b1ba148623302c (patch)
tree92421e8b8d605d7aba7799caa56a75b128f0bc2d
parent16dc79fc5c98228471ed57eb0f8e853de739f6d9 (diff)
Obfuscate `#file` and `#procedure` when `-obfuscate-source-code-locations` is enabled
-rw-r--r--src/check_expr.cpp12
-rw-r--r--src/common.cpp13
-rw-r--r--src/llvm_backend_const.cpp15
3 files changed, 25 insertions, 15 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index fe8c9599f..7d8e0f829 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -8157,8 +8157,12 @@ gb_internal ExprKind check_basic_directive_expr(CheckerContext *c, Operand *o, A
o->mode = Addressing_Constant;
String name = bd->name.string;
if (name == "file") {
+ String file = get_file_path_string(bd->token.pos.file_id);
+ if (build_context.obfuscate_source_code_locations) {
+ file = obfuscate_string(file, "F");
+ }
o->type = t_untyped_string;
- o->value = exact_value_string(get_file_path_string(bd->token.pos.file_id));
+ o->value = exact_value_string(file);
} else if (name == "line") {
o->type = t_untyped_integer;
o->value = exact_value_i64(bd->token.pos.line);
@@ -8168,8 +8172,12 @@ gb_internal ExprKind check_basic_directive_expr(CheckerContext *c, Operand *o, A
o->type = t_untyped_string;
o->value = exact_value_string(str_lit(""));
} else {
+ String p = c->proc_name;
+ if (build_context.obfuscate_source_code_locations) {
+ p = obfuscate_string(p, "P");
+ }
o->type = t_untyped_string;
- o->value = exact_value_string(c->proc_name);
+ o->value = exact_value_string(p);
}
} else if (name == "caller_location") {
init_core_source_code_location(c->checker);
diff --git a/src/common.cpp b/src/common.cpp
index aad420325..6a53332d9 100644
--- a/src/common.cpp
+++ b/src/common.cpp
@@ -353,6 +353,19 @@ gb_global bool global_module_path_set = false;
#include "thread_pool.cpp"
+gb_internal String obfuscate_string(String const &s, char const *prefix) {
+ if (s.len == 0) {
+ return {};
+ }
+ GB_ASSERT(prefix != nullptr);
+ u64 hash = gb_fnv64a(s.text, s.len);
+ gbString res = gb_string_make(temporary_allocator(), prefix);
+ res = gb_string_append_fmt(res, "x%llx", cast(long long unsigned)hash);
+ return make_string_c(res);
+}
+
+
+
struct StringIntern {
StringIntern *next;
isize len;
diff --git a/src/llvm_backend_const.cpp b/src/llvm_backend_const.cpp
index 1ca5f4965..5b2af1049 100644
--- a/src/llvm_backend_const.cpp
+++ b/src/llvm_backend_const.cpp
@@ -287,17 +287,6 @@ gb_internal lbValue lb_expr_untyped_const_to_typed(lbModule *m, Ast *expr, Type
return lb_const_value(m, t, tv.value);
}
-gb_internal String lb_obfuscate_string(String const &s, char const *prefix) {
- if (s.len == 0) {
- return {};
- }
- GB_ASSERT(prefix != nullptr);
- u64 hash = gb_fnv64a(s.text, s.len);
- gbString res = gb_string_make(temporary_allocator(), prefix);
- res = gb_string_append_fmt(res, "x%llx", cast(long long unsigned)hash);
- return make_string_c(res);
-}
-
gb_internal i32 lb_obfuscate_i32(i32 i) {
i32 x = cast(i32)gb_fnv64a(&i, sizeof(i));
if (x < 0) {
@@ -314,8 +303,8 @@ gb_internal lbValue lb_const_source_code_location_const(lbModule *m, String cons
i32 column = pos.column;
if (build_context.obfuscate_source_code_locations) {
- file = lb_obfuscate_string(file, "F");
- procedure = lb_obfuscate_string(procedure, "P");
+ file = obfuscate_string(file, "F");
+ procedure = obfuscate_string(procedure, "P");
line = lb_obfuscate_i32(line);
column = lb_obfuscate_i32(column);