mirror of
https://github.com/OpenSpace/OpenSpace.git
synced 2026-01-07 12:10:52 -06:00
Initial commit of tags added to properties to enable grouping.
This commit is contained in:
@@ -328,6 +328,20 @@ public:
|
||||
*/
|
||||
const ghoul::Dictionary& metaData() const;
|
||||
|
||||
/**
|
||||
* Returns a list of all tags that have been assigned to the Property. Useful for
|
||||
* trying to find a match for a desired batch operation on Properties.
|
||||
* \return Pointer to vector of string tags that were assigned to the Property
|
||||
*/
|
||||
const std::vector<std::string>* getTags(void) const;
|
||||
|
||||
/**
|
||||
* Adds a tag to the Property's list of assigned tags. Tags are useful for creating
|
||||
* groups of Properties that can be used in batch operations.
|
||||
* \param tag The string that is to be assigned to the Property
|
||||
*/
|
||||
void addTag(std::string tag);
|
||||
|
||||
protected:
|
||||
static const char* IdentifierKey;
|
||||
static const char* NameKey;
|
||||
@@ -383,6 +397,9 @@ protected:
|
||||
|
||||
/// The callback function that will be invoked whenever the encapsulated value changes
|
||||
std::function<void()> _onChangeCallback;
|
||||
|
||||
/// Collection of string tag(s) assigned to this property
|
||||
std::vector<std::string> _tags;
|
||||
};
|
||||
|
||||
} // namespace properties
|
||||
|
||||
@@ -211,5 +211,14 @@ std::string Property::generateAdditionalDescription() const {
|
||||
return "";
|
||||
}
|
||||
|
||||
const std::vector<std::string>* Property::getTags(void) const {
|
||||
return &_tags;
|
||||
}
|
||||
|
||||
void Property::addTag(std::string tag) {
|
||||
_tags.push_back(tag);
|
||||
}
|
||||
|
||||
|
||||
} // namespace properties
|
||||
} // namespace openspace
|
||||
|
||||
@@ -672,6 +672,23 @@ scripting::LuaLibrary Scene::luaLibrary() {
|
||||
"the first argument. The second argument can be any type, but it has to "
|
||||
"match the type that the property expects.",
|
||||
},
|
||||
{
|
||||
"setPropertyGroup",
|
||||
&luascriptfunctions::property_setGroup,
|
||||
"string, string, *",
|
||||
"Sets all properties that belong to a tagged group AND match the "
|
||||
"URI (with optional wildcards) in the first argument. Second argument is "
|
||||
"the tag name to match. The third argument can be any type, but it has to "
|
||||
"match tye type that the property expects.",
|
||||
},
|
||||
{
|
||||
"setPropertyGroupSingle",
|
||||
&luascriptfunctions::property_setGroupSingle,
|
||||
"string, *",
|
||||
"Sets all properties that belong to a tagged group. The first argument "
|
||||
"is the tag name to match. The second argument can be any time, but it "
|
||||
"has to match tye type that the property expects.",
|
||||
},
|
||||
{
|
||||
"getPropertyValue",
|
||||
&luascriptfunctions::property_getValue,
|
||||
|
||||
@@ -28,7 +28,20 @@ namespace openspace {
|
||||
|
||||
namespace {
|
||||
|
||||
void applyRegularExpression(lua_State* L, std::regex regex, std::vector<properties::Property*> properties, int type) {
|
||||
void executePropertySet(properties::Property* prop, lua_State* L) {
|
||||
prop->setLuaValue(L);
|
||||
//ensure properties are synced over parallel connection
|
||||
std::string value;
|
||||
prop->getStringValue(value);
|
||||
/*OsEng.parallelConnection().scriptMessage(
|
||||
prop->fullyQualifiedIdentifier(),
|
||||
value
|
||||
);*/
|
||||
}
|
||||
|
||||
void applyRegularExpression(lua_State* L, std::regex regex,
|
||||
std::vector<properties::Property*> properties, int type,
|
||||
const std::string* tagToMatch = nullptr) {
|
||||
using ghoul::lua::errorLocation;
|
||||
using ghoul::lua::luaTypeToString;
|
||||
|
||||
@@ -47,17 +60,16 @@ void applyRegularExpression(lua_State* L, std::regex regex, std::vector<properti
|
||||
"'. Requested type: '" << luaTypeToString(prop->typeLua()) << "'"
|
||||
);
|
||||
}
|
||||
else {
|
||||
prop->setLuaValue(L);
|
||||
//ensure properties are synced over parallel connection
|
||||
std::string value;
|
||||
prop->getStringValue(value);
|
||||
/* OsEng.parallelConnection().scriptMessage(
|
||||
prop->fullyQualifiedIdentifier(),
|
||||
value
|
||||
);*/
|
||||
else if (tagToMatch) {
|
||||
for (const std::string tagEvaluate : *prop->getTags()) {
|
||||
if (tagEvaluate.compare(*tagToMatch) == 0) {
|
||||
executePropertySet(prop, L);
|
||||
break;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
executePropertySet(prop, L);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -85,7 +97,8 @@ int property_setValueSingle(lua_State* L) {
|
||||
|
||||
properties::Property* prop = property(uri);
|
||||
if (!prop) {
|
||||
LERRORC("property_setValue", errorLocation(L) << "Property with URI '" << uri << "' was not found");
|
||||
LERRORC("property_setValue", errorLocation(L) << "Property with URI '"
|
||||
<< uri << "' was not found");
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -131,7 +144,8 @@ int property_setValueRegex(lua_State* L) {
|
||||
);
|
||||
}
|
||||
catch (const std::regex_error& e) {
|
||||
LERRORC("property_setValueRegex", "Malformed regular expression: '" << regex << "'");
|
||||
LERRORC("property_setValueRegex", "Malformed regular expression: '"
|
||||
<< regex << "'");
|
||||
}
|
||||
|
||||
return 0;
|
||||
@@ -174,6 +188,86 @@ int property_setValue(lua_State* L) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* \ingroup LuaScripts
|
||||
* setPropertyGroupSingle(string, *):
|
||||
* Sets value of any property containing a tag that matches that of the first argument
|
||||
* to the value of the second argument, which is arbirtrary, but must agree with the
|
||||
* type the denoted Property expects
|
||||
*/
|
||||
int property_setGroupSingle(lua_State* L) {
|
||||
using ghoul::lua::errorLocation;
|
||||
using ghoul::lua::luaTypeToString;
|
||||
|
||||
int nArguments = lua_gettop(L);
|
||||
SCRIPT_CHECK_ARGUMENTS("property_setValueSingle", L, 2, nArguments);
|
||||
|
||||
std::string tagToMatch = luaL_checkstring(L, -2);
|
||||
const int type = lua_type(L, -1);
|
||||
|
||||
for (properties::Property* prop : allProperties()) {
|
||||
for (std::string tagEvaluate : *prop->getTags()) {
|
||||
if (tagEvaluate.compare(tagToMatch) == 0) {
|
||||
if (type != prop->typeLua()) {
|
||||
LERRORC("property_setValue", errorLocation(L) << "Property '"
|
||||
<< prop->guiName() << "' does not accept input of type '"
|
||||
<< luaTypeToString(type) << "'. Requested type: '"
|
||||
<< luaTypeToString(prop->typeLua()) << "'");
|
||||
return 0;
|
||||
}
|
||||
else {
|
||||
prop->setLuaValue(L);
|
||||
//ensure properties are synced over parallel connection
|
||||
std::string value;
|
||||
prop->getStringValue(value);
|
||||
//OsEng.parallelConnection().scriptMessage(
|
||||
prop->fullyQualifiedIdentifier(), value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* \ingroup LuaScripts
|
||||
* setPropertyGroup(string, string, *):
|
||||
* Sets all properties identified by the URI (with potential wildcards) in the first
|
||||
* argument, AND contain a tag that matches that given in the second argument. The third
|
||||
* argument can be any type, but it has to match the type that the property(s) expect.
|
||||
*/
|
||||
|
||||
int property_setGroup(lua_State* L) {
|
||||
using ghoul::lua::errorLocation;
|
||||
using ghoul::lua::luaTypeToString;
|
||||
|
||||
int nArguments = lua_gettop(L);
|
||||
SCRIPT_CHECK_ARGUMENTS("property_setGroup", L, 3, nArguments);
|
||||
|
||||
std::string tag = luaL_checkstring(L, -2);
|
||||
std::string regex = luaL_checkstring(L, -3);
|
||||
|
||||
// Replace all wildcards * with the correct regex (.*)
|
||||
size_t startPos = regex.find("*");
|
||||
while (startPos != std::string::npos) {
|
||||
regex.replace(startPos, 1, "(.*)");
|
||||
startPos += 4;
|
||||
startPos = regex.find("*", startPos);
|
||||
}
|
||||
|
||||
applyRegularExpression(
|
||||
L,
|
||||
std::regex(regex/*, std::regex_constants::optimize*/),
|
||||
allProperties(),
|
||||
lua_type(L, -1),
|
||||
&tag
|
||||
);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* \ingroup LuaScripts
|
||||
* getPropertyValue(string):
|
||||
|
||||
Reference in New Issue
Block a user