Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Forward compatibility with YARP 3.0 #65

Closed
PeterBowman opened this issue Jun 14, 2018 · 11 comments
Closed

Forward compatibility with YARP 3.0 #65

PeterBowman opened this issue Jun 14, 2018 · 11 comments

Comments

@PeterBowman
Copy link
Member

PeterBowman commented Jun 14, 2018

YARP 3.0 is finally out! And back compat is broken with YARP 2.x code. There are two sides to this coin:

The former is causing Travis build failures since the past few days (said line was added shortly before the final release). I'm not prone to blindly remove the version specifier to find_package() (see #54 for background), but this could be easily solved by arranging some convenient checks in the following manner:

find_package(YARP 3.0 QUIET COMPONENTS ...)
# in the future, remove this check and use REQUIRED above
if(NOT YARP_FOUND)
    find_package(YARP 2.3.70 REQUIRED)
endif()

Alternatively:

find_package(YARP QUIET)
if(YARP_VERSION_SHORT VERSION_LESS 2.3.70)
    message(FATAL_ERROR "You need YARP 2.3.70+, but only ${YARP_VERSION_SHORT} was found!")
endif()

See also #54 (comment) regarding YARP components and #18 regarding optional project components.

Migration is a gradual step. Once fixed, CI builds will test our code against YARP master and devel (to keep up with YARP's development, see #7), both currently at 3.0+, but we'll surely keep using YARP 2.3.x in our PCs. My second proposal covers the improvement of .travis.yml files across the organization in order to add an additional job for said legacy YARP version. Thus, we'll make sure both the previous and current release cycles of YARP are compatible with our code. In that vein, I found this reference page useful since conditional jobs shall be run: two per pr/push action (YARP 2.3.72.1 and YARP master), only one for cron-enabled builds (YARP devel, like usual). Some YAML code improvements laid out at #48 might come in handy here.

@PeterBowman
Copy link
Member Author

Marking as blocked, I'd close #54 first.

@PeterBowman
Copy link
Member Author

Forgot to add: YARP 3.0 requires CMake 3.5. Bump it in non-superbuild repos, teo-main and the like have been already updated in order to support stricter requirements in orchestrated subprojects.

@PeterBowman
Copy link
Member Author

As spoken with @jgvictores, in the future, we'd like to create one tag per repo prior to requiring YARP 3.0 everywhere. The goal is to keep track of the last point in the commit history that supported YARP 2.x.

@PeterBowman PeterBowman self-assigned this Jun 15, 2018
PeterBowman added a commit to roboticslab-uc3m/kinematics-dynamics that referenced this issue Jun 15, 2018
PeterBowman added a commit to roboticslab-uc3m/yarp-devices that referenced this issue Jun 16, 2018
PeterBowman added a commit to roboticslab-uc3m/openrave-yarp-plugins that referenced this issue Jun 16, 2018
PeterBowman added a commit to roboticslab-uc3m/speech that referenced this issue Jun 17, 2018
PeterBowman added a commit to roboticslab-uc3m/vision that referenced this issue Jun 17, 2018
PeterBowman added a commit to roboticslab-uc3m/tools that referenced this issue Jun 18, 2018
PeterBowman added a commit to roboticslab-uc3m/asibot-hmi that referenced this issue Jun 18, 2018
PeterBowman added a commit to roboticslab-uc3m/project-generator that referenced this issue Jun 20, 2018
@PeterBowman PeterBowman removed blocked Do not focus on this issue until blocking issue is closed announcement labels Jun 22, 2018
PeterBowman added a commit to roboticslab-uc3m/kinematics-dynamics that referenced this issue Jun 23, 2018
@PeterBowman
Copy link
Member Author

My second proposal covers the improvement of .travis.yml files across the organization in order to add an additional job for said legacy YARP version.

See roboticslab-uc3m/kinematics-dynamics@d52434c. Testing our new policy: run a job for every supported minor YARP release (currently: v2.3.70, v2.3.72), which in total accounts for six jobs considering gcc/clang and YARP's master branch, on every push action (example). In addition, cron builds would add another couple of jobs against YARP's devel branch, thus totalling eight jobs (example). Also, we pull YCM's master branch in the former build set, and YCM's devel in the latter.

@PeterBowman PeterBowman added the blocked Do not focus on this issue until blocking issue is closed label Jun 24, 2018
@PeterBowman
Copy link
Member Author

I've come up with a possibly elegant solution at #48 (comment). I mark this therefore as blocked because of build times having considerably increased as a consequence of adding new jobs. Let's solve the dependency caching issue first.

@PeterBowman
Copy link
Member Author

Support for optional components has been approved and merged into current YARP master with robotology/yarp#1741. YARP v3.0.1 is expected to come out soon, hence I'd like to review all find_package(YARP 3.0 ...) calls again.

@PeterBowman
Copy link
Member Author

PeterBowman commented Jul 2, 2018

Keep robotology/yarp#1778 in mind while updating the speech project.

@PeterBowman
Copy link
Member Author

PeterBowman commented Jul 8, 2018

Since robotology/yarp#1778, looking for YCM before YARP leads to CI builds errors in superbuild-like repos that orchestrate subprojects in which a feature_summary(FATAL_ON_MISSING_REQUIRED_PACKAGES WHAT ...) call is present (example, FeatureSummary docs (CMake 3.9)). Rationale (sample app):

# Registers and sets a _CMAKE_YARP_TYPE=REQUIRED global property.
find_package(YARP REQUIRED)
message(STATUS "YARP_FOUND: ${YARP_FOUND}") # 1 (found)

# Let's assume we didn't get there yet. Note the QUIET OPTION.
find_package(YARP 99 QUIET)
message(STATUS "YARP_FOUND: ${YARP_FOUND}") # 0 (not found)

include(FeatureSummary)
feature_summary(FATAL_ON_MISSING_REQUIRED_PACKAGES WHAT ALL)

This snippet would throw an error. YARP_FOUND is set to FALSE in the subsequent find_package() call. However, this package is still regarded as a REQUIRED one, hence the fatal outcome of the feature_summary() command.

There is plenty of room for improvements, but I'll start with removing the FATAL_ON_MISSING_REQUIRED_PACKAGES option. Any prior find_package() command would throw anyway.

Edit: forgot to add that the alternative (and counterintuitive) solution is fairly simple, just issue find_package(YCM REQUIRED) after find_package(YARP REQUIRED).

Edit2: this error showed up because superbuild repos fetch the master branch of YCM, whereas latest YARP master requests YCM devel (see linked PR).

PeterBowman added a commit to roboticslab-uc3m/project-generator that referenced this issue Jul 8, 2018
@PeterBowman PeterBowman removed the blocked Do not focus on this issue until blocking issue is closed label Jul 15, 2018
@PeterBowman
Copy link
Member Author

PeterBowman commented Jul 15, 2018

For the time being, I'm not going to use YARP 3.x components. This feature will render no benefits in our projects and would require extra care:

  • By default, YARP_OS, YARP_dev and YARP_sig are loaded. Also, YARP_math if Eigen3 is found on system when building YARP.
  • Any component explicitly passed to find_package() overrides those defaults, that is, find_package(YARP REQUIRED OPTIONAL_COMPONENTS math) would not load YARP_OS et al.
  • The previous point means that we need to use something like this almost everywhere (not accounting for math if not needed, obviously):
    find_package(YARP 3.0 REQUIRED COMPONENTS OS dev sig
                                   OPTIONAL_COMPONENTS math)
  • I'm not prone to leave any of the first three defaults out of the list. It might lead to obscure errors for unaware developers that want to create new tools.
  • Although deprecated, YARP_HAS_MATH_LIB is still alive and may be used in YARP 3.x to test for availability of the math component. The modern replacement is YARP_math_FOUND. It's not mandatory to pass OPTIONAL_COMPONENTS math, but YARP 3.x won't ever look for it if other (OPTIONAL)_COMPONENTS are requested.
  • Dependent projects may not support all required YARP components of a RL dependency. Prior to roboticslab-uc3m/kinematics-dynamics@273ac97, asibot-hmi builds were failing since kin-dyn explicitly requested YARP_math while the Travis build environment for the former didn't even install Eigen3.

Again: for now, I'm happy with current component defaults and no repo of ours require anything more convolute than that. Let's adopt the following sequence (already used throughout most repos) and close this issue:

# Hard dependencies.
find_package(YCM 0.8 REQUIRED)

# https://github.com/roboticslab-uc3m/questions-and-answers/issues/65
find_package(YARP 3.0 QUIET)
if(NOT YARP_FOUND)
    find_package(YARP 2.3.70 REQUIRED)
endif()

find_package(COLOR_DEBUG REQUIRED)

Edit:

Keep robotology/yarp#1778 in mind while updating the speech project.

I forgot about this. YARP 3.x will happily treat idl_tools in the default components, but show deprecations warnings if the CMake macros it sets are used. Looks like explicit components are preferred, at least in this case. I'd defer this matter until a) deprecations become build failures, or b) we enforce YARP 3.0 or later. Then, we'll start resolving deprecations one by one.

PeterBowman added a commit to roboticslab-uc3m/kinematics-dynamics that referenced this issue Jul 15, 2018
PeterBowman added a commit to roboticslab-uc3m/openrave-yarp-plugins that referenced this issue Jul 15, 2018
PeterBowman added a commit to roboticslab-uc3m/yarp-devices that referenced this issue Jul 15, 2018
rsantos88 pushed a commit to roboticslab-uc3m/yarp-devices that referenced this issue Jan 29, 2019
rsantos88 pushed a commit to roboticslab-uc3m/yarp-devices that referenced this issue Jan 29, 2019
@PeterBowman PeterBowman mentioned this issue Apr 19, 2019
3 tasks
@PeterBowman PeterBowman changed the title Migrate to YARP 3.0 Forward compatibility with YARP 3.0 Apr 19, 2019
@PeterBowman
Copy link
Member Author

#65 (comment):

Edit: forgot to add that the alternative (and counterintuitive) solution is fairly simple, just issue find_package(YCM REQUIRED) after find_package(YARP REQUIRED).

Perhaps linked with robotology/yarp@9bfd7ca.

@PeterBowman
Copy link
Member Author

This code:

find_package(YARP 3.0 QUIET COMPONENTS ...)
# in the future, remove this check and use REQUIRED above
if(NOT YARP_FOUND)
    find_package(YARP 2.3.70 REQUIRED)
endif()

...is causing trouble on Windows and YARP 2.3.70. The YARP_DIR variable seems to be ignored by the second find_package(). My hunch is that this might happen on Linux, too, as long as YARP 3.x is not found and YARP_DIR points at a build directory for YARP 2.x.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant