Coder Social home page Coder Social logo

Comments (7)

nathany avatar nathany commented on May 16, 2024

Maybe even just a better error from UseHandler instead of panicking down the line?

from negroni.

codegangsta avatar codegangsta commented on May 16, 2024

@nathany this is a good point, I will leave this issue to remind me to update the documentation

from negroni.

jszwedko avatar jszwedko commented on May 16, 2024

I think maybe just panic()ing right away with a message indicating a nil handler is the best approach here. The alternative is to just exit the method early (skipping the pushing of a handler onto the stack), but I think that behavior is less expected by the user (e.g. they might think that they are passing in a non-nil handler that is being ignored).

from negroni.

jszwedko avatar jszwedko commented on May 16, 2024

To add a bit more context, I think negroni.Use is fundamentally different than http.ListenAndServe. The latter is a convenience function that is called to start a webserver (with the DefaultServerMux if no handler is specified), whereas negori.Uses sole purpose is to push a handler onto the stack -- i.e. you wouldn't call it if you weren't trying to push a handler onto the stack -- so pushing a nil should be unexpected.

from negroni.

jszwedko avatar jszwedko commented on May 16, 2024

Did not mean to close 😄

from negroni.

nathany avatar nathany commented on May 16, 2024

@jszwedko I agree, I think it just needs a better error message.

from negroni.

nathany avatar nathany commented on May 16, 2024

Thanks

from negroni.

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.