Commit dab40b58 authored by Firmansyah Adiputra's avatar Firmansyah Adiputra Committed by Russ Cox

xgb: fix request length and request size.

R=nigeltao_golang, rsc
CC=golang-dev
https://golang.org/cl/759041
parent 5bb29fb1
...@@ -8,6 +8,7 @@ from os.path import basename, exists ...@@ -8,6 +8,7 @@ from os.path import basename, exists
import getopt import getopt
import sys import sys
import re import re
import math
_ns = None _ns = None
...@@ -345,20 +346,22 @@ def go_complex_writer(self, name, void): ...@@ -345,20 +346,22 @@ def go_complex_writer(self, name, void):
go('func (c *Conn) %sRequest(', func_name) go('func (c *Conn) %sRequest(', func_name)
go_complex_writer_arguments(param_fields, "Cookie {") go_complex_writer_arguments(param_fields, "Cookie {")
fixedtotal = structsize(self.fields) fixedlength = math.ceil(float(structsize(self.fields)) / float(4))
if fixedtotal <= 32: fixedsize = fixedlength * 4
go(' b := c.scratch[0:%d]', fixedtotal)
if fixedsize <= 32:
go(' b := c.scratch[0:%d]', fixedsize)
else: else:
go(' b := make([]byte, %d)', fixedtotal) go(' b := make([]byte, %d)', fixedsize)
firstvar = 0 firstvar = 0
for field in wire_fields: for field in wire_fields:
if not field.type.fixed_size(): if not field.type.fixed_size():
if not firstvar: if not firstvar:
firstvar = 1 firstvar = 1
go(' n := %d', fixedtotal) go(' n := %d', fixedsize)
go(' n += pad(%s * %d)', go_accessor_expr(field.type.expr, '', True), field.type.size) go(' n += pad(%s * %d)', go_accessor_expr(field.type.expr, '', True), field.type.size)
if not firstvar: if not firstvar:
go(' put16(b[2:], %d)', fixedtotal / 4) go(' put16(b[2:], %d)', fixedlength)
else: else:
go(' put16(b[2:], uint16(n / 4))') go(' put16(b[2:], uint16(n / 4))')
go(' b[0] = %s', self.opcode) go(' b[0] = %s', self.opcode)
......
...@@ -2427,8 +2427,8 @@ func (c *Conn) ListFontsWithInfoReply(cookie Cookie) (*ListFontsWithInfoReply, o ...@@ -2427,8 +2427,8 @@ func (c *Conn) ListFontsWithInfoReply(cookie Cookie) (*ListFontsWithInfoReply, o
} }
func (c *Conn) SetFontPath(FontQty uint16, Path []byte) { func (c *Conn) SetFontPath(FontQty uint16, Path []byte) {
b := c.scratch[0:6] b := c.scratch[0:8]
n := 6 n := 8
n += pad(len(Path) * 1) n += pad(len(Path) * 1)
put16(b[2:], uint16(n/4)) put16(b[2:], uint16(n/4))
b[0] = 51 b[0] = 51
...@@ -3553,8 +3553,8 @@ func (c *Conn) ListExtensionsReply(cookie Cookie) (*ListExtensionsReply, os.Erro ...@@ -3553,8 +3553,8 @@ func (c *Conn) ListExtensionsReply(cookie Cookie) (*ListExtensionsReply, os.Erro
} }
func (c *Conn) ChangeKeyboardMapping(KeycodeCount byte, FirstKeycode byte, KeysymsPerKeycode byte, Keysyms []Keysym) { func (c *Conn) ChangeKeyboardMapping(KeycodeCount byte, FirstKeycode byte, KeysymsPerKeycode byte, Keysyms []Keysym) {
b := c.scratch[0:6] b := c.scratch[0:8]
n := 6 n := 8
n += pad((int(KeycodeCount) * int(KeysymsPerKeycode)) * 4) n += pad((int(KeycodeCount) * int(KeysymsPerKeycode)) * 4)
put16(b[2:], uint16(n/4)) put16(b[2:], uint16(n/4))
b[0] = 100 b[0] = 100
...@@ -3566,8 +3566,8 @@ func (c *Conn) ChangeKeyboardMapping(KeycodeCount byte, FirstKeycode byte, Keysy ...@@ -3566,8 +3566,8 @@ func (c *Conn) ChangeKeyboardMapping(KeycodeCount byte, FirstKeycode byte, Keysy
} }
func (c *Conn) GetKeyboardMappingRequest(FirstKeycode byte, Count byte) Cookie { func (c *Conn) GetKeyboardMappingRequest(FirstKeycode byte, Count byte) Cookie {
b := c.scratch[0:6] b := c.scratch[0:8]
put16(b[2:], 1) put16(b[2:], 2)
b[0] = 101 b[0] = 101
b[4] = FirstKeycode b[4] = FirstKeycode
b[5] = Count b[5] = Count
...@@ -3733,8 +3733,8 @@ const ( ...@@ -3733,8 +3733,8 @@ const (
) )
func (c *Conn) SetScreenSaver(Timeout int16, Interval int16, PreferBlanking byte, AllowExposures byte) { func (c *Conn) SetScreenSaver(Timeout int16, Interval int16, PreferBlanking byte, AllowExposures byte) {
b := c.scratch[0:10] b := c.scratch[0:12]
put16(b[2:], 2) put16(b[2:], 3)
b[0] = 107 b[0] = 107
put16(b[4:], uint16(Timeout)) put16(b[4:], uint16(Timeout))
put16(b[6:], uint16(Interval)) put16(b[6:], uint16(Interval))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment