Skip to content

Commit

Permalink
i#3129 raw2trace perf: move ctors should be public
Browse files Browse the repository at this point in the history
The move ctors for trace_converter_t and module_mapper_t should be public.

Issue: #3129
  • Loading branch information
mtrofin committed Sep 3, 2018
1 parent 9f01dbc commit cb3f763
Showing 1 changed file with 19 additions and 18 deletions.
37 changes: 19 additions & 18 deletions clients/drcachesim/tracer/raw2trace.h
Original file line number Diff line number Diff line change
Expand Up @@ -292,6 +292,16 @@ class module_mapper_t final {
*/
~module_mapper_t();

// since the dtor frees resources, disable copy constructor but allow
// move semantics
module_mapper_t(const module_mapper_t &) = delete;
module_mapper_t &
operator=(const module_mapper_t &) = delete;
// VS2013 does not support defaulted move ctors/assign operators
#ifndef WINDOWS
module_mapper_t(module_mapper_t &&) = default;
#endif

private:
// We store this in drmodtrack_info_t.custom to combine our binary contents
// data with any user-added module data from drmemtrace_custom_module_data.
Expand Down Expand Up @@ -334,16 +344,6 @@ class module_mapper_t final {

uint verbosity = 0;
std::string last_error;

// since the dtor frees resources, disable copy constructor but allow
// move semantics
module_mapper_t(const module_mapper_t &) = delete;
module_mapper_t &
operator=(const module_mapper_t &) = delete;
// VS2013 does not support defaulted move ctors/assign operators
#ifndef WINDOWS
module_mapper_t(module_mapper_t &&) = default;
#endif
};

/**
Expand Down Expand Up @@ -426,6 +426,15 @@ template <typename T> class trace_converter_t {
if (!(val)) \
return msg; \
} while (0)
public:
trace_converter_t(const trace_converter_t &) = delete;
trace_converter_t &
operator=(const trace_converter_t &) = delete;
#ifndef WINDOWS
trace_converter_t(trace_converter_t &&) = default;
trace_converter_t &
operator=(trace_converter_t &&) = default;
#endif

protected:
/**
Expand Down Expand Up @@ -790,14 +799,6 @@ template <typename T> class trace_converter_t {
// icache entry does not need to be considered a memref PC entry as well.
bool instrs_are_separate = false;

trace_converter_t(const trace_converter_t &) = delete;
trace_converter_t &
operator=(const trace_converter_t &) = delete;
#ifndef WINDOWS
trace_converter_t(trace_converter_t &&) = default;
trace_converter_t &
operator=(trace_converter_t &&) = default;
#endif
#undef DR_CHECK
};

Expand Down

0 comments on commit cb3f763

Please sign in to comment.