GMX_THROW(APIError("Conflicting default values"));
}
}
- // If there is no default value, match is still -1.
- if (enumIndexStore_ != NULL)
- {
- *enumIndexStore_ = match;
- }
}
if (settings.defaultEnumIndex_ >= 0)
{
addValue(allowed_[settings.defaultEnumIndex_]);
commitValues();
}
+ // Somewhat subtly, this does not update the stored enum index if the
+ // caller has not provided store() or storeVector(), because values()
+ // will be empty in such a case. This leads to (desired) behavior of
+ // preserving the existing value in the enum index store variable in such
+ // cases.
+ refreshEnumIndexStore();
}
std::string StringOptionStorage::formatExtraDescription() const
void StringOptionStorage::refreshValues()
{
MyBase::refreshValues();
+ refreshEnumIndexStore();
+}
+
+void StringOptionStorage::refreshEnumIndexStore()
+{
if (enumIndexStore_ != NULL)
{
for (size_t i = 0; i < values().size(); ++i)
{
- ValueList::const_iterator match =
- std::find(allowed_.begin(), allowed_.end(), values()[i]);
- GMX_ASSERT(match != allowed_.end(),
- "Enum value not found (internal error)");
- enumIndexStore_[i] = static_cast<int>(match - allowed_.begin());
+ if (values()[i].empty())
+ {
+ enumIndexStore_[i] = -1;
+ }
+ else
+ {
+ ValueList::const_iterator match =
+ std::find(allowed_.begin(), allowed_.end(), values()[i]);
+ GMX_ASSERT(match != allowed_.end(),
+ "Enum value not found (internal error)");
+ enumIndexStore_[i] = static_cast<int>(match - allowed_.begin());
+ }
}
}
}
EXPECT_EQ(1, index);
}
+TEST(OptionsAssignerStringTest, HandlesEnumDefaultValueFromVariable)
+{
+ gmx::Options options(NULL, NULL);
+ std::string value("test");
+ const char * const allowed[] = { "none", "test", "value" };
+ int index = -1;
+ using gmx::StringOption;
+ ASSERT_NO_THROW(options.addOption(
+ StringOption("p").store(&value)
+ .enumValue(allowed).storeEnumIndex(&index)));
+ EXPECT_EQ("test", value);
+ EXPECT_EQ(1, index);
+
+ gmx::OptionsAssigner assigner(&options);
+ EXPECT_NO_THROW(assigner.start());
+ EXPECT_NO_THROW(assigner.finish());
+ EXPECT_NO_THROW(options.finish());
+
+ EXPECT_EQ("test", value);
+ EXPECT_EQ(1, index);
+}
+
+TEST(OptionsAssignerStringTest, HandlesEnumDefaultValueFromVector)
+{
+ gmx::Options options(NULL, NULL);
+ std::vector<std::string> value;
+ value.push_back("test");
+ value.push_back("value");
+ const char * const allowed[] = { "none", "test", "value" };
+ int index[2] = {-1, -1};
+ using gmx::StringOption;
+ ASSERT_NO_THROW(options.addOption(
+ StringOption("p").storeVector(&value).valueCount(2)
+ .enumValue(allowed).storeEnumIndex(index)));
+ EXPECT_EQ("test", value[0]);
+ EXPECT_EQ("value", value[1]);
+ EXPECT_EQ(1, index[0]);
+ EXPECT_EQ(2, index[1]);
+
+ gmx::OptionsAssigner assigner(&options);
+ EXPECT_NO_THROW(assigner.start());
+ EXPECT_NO_THROW(assigner.finish());
+ EXPECT_NO_THROW(options.finish());
+
+ EXPECT_EQ("test", value[0]);
+ EXPECT_EQ("value", value[1]);
+ EXPECT_EQ(1, index[0]);
+ EXPECT_EQ(2, index[1]);
+}
+
TEST(OptionsAssignerStringTest, HandlesEnumDefaultIndex)
{
gmx::Options options(NULL, NULL);
EXPECT_EQ(1, index);
}
+TEST(OptionsAssignerStringTest, HandlesEnumDefaultIndexFromVariable)
+{
+ gmx::Options options(NULL, NULL);
+ const char * const allowed[] = { "none", "test", "value" };
+ int index = 1;
+ using gmx::StringOption;
+ ASSERT_NO_THROW(options.addOption(
+ StringOption("p")
+ .enumValue(allowed).storeEnumIndex(&index)));
+ EXPECT_EQ(1, index);
+
+ gmx::OptionsAssigner assigner(&options);
+ EXPECT_NO_THROW(assigner.start());
+ EXPECT_NO_THROW(assigner.finish());
+ EXPECT_NO_THROW(options.finish());
+
+ EXPECT_EQ(1, index);
+}
+
} // namespace