Skip to content

Commit

Permalink
Adjust profilset option parsing logic, part deux
Browse files Browse the repository at this point in the history
  • Loading branch information
navv1234 committed Nov 4, 2019
1 parent 44b8623 commit 9307fe2
Showing 1 changed file with 51 additions and 4 deletions.
55 changes: 51 additions & 4 deletions engine/sim/sc_profileset.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,22 @@

namespace
{
// Options that allow "appending" or "mapping" cannot really be overridden in the current
// climate. Note that this does not take into account class module options, and there's no
// easy way to do that, short of iterating over defined option parsers every single time.
// The simc option system really needs the "scoping" system fleshed out to understand
// where a specific option (i.e., a name, value tuple) is defined.
//
// Also, any "function" option is going to be undefined behavior whether it can be merged
// or not, but typically the function option semantics work as such that the next parsing
// of the same option will override whatever is being done.
bool overridable_option( const option_tuple_t& tuple )
{
return tuple.name.rfind( "actions", 0 ) == std::string::npos &&
tuple.name.rfind( "items", 0 ) == std::string::npos &&
tuple.name.rfind( "raid_events", 0 ) == std::string::npos;
}

std::string format_time( double seconds, bool milliseconds = true )
{
std::stringstream s;
Expand Down Expand Up @@ -309,18 +325,49 @@ sim_control_t* profilesets_t::create_sim_options( const sim_control_t*
}

auto options_copy = new sim_control_t( *original );
std::vector<option_tuple_t> filtered_opts;

// Filter profileset options so that any option overridable in the base options is
// overriden, and the rest are inserted at the correct position
range::for_each( new_options.options, [&filtered_opts, options_copy]( const option_tuple_t& t ) {
if ( !overridable_option( t ) )
{
filtered_opts.push_back( t );
}
// Option that can be overridden in the copy, check if it exists in the base options
// set and replace if so
else
{
// Note, replace the last occurrence of the option to ensure the profileset option
// will be set
auto it = std::find_if( options_copy->options.rbegin(), options_copy->options.rend(),
[&t]( const option_tuple_t& orig_t ) {
return orig_t.name == t.name;
} );

if ( it != options_copy->options.rend() )
{
it->value = t.value;
}
else
{
filtered_opts.push_back( t );
}
}
} );

// No enemy option defined, insert profileset to the end of the original options
// No enemy option defined, insert filtered profileset options to the end of the
// original options
if ( m_insert_index == 0 )
{
options_copy -> options.insert( options_copy -> options.end(),
new_options.options.begin(), new_options.options.end() );
filtered_opts.begin(), filtered_opts.end() );
}
// Enemy option found, insert profileset options just before the enemy option
// Enemy option found, insert filtered profileset options just before the enemy option
else
{
options_copy -> options.insert( options_copy -> options.begin() + m_insert_index,
new_options.options.begin(), new_options.options.end() );
filtered_opts.begin(), filtered_opts.end() );
}

return options_copy;
Expand Down

0 comments on commit 9307fe2

Please sign in to comment.