On Tuesday, April 4, 2017 at 2:34:29 AM UTC-4, Axel Wagner wrote:
>
> On Tue, Apr 4, 2017 at 12:38 AM, Joubin Houshyar <jhou...@gmail.com 
> <javascript:>> wrote:
>>
>> Well, you've got bigger fish to fry here in your example above than 
>> worrying about call site snafus: you should be closing that opened file in 
>> the error case. Right?  
>>
>
> I don't think so. First, from a "general go API hygiene" position, it 
> doesn't make sense to require to do *anything* to a returned value if a 
> non-nil error is returned. And second, if open(2) fails, there won't even 
> be anything returned that could be closed.
>
> It seems to me neither Dave's (roughly: all bets are off if function 
>> returns error) nor Ian's (roughly: be extra hygienic) replies has satisfied 
>> you.
>>
>
> I don't know how you would come to that conclusion. Dave's messages didn't 
> satisfy me, because they did not actually have anything to do with the 
> question. Ian's reply did. He asked a follow-up question though, which I 
> answered.
>
> But also, I wasn't asking for a question with an authoritative answer. I 
> was soliciting opinions. That kind of thing doesn't usually end once 
> someone gave theirs. And I find all the other (later) replies very useful.
>  
>
>> And as far as the being "hurtful" to users of your functions, if they are 
>> ignoring errors, and ignoring documentation, then they fully deserve 
>> spending a few extra cycles banging their heads against the wall. It a 
>> lesson worth learning.
>>
>
> This is an incredibly weird position to me. The reasons for not checking 
> an error might range from "they don't have the experience/knowledge" to 
> "they weren't careful enough at that time" and considering either to be 
> deserving of punishment seems very arrogant to me. It seems to say that you 
> assume both you always were an expert programmer and you never make any 
> mistakes. 
>

Punishment is something that is meted out. Self inflicted pain is not a 
form of punishment. Learning any craft entails making mistakes and learning 
from those mistakes. For example, there is not a conspiracy of nail and 
hammer makers to "punish" novice carpenters who miss the nail and hit their 
fingers with the hammer. It is just part of the learning process.

 
>

> Making people's life easier when they made a mistake - even if it's their 
> fault - is a net positive; you lose nothing and their life gets easier.
>

In this context, making people's life easier is adhering to language 
conventions, and providing correct documentation and bug free 
implementations. 

(p.s. I did not appreciate the pejorative terms in your reply. You may wish 
to review this document: https://golang.org/conduct)
 

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to