mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-25 01:41:43 +00:00
54 lines
1.8 KiB
C++
54 lines
1.8 KiB
C++
// Copyright (c) FIRST and other WPILib contributors.
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
// the WPILib BSD license file in the root directory of this project.
|
|
|
|
#include "wpi/math/spline/proto/QuinticHermiteSplineProto.hpp"
|
|
|
|
#include "wpi/util/protobuf/ProtobufCallbacks.hpp"
|
|
|
|
#include "wpimath/protobuf/spline.npb.h"
|
|
|
|
std::optional<frc::QuinticHermiteSpline>
|
|
wpi::Protobuf<frc::QuinticHermiteSpline>::Unpack(InputStream& stream) {
|
|
wpi::WpiArrayUnpackCallback<double, 3> xInitial;
|
|
wpi::WpiArrayUnpackCallback<double, 3> xFinal;
|
|
wpi::WpiArrayUnpackCallback<double, 3> yInitial;
|
|
wpi::WpiArrayUnpackCallback<double, 3> yFinal;
|
|
wpi_proto_ProtobufQuinticHermiteSpline msg{
|
|
.x_initial = xInitial.Callback(),
|
|
.x_final = xFinal.Callback(),
|
|
.y_initial = yInitial.Callback(),
|
|
.y_final = yFinal.Callback(),
|
|
};
|
|
if (!stream.Decode(msg)) {
|
|
return {};
|
|
}
|
|
|
|
if (!xInitial.IsFull() || !yInitial.IsFull() || !xFinal.IsFull() ||
|
|
!yFinal.IsFull()) {
|
|
return {};
|
|
}
|
|
|
|
return frc::QuinticHermiteSpline{
|
|
xInitial.Array(),
|
|
xFinal.Array(),
|
|
yInitial.Array(),
|
|
yFinal.Array(),
|
|
};
|
|
}
|
|
|
|
bool wpi::Protobuf<frc::QuinticHermiteSpline>::Pack(
|
|
OutputStream& stream, const frc::QuinticHermiteSpline& value) {
|
|
wpi::PackCallback<double> xInitial{value.GetInitialControlVector().x};
|
|
wpi::PackCallback<double> xFinal{value.GetFinalControlVector().x};
|
|
wpi::PackCallback<double> yInitial{value.GetInitialControlVector().y};
|
|
wpi::PackCallback<double> yFinal{value.GetFinalControlVector().y};
|
|
wpi_proto_ProtobufQuinticHermiteSpline msg{
|
|
.x_initial = xInitial.Callback(),
|
|
.x_final = xFinal.Callback(),
|
|
.y_initial = yInitial.Callback(),
|
|
.y_final = yFinal.Callback(),
|
|
};
|
|
return stream.Encode(msg);
|
|
}
|