From ad44ecc0b8ccae5285c6015962717f8df4982355 Mon Sep 17 00:00:00 2001 From: methylDragon Date: Wed, 20 Jul 2022 16:13:04 -0700 Subject: [PATCH] Refine migration guide Signed-off-by: methylDragon --- garden/migration_from_ignition.md | 124 +++++++++++++++++------------- 1 file changed, 69 insertions(+), 55 deletions(-) diff --git a/garden/migration_from_ignition.md b/garden/migration_from_ignition.md index 85f6ff1871..ef38360f64 100644 --- a/garden/migration_from_ignition.md +++ b/garden/migration_from_ignition.md @@ -2,7 +2,8 @@ Hello Gazebo community!! -As you know, a couple months ago it was announced that [we’d be retiring the “Ignition” name in favor of “Gazebo”.](https://community.gazebosim.org/t/a-new-era-for-gazebo/1356) This migration guide will serve you help you execute the necessary changes in your own packages, and luckily it won’t be as troublesome as the move from Gazebo Classic! +In April 2022, it was announced that [we’d be retiring the “Ignition” name in favor of “Gazebo”.](https://community.gazebosim.org/t/a-new-era-for-gazebo/1356) +This migration guide will serve you help you execute the necessary changes in your own packages, and luckily it won’t be as troublesome as the move from Gazebo Classic! # Overview @@ -10,11 +11,11 @@ As you know, a couple months ago it was announced that [we’d be retiring the So what’s happening in practice? In summary: -- Whenever the name `Ignition` or `ign` is used, the Gazebo counterpart (`Gazebo` or `gz`) will be used instead, preserving case -- `ign-gazebo` / `Ignition Gazebo` will become `gz-sim` / `Gazebo Sim` -- The Ignition logo will also be replaced by the Gazebo logo. +- Whenever the name `Ignition` or `ign` is used, the Gazebo counterpart (`Gazebo` or `gz`) is used instead, preserving case +- `ign-gazebo` / `Ignition Gazebo` became `gz-sim` / `Gazebo Sim` +- The Ignition logo has been replaced by the Gazebo logo. -These changes will be made in: +These changes were made in: - Websites - GitHub organizations and repositories @@ -22,24 +23,42 @@ These changes will be made in: - UIs - Namespaces, command line tools, shared libraries, directories, APIs, files -This means that a bulk of the migration effort will involve intelligent find-and-replaces of filenames, directories, and source code. - +This means that a bulk of the migration effort on a user's part will involve intelligent find-and-replaces of filenames, directories, and source code. You may also look at the [tracking GitHub issue](https://github.com/gazebo-tooling/release-tools/issues/698) if you need to trace any changes made to support the migration in the core libraries. ## Tick-tocks and Hard-tocks -This section provides just an overview of the different changes made, for a more detailed listing of tick-tocks, see the `[MIGRATION.md](http://MIGRATION.md)` file in each of the individual core libraries’ repositories. Additionally the migration pointers in a later section of this migration guide should help you get your packages ready and working with Gazebo. - -Generally speaking, you should still be able to use either the Ignition counterpart or Gazebo counterpart for **most things** if you are using Garden, due to explicit tick-tocking logic written in the stack. Just note that using the Ignition counterpart will generally cause deprecation warnings to be emitted. +This section provides just an overview of the different changes made, for a more detailed listing of tick-tocks, see the migration file in each of the individual core libraries’ repositories: + +- [gz-cmake](https://github.com/gazebosim/gz-cmake/blob/main/Migration.md) +- [gz-common](https://github.com/gazebosim/gz-common/blob/main/Migration.md) +- [gz-fuel-tools](https://github.com/gazebosim/gz-fuel-tools/blob/main/Migration.md) +- [gz-gui](https://github.com/gazebosim/gz-gui/blob/main/Migration.md) +- [gz-launch](https://github.com/gazebosim/gz-launch/blob/main/Migration.md) +- [gz-math](https://github.com/gazebosim/gz-math/blob/main/Migration.md) +- [gz-msgs](https://github.com/gazebosim/gz-msgs/blob/main/Migration.md) +- [gz-physics](https://github.com/gazebosim/gz-physics/blob/main/Migration.md) +- [gz-plugin](https://github.com/gazebosim/gz-plugin/blob/main/Migration.md) +- [gz-rendering](https://github.com/gazebosim/gz-rendering/blob/main/Migration.md) +- [gz-sensors](https://github.com/gazebosim/gz-sensors/blob/main/Migration.md) +- [gz-sim](https://github.com/gazebosim/gz-sim/blob/main/Migration.md) +- [gz-tools](https://github.com/gazebosim/gz-tools/blob/main/Migration.md) +- [gz-transport](https://github.com/gazebosim/gz-transport/blob/main/Migration.md) +- [gz-utils](https://github.com/gazebosim/gz-utils/blob/main/Migration.md) +- [sdformat](https://github.com/gazebosim/sdformat/blob/main/Migration.md) + +Additionally the migration pointers in a later section of this migration guide should help you get your packages ready and working with Gazebo. + +Generally speaking, you should still be able to use either the Ignition counterpart or Gazebo counterpart for **most things** if you are using Garden, due to explicit tick-tocking logic written in the stack. +Just note that using the Ignition counterpart will generally cause deprecation warnings to be emitted. ### Tick-tocks -Tick-tocks for the following are implemented, though not all of them will emit deprecation warnings. These tick-tocks are implemented either as aliases, or otherwise have some sort of redirection mechanism (e.g. symlinks, directory retargets, string replacements in source) to target the Gazebo counterpart instead. +Tick-tocks for the following are implemented, though not all of them will emit deprecation warnings. +These tick-tocks are implemented either as aliases, or otherwise have some sort of redirection mechanism (e.g. symlinks, directory retargets, string replacements in source) to target the Gazebo counterpart instead. Also, in the source code, most of these tick-tocks will have an associated comment calling out that they are deprecated, or have a `GZ_DEPRECATED()` macro call. -
-Tick-tocks **Namespaces** @@ -59,7 +78,9 @@ Also, in the source code, most of these tick-tocks will have an associated comme - Plugins - e.g. `ignition::gazebo::systems::LiftDrag` → `gz::sim::systems::LiftDrag` - Shared libraries - - e.g. `libignition-gazebo-buoyancy-engine-system.so` → `gz-sim-buoyancy-engine-system` + - e.g. `libignition-gazebo-buoyancy-engine-system.so` → `libgz-sim-buoyancy-engine-system.so` + - You may remove the `lib` and `.so` prefix and suffixes! + - e.g. `libignition-gazebo-buoyancy-engine-system.so` → `gz-sim-buoyancy-engine-system` - C++ Macros in public headers - e.g. `IGN_PARTITION` → `GZ_PARTITION` @@ -96,15 +117,14 @@ Also, in the source code, most of these tick-tocks will have an associated comme - e.g. [ignitionrobotics.org](http://ignitionrobotics.org) → [gazebosim.org](http://gazebosim.org) - SDF and launch tags - e.g. `` → `` +- SDF namespaces + - e.g. `ignition:type` -
### Hard-tocks -There are some exceptions that have been hard-tocked instead, meaning that you **MUST** use the Gazebo counterpart. Using the Ignition counterpart will likely cause compilation or something else to break (unless it’s just a documentation change.) - -
-Hard-tocks +There are some exceptions that have been hard-tocked instead, meaning that you **MUST** use the Gazebo counterpart. +Using the Ignition counterpart will likely cause compilation or something else to break (unless it’s just a documentation change.) **Namespaces** @@ -113,14 +133,8 @@ There are some exceptions that have been hard-tocked instead, meaning that you * **Source** -- C++ Macros in private headers (typically something in a `detail/` directory) - - e.g. `DETAIL_IGNITION_UTILS_WARN_RESUME` → `DETAIL_GZ_UTILS_WARN_RESUME` -- Class names, members, functions, and variables in private headers, or function-local scope - - e.g. `kIgnAuthDomain` → `kGzAuthDomain` - Install space - e.g. `install/share/ignition` → `install/share/gz` -- Header guards (where appropriate) - - e.g. `IGNITION_COMMON_MATERIAL_HH_` → `GZ_COMMON_MATERIAL_HH_` **CMake and Packaging** @@ -137,6 +151,7 @@ There are some exceptions that have been hard-tocked instead, meaning that you * - e.g. `sim.ign` → `sim.gzlaunch`, ` - ## Untocks A very small selection of things have not been migrated, mostly for backwards compatibility reasons (e.g. supporting Fortress.) @@ -185,7 +193,8 @@ What might help greatly is to: - Pay attention to compilation warnings/errors, which usually (but not always) give suggestions for what to replace! - If in doubt, trace the change to changes listed in the [tracking issue](https://github.com/gazebo-tooling/release-tools/issues/698) -Also, if you are building the Gazebo stack from source, you should do a clean, fresh rebuild and install. Delete your `build` and `install` directories, and run the build with `--merge-install`. +Also, if you are building the Gazebo stack from source, you should do a clean, fresh rebuild and install. +Delete your `build` and `install` directories, and run the build with `--merge-install`. ### Gotchas @@ -209,6 +218,9 @@ However, here are a lot of edge cases that make it difficult to create a script Additionally, take note of the following behaviors: - Config files are not overwritten, so you might need to delete or manually migrate Ignition-counterpart references in your config files to get them to point to the appropriate Gazebo-counterpart locations + - For example, a `sim/7/server.config` file could be using an `ignition::gazebo::systems::Physics` plugin. + This config file cannot get overwritten unless explicitly deleted, so you might encounter deprecation warnings because that reference has not yet been migrated. + - Because the install spaces have changed, if you have hard-coded locations involving `ignition`, you might need to migrate them to `gz` ## Migration Steps @@ -314,8 +326,8 @@ Replace: