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

Use direct member initialization instead of ctr initialisation #7558

Merged
merged 3 commits into from
Oct 5, 2020

Conversation

dirkmueller
Copy link
Contributor

This removes a bit of code repetition.

#define SSDP_PORT 1900
#define SSDP_METHOD_SIZE 10
#define SSDP_URI_SIZE 2
#define SSDP_BUFFER_SIZE 64
#define SSDP_MULTICAST_TTL 2
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would leave SSDP_INTERVAL and SSDP_MULTICAST_TTL defined and used in member initializers for clarity (maybe also adding the unity: SSDP_INTERVAL_SECONDS)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

that'd defeat the purpose of the PR to only have initialization once in one place. I can rename the _interval member variable to _interval_s to keep the unit.

this define is used only in one place, adding this #define does not add make things easier (you need to look it up anyway when you come across reading the constructor).

if thats a hard objection the only thing I'd do is then to remove ESP82666SSDP* completely from this cleanup, leaving it as it is now.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What @d-a-v means is expose the defines, i.e.: move them to the header, maybe turn them into constexpr, and use the relevant ones in the direct member assignment instead of using literal numbers that don't convey meaning.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

BTW, if it is true that the new MDNS responder also handles SSDP, then this SSDP class will likely be pulled out.

@earlephilhower
Copy link
Collaborator

Other than trading one style for another, @dirkmueller, it doesn't look like this has any actual effect on the generated code, no? I'm not really convinced one way is better than the other (and the whole codebase mixes and matches between the two ways in my experience)...

@dirkmueller
Copy link
Contributor Author

@earlephilhower yes, generated code will remain identical. We could decide for one style (e.g the one proposed in this PR) and I can make the code base consistent. There are advantages (reordering class members doesn't require code changes in the constructor code, multiple constructors don't have to repeate initializations)

@TD-er
Copy link
Contributor

TD-er commented Aug 31, 2020

Isn't there a difference here?
Don't know what to search for to check in the standard, but I thought it also allowed to initialize the members directly on the stack, before the constructor was called.
If members are initialized in the constructor, then it depends on whether the constructor is actually called (and also which constructor).
This can be an issue if you have specified a destructor which depends on variables to be initialized correctly (like pointers).

But like I said, have to check in the standard to make sure that's what is happening.

#define SSDP_PORT 1900
#define SSDP_METHOD_SIZE 10
#define SSDP_URI_SIZE 2
#define SSDP_BUFFER_SIZE 64
#define SSDP_MULTICAST_TTL 2
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What @d-a-v means is expose the defines, i.e.: move them to the header, maybe turn them into constexpr, and use the relevant ones in the direct member assignment instead of using literal numbers that don't convey meaning.

#define SSDP_PORT 1900
#define SSDP_METHOD_SIZE 10
#define SSDP_URI_SIZE 2
#define SSDP_BUFFER_SIZE 64
#define SSDP_MULTICAST_TTL 2
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

BTW, if it is true that the new MDNS responder also handles SSDP, then this SSDP class will likely be pulled out.

@dirkmueller dirkmueller requested a review from devyte September 1, 2020 21:44
@dirkmueller
Copy link
Contributor Author

Isn't there a difference here?
Don't know what to search for to check in the standard, but I thought it also allowed to initialize the members directly on the stack, before the constructor was called.

No, its identical, see this FAQ: https://isocpp.org/wiki/faq/cpp11-language-classes#member-init

you're right that initalizer lists (e.g. foo::foo() : member(0) {} ) allow avoiding default constructor invocation of the member (which optimizes runtime) as well as allow the compiler to be clever in initializing objects. however one or the other is just syntactical sugar that is making error-prone repetition of code obsolete (DRY - don't repeat yourself).

@dirkmueller dirkmueller force-pushed the no_ctr_initialization branch from 9faeb8a to 65775e9 Compare September 1, 2020 21:58
@dirkmueller dirkmueller force-pushed the no_ctr_initialization branch from 10c57f7 to ade47e2 Compare September 2, 2020 17:56
Copy link
Collaborator

@d-a-v d-a-v left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks !

@earlephilhower earlephilhower merged commit 4aeb0f5 into esp8266:master Oct 5, 2020
davisonja added a commit to davisonja/Arduino that referenced this pull request Oct 16, 2020
* master: (37 commits)
  BREAKING: Change return EEPROM.end() to bool (esp8266#7630)
  BREAKING: Change return type of channel() (esp8266#7656)
  BREAKING: Change return type of RSSI() (esp8266#7657)
  Add Copyright notice to Schedule.h (esp8266#7653)
  MDNS MultiInterface (esp8266#7636)
  BREAKING: Add Wrong Password wifi status case (esp8266#7652)
  New flash writing method with offset/memory/size alignment handling (esp8266#7514)
  Fix error when debug enabled but no port chosen (esp8266#7648)
  LEAmDNSv2: change a macro name to be independant from LEAmDNS1 (esp8266#7640)
  Allow test framework to use cores/esp8266/Arduino.h directly (esp8266#7377)
  Update OTA HTTP Server Header Information (esp8266#7633)
  Add missing sntp_init/sntp_stop (esp8266#7628)
  Use direct member initialization instead of ctr initialisation (esp8266#7558)
  Prevent rewriting Updater_Signing.h if content unchanged (esp8266#7627)
  Add WiFi Multi to readme.rst
  Remove stray axtls refs, deprecated compat funcs (esp8266#7626)
  Pull deprecated axtls link (esp8266#7624)
  Redesign ESP8266WiFiMulti.[cpp|h]
  Update README.md (esp8266#7623)
  Eliminate code duplication by template for printNumber(...)/printFloat(...).
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants