aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr/eval.cc
diff options
context:
space:
mode:
authorQyriad <qyriad@qyriad.me>2024-07-15 18:19:54 -0600
committerQyriad <qyriad@qyriad.me>2024-07-20 20:20:01 +0000
commite67dac1d7493741cf88b411f68e31fc496179bf2 (patch)
tree940ec66fad8d250db1eea154265b5765efa13657 /src/libexpr/eval.cc
parenta3361557e3f4a53b90ca5067e68ba9788df20928 (diff)
libexpr: rename confusing makeImmutableString -> gcCopyStringIfNeeded
The purpose of this function has little to do with immutability. Value's strings are never mutated, and the point of this function is to singleton empty strings. Change-Id: Ifd41dd952409d54e4d3de9ab59064e6928b0e480
Diffstat (limited to 'src/libexpr/eval.cc')
-rw-r--r--src/libexpr/eval.cc21
1 files changed, 3 insertions, 18 deletions
diff --git a/src/libexpr/eval.cc b/src/libexpr/eval.cc
index ce469e5c5..06b1f27f5 100644
--- a/src/libexpr/eval.cc
+++ b/src/libexpr/eval.cc
@@ -49,21 +49,6 @@ using json = nlohmann::json;
namespace nix {
-// When there's no need to write to the string, we can optimize away empty
-// string allocations.
-// This function handles makeImmutableString(std::string_view()) by returning
-// the empty string.
-static const char * makeImmutableString(std::string_view s)
-{
- const size_t size = s.size();
- if (size == 0)
- return "";
- auto t = gcAllocString(size + 1);
- memcpy(t, s.data(), size);
- t[size] = '\0';
- return t;
-}
-
RootValue allocRootValue(Value * v)
{
#if HAVE_BOEHMGC
@@ -784,7 +769,7 @@ DebugTraceStacker::DebugTraceStacker(EvalState & evalState, DebugTrace t)
void Value::mkString(std::string_view s)
{
- mkString(makeImmutableString(s));
+ mkString(gcCopyStringIfNeeded(s));
}
@@ -795,7 +780,7 @@ static void copyContextToValue(Value & v, const NixStringContext & context)
v.string.context = (const char * *)
gcAllocBytes((context.size() + 1) * sizeof(char *));
for (auto & i : context)
- v.string.context[n++] = makeImmutableString(i.to_string());
+ v.string.context[n++] = gcCopyStringIfNeeded(i.to_string());
v.string.context[n] = 0;
}
}
@@ -815,7 +800,7 @@ void Value::mkStringMove(const char * s, const NixStringContext & context)
void Value::mkPath(const SourcePath & path)
{
- mkPath(makeImmutableString(path.path.abs()));
+ mkPath(gcCopyStringIfNeeded(path.path.abs()));
}