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?

在 2016年12月16日星期五 UTC+8上午4:56:12,Tamás Gulácsi写道:
>
> 2016. december 15., csütörtök 17:36:47 UTC+1 időpontban 彭望 a következőt 
> írta:
>>
>> Hi all, I'm doing a simple message serialization, message defines like 
>> below:
>> type Envelope struct {
>>     Magic uint32
>>     DataSize uint32
>> }
>>
>> type Message struct {
>>     Envelope
>>     Data []byte
>> }
>>
>> and I want to implement the io.WriterTo interface for Message
>> func (m *Message) WriteTo(w io.Writer) (n int64, err error) {
>>     err = binary.Write(w, binary.BigEndian, &m.Envelope)
>>     if err != nil {
>>         // here, how should I return a proper n? Since w maybe 
>> *net.TCPConn and binary.Write maybe write 1 bytes and peer has dropped the 
>> connection.
>>         return 0, fmt.Errorf("Write message envelope error: %s", err)
>>     }
>>
>>     // multiple lines skipped
>> }
>>
>
> If you really want to know the number of bytes written, wrap w in a 
> counting writer, which counts the bytes written.
>
>> type countingWriter struct {  
>>     w io.Writer
>>     N int64
>> }
>> func (w *countingWriter) Write(p []byte) (int, error) {
>>     n, err := w.w.Write(p)
>>     w.N += int64(n)
>>     return n, err
>> }
>>
>  
>

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