[Signals] Is connection::disconnect() "const-correct"?
data:image/s3,"s3://crabby-images/7cfa6/7cfa6064001d5d3b9d0e0993bba653cf9d217e9e" alt=""
For a connection 'c', if c.connected() == true prior to calling c.disconnect(); after which c.connected() == false, how can connection::disconnect() be considered a "const" member function since it clearly changes the observable state of a connection?
data:image/s3,"s3://crabby-images/5bcf6/5bcf69108158a01408688a573f77c51915ee8ae7" alt=""
On Tuesday, May 03, 2011, Greg Hickman wrote:
For a connection 'c', if c.connected() == true prior to calling
c.disconnect();
after which c.connected() == false, how can connection::disconnect() be considered a "const" member function since it clearly changes the observable state of a connection?
Signals2 continues to do the same, although if I ever thought much about rationalizing it before, I don't remember doing so now. Anyways, maybe it's because connection objects are just handles to the real connection. So it's like a pointer in that a const pointer just means the pointer can't be reassigned to point at another object, but you can still modify the pointed-at object through it. To make things more concrete, suppose disconnect was non-const. It still wouldn't stop you from making a new non-const connection object that is a copy of the const connection object, and then disconnecting through the non-const connection object. So I guess I'm arguing that the connected() method isn't returning information about the state of the connection object itself, but rather the state of the thing it is a handle to.
data:image/s3,"s3://crabby-images/7cfa6/7cfa6064001d5d3b9d0e0993bba653cf9d217e9e" alt=""
On Tue, May 3, 2011 at 10:10 PM, Frank Mori Hess
To make things more concrete, suppose disconnect was non-const. It still wouldn't stop you from making a new non-const connection object that is a copy of the const connection object, and then disconnecting through the non-const connection object. So I guess I'm arguing that the connected() method isn't returning information about the state of the connection object itself, but rather the state of the thing it is a handle to.
I agree that a connection has reference semantics and that connection::connected() therefore returns information about the thing being referenced (as opposed to the handle itself). According the logic above, however, doesn't the fact that connection::block() is non-const seem inconsistent? In other words, it would seem that connection::disconnect() and connection::block() should both be either const or non-const for consistency.
data:image/s3,"s3://crabby-images/901b9/901b92bedbe00b09b23de814be508bc893a8e94d" alt=""
-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 On Wednesday, May 04, 2011, Greg Hickman wrote:
I agree that a connection has reference semantics and that connection::connected() therefore returns information about the thing being referenced (as opposed to the handle itself). According the logic above, however, doesn't the fact that connection::block() is non-const seem inconsistent? In other words, it would seem that connection::disconnect() and connection::block() should both be either const or non-const for consistency.
Yes, I agree. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.10 (GNU/Linux) iEYEARECAAYFAk3CnREACgkQ5vihyNWuA4UliQCdGGHYOcxhq3qLKZr993GYJPgz 1/IAn0Xk/0nMxT1E08zqssVEaRZBH6Y4 =7Bt8 -----END PGP SIGNATURE-----
participants (3)
-
Frank Mori Hess
-
Frank Mori Hess
-
Greg Hickman