push.go 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. package yu_pack
  2. // -----------------------------------------------------------------------------------------------------组包
  3. func (t *Pack) PushByte(val ...byte) *Pack {
  4. t.Grow(len(val))
  5. t.buf = append(t.buf, val...)
  6. return t
  7. }
  8. /*
  9. PushInt16L 追加int16数据
  10. val 可循环添加,字节序为:小端字节序——将低序字节存储在起始地址(123=>[123 0])
  11. */
  12. func (t *Pack) PushInt16L(val ...int16) *Pack {
  13. t.Grow(2 * len(val))
  14. for j_i := 0; j_i < len(val); j_i++ {
  15. t.buf = append(t.buf, byte(val[j_i]), byte(val[j_i]>>8))
  16. }
  17. return t
  18. }
  19. /*
  20. PushInt16B 追加int16数据
  21. val 可循环添加,字节序为:大端字节序——将高序字节存储在起始地址(123=>[0 123])
  22. */
  23. func (t *Pack) PushInt16B(val ...int16) *Pack {
  24. t.Grow(2 * len(val))
  25. for j_i := 0; j_i < len(val); j_i++ {
  26. t.buf = append(t.buf, byte(val[j_i]>>8), byte(val[j_i]))
  27. }
  28. return t
  29. }
  30. /*
  31. PushInt16L 追加int16数据
  32. val 可循环添加,字节序为:小端字节序——将低序字节存储在起始地址(123=>[123 0])
  33. */
  34. func (t *Pack) PushUint16L(val ...uint16) *Pack {
  35. t.Grow(2 * len(val))
  36. for j_i := 0; j_i < len(val); j_i++ {
  37. t.buf = append(t.buf, byte(val[j_i]), byte(val[j_i]>>8))
  38. }
  39. return t
  40. }
  41. /*
  42. PushInt16B 追加int16数据
  43. val 可循环添加,字节序为:大端字节序——将高序字节存储在起始地址(123=>[0 123])
  44. */
  45. func (t *Pack) PushUint16B(val ...uint16) *Pack {
  46. t.Grow(2 * len(val))
  47. for j_i := 0; j_i < len(val); j_i++ {
  48. t.buf = append(t.buf, byte(val[j_i]>>8), byte(val[j_i]))
  49. }
  50. return t
  51. }
  52. /*
  53. PushInt32L 追加int32数据
  54. val 可循环添加,字节序为:小端字节序——将低序字节存储在起始地址(123=>[123 0])
  55. */
  56. func (t *Pack) PushInt32L(val ...int32) *Pack {
  57. t.Grow(4 * len(val))
  58. for j_i := 0; j_i < len(val); j_i++ {
  59. t.buf = append(t.buf,
  60. byte(val[j_i]), byte(val[j_i]>>8),
  61. byte(val[j_i]>>16), byte(val[j_i]>>24),
  62. )
  63. }
  64. return t
  65. }
  66. /*
  67. PushInt32B 追加int32数据
  68. val 可循环添加,字节序为:大端字节序——将高序字节存储在起始地址(123=>[0 123])
  69. */
  70. func (t *Pack) PushInt32B(val ...int32) *Pack {
  71. t.Grow(4 * len(val))
  72. for j_i := 0; j_i < len(val); j_i++ {
  73. t.buf = append(t.buf,
  74. byte(val[j_i]>>24), byte(val[j_i]>>16),
  75. byte(val[j_i]>>8), byte(val[j_i]),
  76. )
  77. }
  78. return t
  79. }
  80. /*
  81. PushInt32L 追加int32数据
  82. val 可循环添加,字节序为:小端字节序——将低序字节存储在起始地址(123=>[123 0])
  83. */
  84. func (t *Pack) PushUint32L(val ...uint32) *Pack {
  85. t.Grow(4 * len(val))
  86. for j_i := 0; j_i < len(val); j_i++ {
  87. t.buf = append(t.buf,
  88. byte(val[j_i]), byte(val[j_i]>>8),
  89. byte(val[j_i]>>16), byte(val[j_i]>>24),
  90. )
  91. }
  92. return t
  93. }
  94. /*
  95. PushInt32B 追加int32数据
  96. val 可循环添加,字节序为:大端字节序——将高序字节存储在起始地址(123=>[0 123])
  97. */
  98. func (t *Pack) PushUint32B(val ...uint32) *Pack {
  99. t.Grow(4 * len(val))
  100. for j_i := 0; j_i < len(val); j_i++ {
  101. t.buf = append(t.buf,
  102. byte(val[j_i]>>24), byte(val[j_i]>>16),
  103. byte(val[j_i]>>8), byte(val[j_i]),
  104. )
  105. }
  106. return t
  107. }
  108. /*
  109. PushInt64L 追加int64数据
  110. val 可循环添加,字节序为:小端字节序——将低序字节存储在起始地址(123=>[123 0])
  111. */
  112. func (t *Pack) PushInt64L(val ...int64) *Pack {
  113. t.Grow(8 * len(val))
  114. for j_i := 0; j_i < len(val); j_i++ {
  115. t.buf = append(t.buf,
  116. byte(val[j_i]), byte(val[j_i]>>8),
  117. byte(val[j_i]>>16), byte(val[j_i]>>24),
  118. byte(val[j_i]>>32), byte(val[j_i]>>40),
  119. byte(val[j_i]>>48), byte(val[j_i]>>56),
  120. )
  121. }
  122. return t
  123. }
  124. /*
  125. PushInt64B 追加int64数据
  126. val 可循环添加,字节序为:大端字节序——将高序字节存储在起始地址(123=>[0 123])
  127. */
  128. func (t *Pack) PushInt64B(val ...int64) *Pack {
  129. t.Grow(8 * len(val))
  130. for j_i := 0; j_i < len(val); j_i++ {
  131. t.buf = append(t.buf,
  132. byte(val[j_i]>>56), byte(val[j_i]>>48),
  133. byte(val[j_i]>>40), byte(val[j_i]>>32),
  134. byte(val[j_i]>>24), byte(val[j_i]>>16),
  135. byte(val[j_i]>>8), byte(val[j_i]),
  136. )
  137. }
  138. return t
  139. }
  140. /*
  141. PushInt64L 追加int64数据
  142. val 可循环添加,字节序为:小端字节序——将低序字节存储在起始地址(123=>[123 0])
  143. */
  144. func (t *Pack) PushUint64L(val ...uint64) *Pack {
  145. t.Grow(8 * len(val))
  146. for j_i := 0; j_i < len(val); j_i++ {
  147. t.buf = append(t.buf,
  148. byte(val[j_i]), byte(val[j_i]>>8),
  149. byte(val[j_i]>>16), byte(val[j_i]>>24),
  150. byte(val[j_i]>>32), byte(val[j_i]>>40),
  151. byte(val[j_i]>>48), byte(val[j_i]>>56),
  152. )
  153. }
  154. return t
  155. }
  156. /*
  157. PushInt64B 追加int64数据
  158. val 可循环添加,字节序为:大端字节序——将高序字节存储在起始地址(123=>[0 123])
  159. */
  160. func (t *Pack) PushUint64B(val ...uint64) *Pack {
  161. t.Grow(8 * len(val))
  162. for j_i := 0; j_i < len(val); j_i++ {
  163. t.buf = append(t.buf,
  164. byte(val[j_i]>>56), byte(val[j_i]>>48),
  165. byte(val[j_i]>>40), byte(val[j_i]>>32),
  166. byte(val[j_i]>>24), byte(val[j_i]>>16),
  167. byte(val[j_i]>>8), byte(val[j_i]),
  168. )
  169. }
  170. return t
  171. }
  172. func (t *Pack) PushBytes(val []byte) *Pack {
  173. t.Grow(len(val))
  174. t.buf = append(t.buf, val...)
  175. return t
  176. }
  177. func (t *Pack) PushBytesByte(val []byte, add int) *Pack {
  178. j_len := len(val)
  179. t.Grow(j_len + 1)
  180. j_len += add
  181. t.buf = append(t.buf, byte(j_len))
  182. t.buf = append(t.buf, val...)
  183. return t
  184. }
  185. func (t *Pack) PushBytesInt16L(val []byte, add int) *Pack {
  186. j_len := len(val)
  187. t.Grow(j_len + 2)
  188. j_len += add
  189. t.buf = append(t.buf, byte(j_len), byte(j_len>>8))
  190. t.buf = append(t.buf, val...)
  191. return t
  192. }
  193. func (t *Pack) PushBytesInt16B(val []byte, add int) *Pack {
  194. j_len := len(val)
  195. t.Grow(j_len + 2)
  196. j_len += add
  197. t.buf = append(t.buf, byte(j_len>>8), byte(j_len))
  198. t.buf = append(t.buf, val...)
  199. return t
  200. }
  201. func (t *Pack) PushBytesInt32L(val []byte, add int) *Pack {
  202. j_len := len(val)
  203. t.Grow(j_len + 4)
  204. j_len += add
  205. t.buf = append(t.buf,
  206. byte(j_len), byte(j_len>>8),
  207. byte(j_len>>16), byte(j_len>>24),
  208. )
  209. t.buf = append(t.buf, val...)
  210. return t
  211. }
  212. func (t *Pack) PushBytesInt32B(val []byte, add int) *Pack {
  213. j_len := len(val)
  214. t.Grow(j_len + 4)
  215. j_len += add
  216. t.buf = append(t.buf,
  217. byte(j_len>>24), byte(j_len>>16),
  218. byte(j_len>>8), byte(j_len),
  219. )
  220. t.buf = append(t.buf, val...)
  221. return t
  222. }
  223. func (t *Pack) PushBytesInt64L(val []byte, add int) *Pack {
  224. j_len := len(val)
  225. t.Grow(j_len + 8)
  226. j_len += add
  227. t.buf = append(t.buf,
  228. byte(j_len), byte(j_len>>8),
  229. byte(j_len>>16), byte(j_len>>24),
  230. byte(j_len>>32), byte(j_len>>40),
  231. byte(j_len>>48), byte(j_len>>56),
  232. )
  233. t.buf = append(t.buf, val...)
  234. return t
  235. }
  236. func (t *Pack) PushBytesInt64B(val []byte, add int) *Pack {
  237. j_len := len(val)
  238. t.Grow(j_len + 8)
  239. j_len += add
  240. t.buf = append(t.buf,
  241. byte(j_len>>56), byte(j_len>>48),
  242. byte(j_len>>40), byte(j_len>>32),
  243. byte(j_len>>24), byte(j_len>>16),
  244. byte(j_len>>8), byte(j_len),
  245. )
  246. t.buf = append(t.buf, val...)
  247. return t
  248. }
  249. func (t *Pack) PushString(val string) *Pack {
  250. t.Grow(len(val))
  251. t.buf = append(t.buf, val...)
  252. return t
  253. }
  254. func (t *Pack) PushStringByte(val string, add int) *Pack {
  255. j_len := len(val)
  256. t.Grow(j_len + 1)
  257. j_len += add
  258. t.buf = append(t.buf, byte(j_len))
  259. t.buf = append(t.buf, val...)
  260. return t
  261. }
  262. func (t *Pack) PushStringInt16L(val string, add int) *Pack {
  263. j_len := len(val)
  264. t.Grow(j_len + 2)
  265. j_len += add
  266. t.buf = append(t.buf, byte(j_len), byte(j_len>>8))
  267. t.buf = append(t.buf, val...)
  268. return t
  269. }
  270. func (t *Pack) PushStringInt16B(val string, add int) *Pack {
  271. j_len := len(val)
  272. t.Grow(j_len + 2)
  273. j_len += add
  274. t.buf = append(t.buf, byte(j_len>>8), byte(j_len))
  275. t.buf = append(t.buf, val...)
  276. return t
  277. }
  278. func (t *Pack) PushStringInt32L(val string, add int) *Pack {
  279. j_len := len(val)
  280. t.Grow(j_len + 4)
  281. j_len += add
  282. t.buf = append(t.buf,
  283. byte(j_len), byte(j_len>>8),
  284. byte(j_len>>16), byte(j_len>>24),
  285. )
  286. t.buf = append(t.buf, val...)
  287. return t
  288. }
  289. func (t *Pack) PushStringInt32B(val string, add int) *Pack {
  290. j_len := len(val)
  291. t.Grow(j_len + 4)
  292. j_len += add
  293. t.buf = append(t.buf,
  294. byte(j_len>>24), byte(j_len>>16),
  295. byte(j_len>>8), byte(j_len),
  296. )
  297. t.buf = append(t.buf, val...)
  298. return t
  299. }
  300. func (t *Pack) PushStringInt64L(val string, add int) *Pack {
  301. j_len := len(val)
  302. t.Grow(j_len + 8)
  303. j_len += add
  304. t.buf = append(t.buf,
  305. byte(j_len), byte(j_len>>8),
  306. byte(j_len>>16), byte(j_len>>24),
  307. byte(j_len>>32), byte(j_len>>40),
  308. byte(j_len>>48), byte(j_len>>56),
  309. )
  310. t.buf = append(t.buf, val...)
  311. return t
  312. }
  313. func (t *Pack) PushStringInt64B(val string, add int) *Pack {
  314. j_len := len(val)
  315. t.Grow(j_len + 8)
  316. j_len += add
  317. t.buf = append(t.buf,
  318. byte(j_len>>56), byte(j_len>>48),
  319. byte(j_len>>40), byte(j_len>>32),
  320. byte(j_len>>24), byte(j_len>>16),
  321. byte(j_len>>8), byte(j_len),
  322. )
  323. t.buf = append(t.buf, val...)
  324. return t
  325. }