summaryrefslogtreecommitdiff
path: root/common/rawaccel-userspace.hpp
diff options
context:
space:
mode:
authora1xd <[email protected]>2020-07-30 17:07:35 -0400
committera1xd <[email protected]>2020-07-30 17:07:35 -0400
commite8417a29fb2153ea035a757f36bfa300cf8b480d (patch)
tree802905bbf262196678e140463150e66d0a674b01 /common/rawaccel-userspace.hpp
parentMerge remote-tracking branch 'downstream/Inheritance' into st-refactor (diff)
downloadrawaccel-e8417a29fb2153ea035a757f36bfa300cf8b480d.tar.xz
rawaccel-e8417a29fb2153ea035a757f36bfa300cf8b480d.zip
add tweaks for st-refactor
Diffstat (limited to 'common/rawaccel-userspace.hpp')
-rw-r--r--common/rawaccel-userspace.hpp53
1 files changed, 28 insertions, 25 deletions
diff --git a/common/rawaccel-userspace.hpp b/common/rawaccel-userspace.hpp
index 3e8886f..49c0fcd 100644
--- a/common/rawaccel-userspace.hpp
+++ b/common/rawaccel-userspace.hpp
@@ -4,6 +4,7 @@
#include "external/clipp.h"
+#include <accel-error.hpp>
#include "rawaccel.hpp"
namespace rawaccel {
@@ -12,12 +13,14 @@ inline constexpr int SYSTEM_ERROR = -1;
inline constexpr int PARSE_ERROR = 1;
inline constexpr int INVALID_ARGUMENT = 2;
-void error(const char* s) {
- throw std::domain_error(s);
+template<typename Accel, typename StrFirst, typename... StrRest>
+clipp::parameter make_accel_cmd(modifier_args& args, StrFirst&& first_flag, StrRest&&... rest) {
+ return clipp::command(first_flag, rest...)
+ .set(args.acc_fn_args.accel_mode, accel_impl_t::id<Accel>);
}
mouse_modifier parse(int argc, char** argv) {
- modifier_args modifier_args{};
+ modifier_args args{};
auto make_opt_vec = [](vec2d& v, auto first_flag, auto... rest) {
return clipp::option(first_flag, rest...) & (
@@ -38,64 +41,64 @@ mouse_modifier parse(int argc, char** argv) {
};
// default options
- auto opt_sens = "sensitivity (default = 1)" % make_opt_vec(modifier_args.sens, "sens");
+ auto opt_sens = "sensitivity (default = 1)" % make_opt_vec(args.sens, "sens");
auto opt_rot = "counter-clockwise rotation (default = 0)" % (
clipp::option("rotate") &
- clipp::number("degrees", modifier_args.degrees)
+ clipp::number("degrees", args.degrees)
);
// mode-independent accel options
auto opt_weight = "accel multiplier (default = 1)" %
- make_opt_vec(modifier_args.acc_fn_args.weight, "weight");
+ make_opt_vec(args.acc_fn_args.weight, "weight");
auto opt_offset = "speed (dots/ms) where accel kicks in (default = 0)" % (
- clipp::option("offset") & clipp::number("speed", modifier_args.acc_fn_args.acc_args.offset)
+ clipp::option("offset") & clipp::number("speed", args.acc_fn_args.acc_args.offset)
);
auto opt_cap = "accel scale cap (default = 9)" %
- make_opt_vec(modifier_args.acc_fn_args.cap, "cap");
+ make_opt_vec(args.acc_fn_args.cap, "cap");
auto opt_tmin = "minimum time between polls (default = 0.4)" % (
clipp::option("tmin") &
- clipp::number("ms", modifier_args.acc_fn_args.acc_args.time_min)
+ clipp::number("ms", args.acc_fn_args.time_min)
);
- auto accel_var = (clipp::required("accel") & clipp::number("num", modifier_args.acc_fn_args.acc_args.accel)) % "ramp rate";
- auto limit_var = (clipp::required("limit") & clipp::number("scale", modifier_args.acc_fn_args.acc_args.lim_exp)) % "limit";
+ auto accel_var = (clipp::required("accel") & clipp::number("num", args.acc_fn_args.acc_args.accel)) % "ramp rate";
+ auto limit_var = (clipp::required("limit") & clipp::number("scale", args.acc_fn_args.acc_args.limit)) % "limit";
+ auto exp_var = (clipp::required("exponent") & clipp::number("num", args.acc_fn_args.acc_args.exponent)) % "exponent";
// modes
- auto noaccel_mode = "no-accel mode" % (
- clipp::command("off", "noaccel").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_noaccel>)
- );
+ auto noaccel_mode = "no-accel mode" % make_accel_cmd<accel_noaccel>(args, "off", "noaccel");
+
auto lin_mode = "linear accel mode:" % (
- clipp::command("linear").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_linear>),
+ make_accel_cmd<accel_linear>(args, "linear"),
accel_var
);
auto classic_mode = "classic accel mode:" % (
- clipp::command("classic").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_classic>),
+ make_accel_cmd<accel_classic>(args, "classic"),
accel_var,
- (clipp::required("exponent") & clipp::number("num", modifier_args.acc_fn_args.acc_args.lim_exp)) % "exponent"
+ exp_var
);
auto nat_mode = "natural accel mode:" % (
- clipp::command("natural").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_natural>),
+ make_accel_cmd<accel_natural>(args, "natural"),
accel_var,
limit_var
);
auto log_mode = "logarithmic accel mode:" % (
- clipp::command("logarithmic").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_logarithmic>),
+ make_accel_cmd<accel_logarithmic>(args, "logarithmic"),
accel_var
);
auto sig_mode = "sigmoid accel mode:" % (
- clipp::command("sigmoid").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_sigmoid>),
+ make_accel_cmd<accel_sigmoid>(args, "sigmoid"),
accel_var,
limit_var,
- (clipp::required("midpoint") & clipp::number("speed", modifier_args.acc_fn_args.acc_args.midpoint)) % "midpoint"
+ (clipp::required("midpoint") & clipp::number("speed", args.acc_fn_args.acc_args.midpoint)) % "midpoint"
);
auto pow_mode = "power accel mode:" % (
- clipp::command("power").set(modifier_args.acc_fn_args.accel_mode, accel_implementation_t::id<accel_power>) >> [&] { modifier_args.acc_fn_args.acc_args.accel = 1; },
- (clipp::required("exponent") & clipp::number("num", modifier_args.acc_fn_args.acc_args.lim_exp)) % "exponent",
- (clipp::option("scale") & clipp::number("num", modifier_args.acc_fn_args.acc_args.accel)) % "scale factor"
+ make_accel_cmd<accel_power>(args, "power"),
+ exp_var,
+ (clipp::option("scale") & clipp::number("num", args.acc_fn_args.acc_args.power_scale)) % "scale factor"
);
auto accel_mode_exclusive = (lin_mode | classic_mode | nat_mode | log_mode | sig_mode | pow_mode);
@@ -119,7 +122,7 @@ mouse_modifier parse(int argc, char** argv) {
std::exit(0);
}
- return mouse_modifier(modifier_args);
+ return mouse_modifier(args);
}
} // rawaccel