Hi internals, Currently, there doesn't seem to be an exact fit for indicating that a method isn't supported on an object by design (and will throw unconditionally). (For example, when implementing an interface or overriding a base class, e.g. an Immutable datastructure not implementing offsetSet/offsetUnset, an object that does not support serialization and overrides __serialize/__unserialize to forbid it, etc.)
- BadMethodCallException - Exception thrown if a callback refers to an undefined method or if some arguments are missing. - DomainException/RangeException - Seemingly refer to argument values - LogicException - "Exception that represents error in the program logic. This kind of exception should lead directly to a fix in your code." I don't believe it's quite that, because code designed for the interface implementing the method (e.g. ArrayAccess) might have correct logic, it's the choice of implementation/subclass at runtime that caused the exception. - RuntimeException and its subclasses are also used for unpredictable errors such as missing files, network/db errors, etc, making the meaning of `try { ... } catch (RuntimeException $e) {}` less clear. - BadMethodCallException - Exception thrown if a callback refers to an undefined method or if some arguments are missing.' seems misleading as well since the method is defined and has its arguments, and existing uses in CachingIterator/Phar are checking the object's properties or arguments. (Uncaught BadMethodCallException: CachingIterator does not fetch string value (see CachingIterator::__construct) in %s:%d) RuntimeException (or a userland subclass) is the most common exception type I see used for this purpose, but RuntimeException is already used for many other things and has many subclasses. https://www.php.net/manual/en/spl.exceptions.php#spl.exceptions.tree https://www.php.net/manual/en/class.exception.php (RuntimeException and subclasses are also used for unpredictable errors such as missing files, network/db errors, some types of errors in destructors, etc, making writing `try { ... } catch (RuntimeException $e) {}` to catch this also catch other issues that should instead be rethrown.) It would be useful to provide this instead of having extensions or userland code throw RuntimeException or implement their own exceptions https://www.php.net/manual/en/class.solrillegaloperationexception IDEs/type checkers would also have more information to indicate that a method call is probably invalid in a use case and it would allow userland code to be have more specific api documentation/type info than `@throws RuntimeException` (rather than deliberately invoking a shared helper method to throw exceptions). - Type checkers already check this - e.g. https://psalm.dev/docs/running_psalm/configuration/#ignoreexceptions https://github.com/phan/phan/wiki/Issue-Types-Caught-by-Phan#phanthrowcommentintostring Thoughts on adding UnsupportedOperationException to the spl? Thanks, Tyson -- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: https://www.php.net/unsub.php