-
-
Notifications
You must be signed in to change notification settings - Fork 2k
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
Add syslog logger support. #386
Conversation
I don't think the build failure is related to my change (when running |
yep, the failure is in one of the timed tests. Travis machines are not always super fast so sometimes there are false positives on those. |
I'm not ready to introduce virtual methods to the logging interface. If you resubmit this without the virtual methods I'll accept. |
@zaphoyd, I can definitely remove the virtual methods, but just to satisfy my curiosity, can I ask why? (e.g., worries about performance). The reason I marked it virtual (and used C++11's |
Sure. A few reasons. Primarily, appropriate tools for the job and not bringing in additional runtime complexity unless it is necessary. WebSocket++'s policy based composition of components (including the logging system) is a compile time operation with no need for runtime polymorphism, as such virtual methods add complexity and overhead that is not needed. Keeping static binding is faster and gentler on caches/branch predictors, allows IDEs and the compiler to provide better error messages, better documentation links, better inlining, and other optimization. This is particularly important for the logging system which gets invoked in many of the library's critical paths and in many cases those invocations are intended to be inlined into no-ops/branches that always fail, something which virtual dispatch complicates. With respect to override, the library is required to be useable on non-C++11 systems, so the addition of new C++11 keywords needs to be done carefully. In practice, even without virtual+override, you will still get a compile error if the signature of the write methods change as the call sites in the library itself will change. The policy based design methods will enforce at compile time that all custom policy components implement all required method signatures. WebSocket++ is designed to be extended via custom policies for certain components (logging, RNG, transport, http parsing). I consider the interfaces that the library uses to talk to these components a part of the public API and subject to the same backwards compatibility and breaking change notifications as the rest of the library. An update to the interface between the library core and policy components would be considered a major API breaking change that would not be made lightly and if done would be be listed prominently in the release notes. |
Thanks, that's exactly what I was looking for. Glad to know that changing the logger interface would be considered a major API break. |
@zaphoyd Excellent explanation. 👍 |
@zaphoyd Removed the |
Adding syslog as a supported logger. This seems like a common enough use-case to be in the main repo.