<div dir="ltr">Thanks for the test. Is there any practical difference between "ARGS=" and "ARGS"?</div><br><div class="gmail_quote"><div dir="ltr">On Thu, Sep 22, 2016 at 9:08 AM Todd Fiala via lldb-commits <<a href="mailto:lldb-commits@lists.llvm.org">lldb-commits@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: tfiala<br class="gmail_msg">
Date: Thu Sep 22 11:00:01 2016<br class="gmail_msg">
New Revision: 282171<br class="gmail_msg">
<br class="gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=282171&view=rev" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project?rev=282171&view=rev</a><br class="gmail_msg">
Log:<br class="gmail_msg">
added environment variable-related Args gtests<br class="gmail_msg">
<br class="gmail_msg">
Also fixed up a couple misbehaving functions. It is perfectly<br class="gmail_msg">
legal to have env vars with no values (i.e. the '=' and following<br class="gmail_msg">
need not be present).<br class="gmail_msg">
<br class="gmail_msg">
Modified:<br class="gmail_msg">
lldb/trunk/source/Interpreter/Args.cpp<br class="gmail_msg">
lldb/trunk/unittests/Interpreter/TestArgs.cpp<br class="gmail_msg">
<br class="gmail_msg">
Modified: lldb/trunk/source/Interpreter/Args.cpp<br class="gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Interpreter/Args.cpp?rev=282171&r1=282170&r2=282171&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/source/Interpreter/Args.cpp?rev=282171&r1=282170&r2=282171&view=diff</a><br class="gmail_msg">
==============================================================================<br class="gmail_msg">
--- lldb/trunk/source/Interpreter/Args.cpp (original)<br class="gmail_msg">
+++ lldb/trunk/source/Interpreter/Args.cpp Thu Sep 22 11:00:01 2016<br class="gmail_msg">
@@ -976,13 +976,15 @@ void Args::LongestCommonPrefix(std::stri<br class="gmail_msg">
<br class="gmail_msg">
void Args::AddOrReplaceEnvironmentVariable(llvm::StringRef env_var_name,<br class="gmail_msg">
llvm::StringRef new_value) {<br class="gmail_msg">
- if (env_var_name.empty() || new_value.empty())<br class="gmail_msg">
+ if (env_var_name.empty())<br class="gmail_msg">
return;<br class="gmail_msg">
<br class="gmail_msg">
// Build the new entry.<br class="gmail_msg">
std::string var_string(env_var_name);<br class="gmail_msg">
- var_string += "=";<br class="gmail_msg">
- var_string += new_value;<br class="gmail_msg">
+ if (!new_value.empty()) {<br class="gmail_msg">
+ var_string += "=";<br class="gmail_msg">
+ var_string += new_value;<br class="gmail_msg">
+ }<br class="gmail_msg">
<br class="gmail_msg">
size_t index = 0;<br class="gmail_msg">
if (ContainsEnvironmentVariable(env_var_name, &index)) {<br class="gmail_msg">
@@ -1006,7 +1008,7 @@ bool Args::ContainsEnvironmentVariable(l<br class="gmail_msg">
<br class="gmail_msg">
llvm::StringRef name, value;<br class="gmail_msg">
std::tie(name, value) = arg_value.split('=');<br class="gmail_msg">
- if (name == env_var_name && !value.empty()) {<br class="gmail_msg">
+ if (name == env_var_name) {<br class="gmail_msg">
if (argument_index)<br class="gmail_msg">
*argument_index = i;<br class="gmail_msg">
return true;<br class="gmail_msg">
<br class="gmail_msg">
Modified: lldb/trunk/unittests/Interpreter/TestArgs.cpp<br class="gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/unittests/Interpreter/TestArgs.cpp?rev=282171&r1=282170&r2=282171&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/unittests/Interpreter/TestArgs.cpp?rev=282171&r1=282170&r2=282171&view=diff</a><br class="gmail_msg">
==============================================================================<br class="gmail_msg">
--- lldb/trunk/unittests/Interpreter/TestArgs.cpp (original)<br class="gmail_msg">
+++ lldb/trunk/unittests/Interpreter/TestArgs.cpp Thu Sep 22 11:00:01 2016<br class="gmail_msg">
@@ -11,6 +11,9 @@<br class="gmail_msg">
<br class="gmail_msg">
#include "lldb/Interpreter/Args.h"<br class="gmail_msg">
<br class="gmail_msg">
+#include <limits><br class="gmail_msg">
+#include <sstream><br class="gmail_msg">
+<br class="gmail_msg">
using namespace lldb_private;<br class="gmail_msg">
<br class="gmail_msg">
TEST(ArgsTest, TestSingleArg) {<br class="gmail_msg">
@@ -153,3 +156,85 @@ TEST(ArgsTest, StringToScriptLanguage) {<br class="gmail_msg">
}<br class="gmail_msg">
<br class="gmail_msg">
TEST(ArgsTest, StringToVersion) {}<br class="gmail_msg">
+<br class="gmail_msg">
+// Environment Variable Tests<br class="gmail_msg">
+<br class="gmail_msg">
+class EnvVarFixture: public ::testing::Test {<br class="gmail_msg">
+protected:<br class="gmail_msg">
+<br class="gmail_msg">
+ void SetUp() {<br class="gmail_msg">
+ args.AppendArgument(llvm::StringRef("Arg1=foo"));<br class="gmail_msg">
+ args.AppendArgument(llvm::StringRef("Arg2"));<br class="gmail_msg">
+ args.AppendArgument(llvm::StringRef("Arg3=bar"));<br class="gmail_msg">
+ }<br class="gmail_msg">
+<br class="gmail_msg">
+ size_t GetIndexForEnvVar(llvm::StringRef envvar_name) {<br class="gmail_msg">
+ size_t argument_index = std::numeric_limits<size_t>::max();<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(envvar_name,<br class="gmail_msg">
+ &argument_index));<br class="gmail_msg">
+ EXPECT_LT(argument_index, args.GetArgumentCount());<br class="gmail_msg">
+ return argument_index;<br class="gmail_msg">
+ }<br class="gmail_msg">
+<br class="gmail_msg">
+ Args args;<br class="gmail_msg">
+};<br class="gmail_msg">
+<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestContainsEnvironmentVariableNoValue) {<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(llvm::StringRef("Arg2")));<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestContainsEnvironmentVariableWithValue) {<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(llvm::StringRef("Arg3")));<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestContainsEnvironmentVariableNonExistentVariable) {<br class="gmail_msg">
+ auto nonexistent_envvar = llvm::StringRef("ThisEnvVarShouldNotExist");<br class="gmail_msg">
+ EXPECT_FALSE(args.ContainsEnvironmentVariable(nonexistent_envvar));<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestReplaceEnvironmentVariableInitialNoValueWithNoValue) {<br class="gmail_msg">
+ auto envvar_name = llvm::StringRef("Arg2");<br class="gmail_msg">
+ auto argument_index = GetIndexForEnvVar(envvar_name);<br class="gmail_msg">
+<br class="gmail_msg">
+ args.AddOrReplaceEnvironmentVariable(envvar_name, llvm::StringRef(""));<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(envvar_name));<br class="gmail_msg">
+ EXPECT_EQ(envvar_name, args.GetArgumentAtIndex(argument_index));<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestReplaceEnvironmentVariableInitialNoValueWithValue) {<br class="gmail_msg">
+ auto envvar_name = llvm::StringRef("Arg2");<br class="gmail_msg">
+ auto argument_index = GetIndexForEnvVar(envvar_name);<br class="gmail_msg">
+<br class="gmail_msg">
+ auto new_value = llvm::StringRef("NewValue");<br class="gmail_msg">
+ args.AddOrReplaceEnvironmentVariable(envvar_name, new_value);<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(envvar_name));<br class="gmail_msg">
+<br class="gmail_msg">
+ std::stringstream stream;<br class="gmail_msg">
+ stream << envvar_name.str() << '=' << new_value.str();<br class="gmail_msg">
+ EXPECT_EQ(llvm::StringRef(stream.str()),<br class="gmail_msg">
+ args.GetArgumentAtIndex(argument_index));<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestReplaceEnvironmentVariableInitialValueWithNoValue) {<br class="gmail_msg">
+ auto envvar_name = llvm::StringRef("Arg1");<br class="gmail_msg">
+ auto argument_index = GetIndexForEnvVar(envvar_name);<br class="gmail_msg">
+<br class="gmail_msg">
+ args.AddOrReplaceEnvironmentVariable(envvar_name, llvm::StringRef(""));<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(envvar_name));<br class="gmail_msg">
+ EXPECT_EQ(envvar_name, args.GetArgumentAtIndex(argument_index));<br class="gmail_msg">
+}<br class="gmail_msg">
+<br class="gmail_msg">
+TEST_F(EnvVarFixture, TestReplaceEnvironmentVariableInitialValueWithValue) {<br class="gmail_msg">
+ auto envvar_name = llvm::StringRef("Arg1");<br class="gmail_msg">
+ auto argument_index = GetIndexForEnvVar(envvar_name);<br class="gmail_msg">
+<br class="gmail_msg">
+ auto new_value = llvm::StringRef("NewValue");<br class="gmail_msg">
+ args.AddOrReplaceEnvironmentVariable(envvar_name, new_value);<br class="gmail_msg">
+ EXPECT_TRUE(args.ContainsEnvironmentVariable(envvar_name));<br class="gmail_msg">
+<br class="gmail_msg">
+ std::stringstream stream;<br class="gmail_msg">
+ stream << envvar_name.str() << '=' << new_value.str();<br class="gmail_msg">
+ EXPECT_EQ(llvm::StringRef(stream.str()),<br class="gmail_msg">
+ args.GetArgumentAtIndex(argument_index));<br class="gmail_msg">
+}<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
_______________________________________________<br class="gmail_msg">
lldb-commits mailing list<br class="gmail_msg">
<a href="mailto:lldb-commits@lists.llvm.org" class="gmail_msg" target="_blank">lldb-commits@lists.llvm.org</a><br class="gmail_msg">
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits" rel="noreferrer" class="gmail_msg" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits</a><br class="gmail_msg">
</blockquote></div>