It can be covered, but then I'll have to duplicate the `connection.release()` call in both the try and catch blocks, (and remember, there can be multiple resources to be cleaned up).
Plus, in case that I have a function with multiple if-else branches with returns from multiple branches, I will have to duplicate that in all the branches. Another benefit of this is that this will help us logically group allocation and deallocation of resources together, for better readability and debuggability. On Thu, Sep 20, 2018 at 2:57 PM Ben Wiley <therealbenwi...@gmail.com> wrote: > Hey Ayush, > > That's an interesting language feature I hadn't heard of before. > > Any reason your use case couldn't be covered by a try/catch in the > synchronous case, and a promise.finally() in the async case? > > Ben > > Le jeu. 20 sept. 2018 05 h 21, Ayush Gupta <ayushg3...@gmail.com> a > écrit : > >> Hi, >> >> I would like to propose a `defer` keyword(or something else as the >> keyword name) which would allow us to "defer" a function which will be >> executed once the current function either returns or throws. >> >> The idea for this is taken from the Go programming language. >> >> It would allow us to perform cleanup activities in a function which has >> multiple branches in a single place. >> >> For example, a sample server side code can look like: >> >> ``` js >> function doSomeDbWork() { >> const connection = databasepool.getConnection(); >> defer function () { connection.release(); } // function would be >> called no matter when/if the function returns or throws >> // do your work >> } >> ``` >> >> Regards >> Ayush Gupta >> >> >> _______________________________________________ >> es-discuss mailing list >> es-discuss@mozilla.org >> https://mail.mozilla.org/listinfo/es-discuss >> >
_______________________________________________ es-discuss mailing list es-discuss@mozilla.org https://mail.mozilla.org/listinfo/es-discuss