Skip to content

Commit

Permalink
refactor: Reuse the opc_ua_client_copy variable
Browse files Browse the repository at this point in the history
in order to avoid the explicitly coupled copy variables.
  • Loading branch information
philipp-caspers committed Dec 6, 2024
1 parent 8661228 commit 9a3141e
Showing 1 changed file with 8 additions and 9 deletions.
17 changes: 8 additions & 9 deletions src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -37,12 +37,8 @@ fn main() -> Result<(), RclrsError> {
let Ok(_connection_result) = opc_ua_client.lock().unwrap().connect() else {
panic!("Connection could not be established, but is required.");
};
let opc_ua_client_copy_run = Arc::clone(&opc_ua_client);
let opc_ua_client_copy_services = Arc::clone(&opc_ua_client);
let opc_ua_client_copy_wrench = Arc::clone(&opc_ua_client);
let opc_ua_client_copy_stiffness = Arc::clone(&opc_ua_client);

register_opcua_subscriptions(ros_node_copy_register, opc_ua_client);
let opc_ua_client_copy = Arc::clone(&opc_ua_client);
register_opcua_subscriptions(ros_node_copy_register, opc_ua_client_copy);

let ros_services = Arc::new(ROSServices::new(opc_ua_client_copy_services));
let _enable_impedance_control = ros_node_copy_service
Expand All @@ -57,11 +53,12 @@ fn main() -> Result<(), RclrsError> {
move |request_header, request| rsc.disable_impedance_control(request_header, request)
});

let opc_ua_client_copy = Arc::clone(&opc_ua_client);
let _wrench_subscriber: Arc<Subscription<Wrench>> = ros_node.create_subscription(
"~/impedance_control/set_wrench",
QOS_PROFILE_DEFAULT,
move |msg: Wrench| {
opc_ua_client_copy_wrench.lock().unwrap().call_method(
opc_ua_client_copy.lock().unwrap().call_method(
NodeId::new(1, 100182),
NodeId::new(1, 100267),
Some(vec![
Expand All @@ -75,12 +72,13 @@ fn main() -> Result<(), RclrsError> {
);
},
)?;
let opc_ua_client_copy = Arc::clone(&opc_ua_client);
let _stiffness_subscriber: Arc<Subscription<voraus_interfaces::msg::CartesianStiffness>> =
ros_node.create_subscription(
"~/impedance_control/set_stiffness",
QOS_PROFILE_DEFAULT,
move |msg: voraus_interfaces::msg::CartesianStiffness| {
opc_ua_client_copy_stiffness.lock().unwrap().call_method(
opc_ua_client_copy.lock().unwrap().call_method(
NodeId::new(1, 100182),
NodeId::new(1, 100265),
Some(vec![
Expand All @@ -96,7 +94,8 @@ fn main() -> Result<(), RclrsError> {
)?;

info!("Starting OPC UA client");
let _session = opc_ua_client_copy_run.lock().unwrap().run_async();
let opc_ua_client_copy = Arc::clone(&opc_ua_client);
let _session = opc_ua_client_copy.lock().unwrap().run_async();
info!("Spinning ROS");
rclrs::spin(ros_node_copy_spin)
}

0 comments on commit 9a3141e

Please sign in to comment.