本文整理匯總了Golang中github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol.WriteMessageEnd方法的典型用法代碼示例。如果您正苦於以下問題:Golang TProtocol.WriteMessageEnd方法的具體用法?Golang TProtocol.WriteMessageEnd怎麽用?Golang TProtocol.WriteMessageEnd使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/upfluence/goutils/Godeps/_workspace/src/github.com/upfluence/thrift/lib/go/thrift.TProtocol
的用法示例。
在下文中一共展示了TProtocol.WriteMessageEnd方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: Process
func (p *BaseServiceProcessor) Process(iprot, oprot thrift.TProtocol) (success bool, err thrift.TException) {
name, _, seqId, err := iprot.ReadMessageBegin()
if err != nil {
return false, err
}
if processor, ok := p.GetProcessorFunction(name); ok {
return processor.Process(seqId, iprot, oprot)
}
iprot.Skip(thrift.STRUCT)
iprot.ReadMessageEnd()
x11 := thrift.NewTApplicationException(thrift.UNKNOWN_METHOD, "Unknown function "+name)
oprot.WriteMessageBegin(name, thrift.EXCEPTION, seqId)
x11.Write(oprot)
oprot.WriteMessageEnd()
oprot.Flush()
return false, x11
}
示例2: Process
func (p *monitoringProcessorCollect) Process(seqId int32, iprot, oprot thrift.TProtocol) (success bool, err thrift.TException) {
args := MonitoringCollectArgs{}
if err = args.Read(iprot); err != nil {
iprot.ReadMessageEnd()
x := thrift.NewTApplicationException(thrift.PROTOCOL_ERROR, err.Error())
oprot.WriteMessageBegin("collect", thrift.EXCEPTION, seqId)
x.Write(oprot)
oprot.WriteMessageEnd()
oprot.Flush()
return false, err
}
iprot.ReadMessageEnd()
result := MonitoringCollectResult{}
var retval Metrics
var err2 error
t0 := time.Now().UnixNano()
if retval, err2 = p.handler.Collect(args.Metrics); err2 != nil {
switch v := err2.(type) {
case *ServiceNotAvailable:
thrift.Metrics.Incr("Monitoring.collect.server.exceptions.*ServiceNotAvailable")
result.ServiceUnavailable = v
case *UnknownMetric:
thrift.Metrics.Incr("Monitoring.collect.server.exceptions.*UnknownMetric")
result.UnknownMetric = v
default:
thrift.Metrics.Incr("Monitoring.collect.server.success")
x := thrift.NewTApplicationException(thrift.INTERNAL_ERROR, "Internal error processing collect: "+err2.Error())
oprot.WriteMessageBegin("collect", thrift.EXCEPTION, seqId)
x.Write(oprot)
oprot.WriteMessageEnd()
oprot.Flush()
thrift.Metrics.Incr("Monitoring.collect.server.exceptions.application_error")
return true, err2
}
} else {
thrift.Metrics.Incr("Monitoring.collect.server.success")
result.Success = retval
}
t1 := time.Now().UnixNano()
thrift.Metrics.Timing("Monitoring.collect.server", t1-t0)
if err2 = oprot.WriteMessageBegin("collect", thrift.REPLY, seqId); err2 != nil {
err = err2
}
if err2 = result.Write(oprot); err == nil && err2 != nil {
err = err2
}
if err2 = oprot.WriteMessageEnd(); err == nil && err2 != nil {
err = err2
}
if err2 = oprot.Flush(); err == nil && err2 != nil {
err = err2
}
if err != nil {
return
}
return true, err
}