Skip to content

Releases: viamrobotics/viam-cpp-sdk

releases/v0.0.21

21 Jan 16:51
e14af53
Compare
Choose a tag to compare

What's Changed

New Contributors

Full Changelog: releases/v0.0.20...releases/v0.0.21

releases/v0.0.20

13 Jan 19:37
951b7e4
Compare
Choose a tag to compare

What's Changed

Full Changelog: releases/v0.0.19...releases/v0.0.20

releases/v0.0.19

08 Jan 21:02
ddbf852
Compare
Choose a tag to compare

What's Changed

Full Changelog: releases/v0.0.18...releases/v0.0.19

releases/v0.0.18

16 Dec 18:35
f845acf
Compare
Choose a tag to compare

What's Changed

  • RSDK-3589 audit nav service docstrings by @raybjork in #334
  • RSDK-6574: Fix use of time_point by @lia-viam in #335
  • RSDK-9337: Introduce proto API bridge and insulate various geometry and math types from API by @lia-viam in #332
  • RSDK-9466 - Remove robot status endpoint from SDK by @cheukt in #338
  • Version bump by @lia-viam in #340

New proto API bridge approach

As part of an ongoing project to insulate google protobuf and the Viam API from the ABI and public API of the Viam SDK, we have introduced a new approach for writing and using to_proto and from_proto conversions. See https://github.com/viamrobotics/viam-cpp-sdk/blob/main/src/viam/sdk/common/pose.hpp for a worked example.

You have to

  • include viam/sdk/common/proto_convert.hpp
  • forward declare the relevant API types
  • specialize the struct callables proto_convert_details::to_proto and proto_convert_details::from_proto to implement API to SDK interchange.

Note that the detail structs only refer to API types by pointer to a forward-declared class, so there is no ABI dependency on the Viam API types.

The proto_convert.hpp header also provides the callables viam::sdk::v2::to_proto, which returns an API type by value, and viam::sdk::v2::from_proto which takes an API type by reference to const. In practice if you need an escape hatch to work with API types directly, you should include the relevant viam/api/... headers and use the to_proto and from_proto callables rather than the struct templates. The v2 namespace will be removed when this migration is complete and none of the old conversion functions remain.

Full Changelog: releases/v0.0.17...releases/v0.0.18

releases/v0.0.17

02 Dec 18:03
a63b7a0
Compare
Choose a tag to compare

What's Changed

  • RSDK-6634 - remove resource proto conversions from public headers by @stuqdog in #328
  • use docker base image in CI by @abe-winter in #327
  • RSDK-9299 - refactor get_resource_name to be a non-proto method by @stuqdog in #329
  • Automated Protos Update by @github-actions in #321
  • remove null opt derefs by @lia-viam in #330
  • bump to 0.0.17 by @stuqdog in #333

Full Changelog: releases/v0.0.16...releases/v0.0.17

releases/v0.0.16

18 Nov 21:54
7c8487c
Compare
Choose a tag to compare

What's Changed

New Contributors

Full Changelog: releases/v0.0.15...releases/v0.0.16

releases/v0.0.15

11 Nov 19:00
7851b44
Compare
Choose a tag to compare

What's Changed

Full Changelog: releases/v0.0.14...releases/v0.0.15

releases/v0.0.14

04 Nov 19:59
69e1758
Compare
Choose a tag to compare

What's Changed

  • Automated Protos Update by @github-actions in #308
  • Automated Protos Update by @github-actions in #311
  • RSDK-9077: Docker containers for module development by @lia-viam in #310
  • Automated Protos Update by @github-actions in #313
  • Bump version to 0.0.14 by @jckras in #314
  • Update README.md for module dev Docker by @lia-viam in #315

Full Changelog: releases/v0.0.13...releases/v0.0.14

releases/v0.0.13

21 Oct 17:58
d5000dd
Compare
Choose a tag to compare

What's Changed

  • Automated Protos Update by @github-actions in #305
  • RSDK-8822: Whole archive linking by @lia-viam in #306
    • module example code is no longer broken on static builds
    • no further guarantees are made and this is not extensively tested in CI/releases nor will it be part of release archives going forward
  • version bump by @lia-viam in #307

Full Changelog: releases/v0.0.12...releases/v0.0.13

releases/v0.0.12

09 Oct 16:21
4a06676
Compare
Choose a tag to compare

Breaking change

Details and migration guide

Removes ProtoType and AttributeMap , replacing them with ProtoValue and ProtoStruct. This affects the parameter used in component doCommand calls, as well as the extra parameter included in all component methods.

For most use cases, the change will look like this:
90246f0#diff-becf92545c215777e3fe43c17c0f4196f96bb623d3aa8feee82d1357e7c1738fL11
Namely,

  • include path is now #include <viam/sdk/common/proto_value.hpp>
  • parameter is now const ProtoStruct&

The majority of code changes will be able to just do a Replace-In-Files for the two changes above

If your component or module code actually used these types directly, the changes will look something like this:
90246f0#diff-e07f0fbd2e62063a2446d7ab99d80d9a5c50e9a94649f64b9d5caf5c67b3a345
Namely, ProtoValue is now has value semantics rather than pointer semantics and std::shared_ptr , and ProtoStruct is a map of std::string to ProtoType. You can construct a ProtoValue like a normal C++ class as you would, eg, a variant or JSON type:

ProtoValue num_val{5.6};
ProtoValue str_val{"meow"};

// ProtoList is a vector of ProtoValue:
ProtoList my_list{{ProtoValue{true}, ProtoValue{"meow"}, ProtoValue{6.0}}};

// ProtoStruct is a map:
ProtoStruct my_map{
    {"cat", "meow"},
    {"dog", "woof"},
    {"number", 1.234},
    {"list", my_list}, //copies my_list
};

ProtoValue and related types now have value semantics rather than smart pointer semantics. This means, eg
map lookup operations will now use a . rather than ->, and types will behave like arithmetic types or standard library containers with respect to copying, moving, etc

Please see the proto_value.hpp header for detailed documentation and API of other methods, including

  • to_proto to convert to google::protobuf classes, and ProtoValue::from_proto to construct from google::protobuf classes
  • is_a<T> and get<T>/get_unchecked<T> for stored element inpection
  • ...or generate the doxygen documentation if you like!

To find affected code, you can grep or ag or GitHub code search for ProtoType and AttributeMap.

Additional changes

  • RSDK-8828 Remove integer type from ProtoValue by @lia-viam in #292
  • RSDK-8826: Conan builds in CI by @lia-viam in #296
  • Fix debian builds in CI by @lia-viam in #297
  • Automated Protos Update by @github-actions in #298
  • Automated Protos Update by @github-actions in #300
  • Use proto value get in example code by @lia-viam in #303
  • RSDK-6170 - add debug log support by @stuqdog in #299
  • Automated Protos Update by @github-actions in #302
  • Version bump by @lia-viam in #304

Full Changelog: releases/v0.0.11...releases/v0.0.12