Giter VIP home page Giter VIP logo

Comments (4)

TommyKaneko avatar TommyKaneko commented on September 14, 2024

Ah, this isn't for suppressing warnings. It's been a while when I did this, but (I think) it served the purpose of easily removing variables that were created for assert() checks, for production builds. I need the asserts for debugging.

from sketchup-api-c-wrapper.

thomthom avatar thomthom commented on September 14, 2024

How is this removing any variable?

Looking at how it's used:

SUTypedValueRef TypedValue::create_typed_value() {
SUTypedValueRef typed_value = SU_INVALID;
SUResult res = SUTypedValueCreate(&typed_value);
assert(res == SU_ERROR_NONE); _unused(res);
return typed_value;
}
TypedValue::~TypedValue() {
if (SUIsValid(m_typed_value) && !m_attached) {
SUResult res = SUTypedValueRelease(&m_typed_value);
assert(res == SU_ERROR_NONE); _unused(res);
}
}

The results variable is created regardless. But in Release it'll be unused and produce a warning.

This should do the same, but with newer C++ semantics.

SUTypedValueRef TypedValue::create_typed_value() {
  SUTypedValueRef typed_value = SU_INVALID;
  [[maybe_unused]] auto res = SUTypedValueCreate(&typed_value);
  assert(res == SU_ERROR_NONE);
  return typed_value;
}

from sketchup-api-c-wrapper.

TommyKaneko avatar TommyKaneko commented on September 14, 2024

OK, thank for the tip. I will implement that. The wrapper was made initially with C++14, so I will get on and make those changes.

from sketchup-api-c-wrapper.

thomthom avatar thomthom commented on September 14, 2024

I've been recently migrating my projects to C++20 and it's adding quite a few nice features. Even C++17 add a good chunk of useful improvements to the language.

from sketchup-api-c-wrapper.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.