OK, now I actually get it. Just use a CounterWriter and return bytes num it 
receives.
Such writer already exists in the std lib?

在 2016年12月16日星期五 UTC+8下午2:10:41,P Q写道:
>
> 2016년 12월 16일 금요일 오전 11시 5분 53초 UTC+9, Peng Wang 님의 말:
> Actually I don't really care about that, just don't want break the 
> interface requirement
> in the doc it says "WriteAt writes len(p) bytes from p to the underlying 
> data stream at offset off. It returns the number of bytes written from p (0 
> <= n <= len(p)) and any error encountered that caused the write to stop 
> early."
> but using binary.Write I lost that infomation. So what's the right way to 
> do it ? or just ignore it and return 0? 
>
> Write should inform the caller of the number of bytes written even though 
> some error happens during the write operation. (
> https://golang.org/pkg/io/#Writer states explicitly). It's recommended 
> for the WriteTo method to return a proper n, not 0.
>
> binary.Write dosen't return how many bytes are written, but not mean you 
> have to miss the information, because binary.Write calls internally to 
> io.Write.
>
> As Tamás Gulácsi says, you can wrap w in countWriter. And if error occurs, 
> examine countWriter.N field to get information about the number of bytes 
> written.
>
> I couldn't understand this wrapping could break the interface 
> requirements. The program you're writing need some even complicated 
> behavior i couldn't guess at?
>

-- 
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