Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Y
ygopro
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
YGOPRO-520DIY
ygopro
Commits
ced64065
Commit
ced64065
authored
Dec 13, 2024
by
salix5
Committed by
GitHub
Dec 13, 2024
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
use uint16_t in NetServer, DuelClient (#2633)
parent
480e2f1a
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
27 additions
and
34 deletions
+27
-34
gframe/duelclient.h
gframe/duelclient.h
+11
-14
gframe/netserver.cpp
gframe/netserver.cpp
+1
-1
gframe/netserver.h
gframe/netserver.h
+15
-19
No files found.
gframe/duelclient.h
View file @
ced64065
...
@@ -52,31 +52,28 @@ public:
...
@@ -52,31 +52,28 @@ public:
static
void
SendResponse
();
static
void
SendResponse
();
static
void
SendPacketToServer
(
unsigned
char
proto
)
{
static
void
SendPacketToServer
(
unsigned
char
proto
)
{
auto
p
=
duel_client_write
;
auto
p
=
duel_client_write
;
BufferIO
::
WriteInt16
(
p
,
1
);
buffer_write
<
uint16_t
>
(
p
,
1
);
BufferIO
::
WriteInt8
(
p
,
proto
);
buffer_write
<
uint8_t
>
(
p
,
proto
);
bufferevent_write
(
client_bev
,
duel_client_write
,
3
);
bufferevent_write
(
client_bev
,
duel_client_write
,
3
);
}
}
template
<
typename
ST
>
template
<
typename
ST
>
static
void
SendPacketToServer
(
unsigned
char
proto
,
ST
&
st
)
{
static
void
SendPacketToServer
(
unsigned
char
proto
,
ST
&
st
)
{
auto
p
=
duel_client_write
;
auto
p
=
duel_client_write
;
if
(
(
int
)
sizeof
(
ST
)
>
MAX_DATA_SIZE
)
if
(
sizeof
(
ST
)
>
MAX_DATA_SIZE
)
return
;
return
;
BufferIO
::
WriteInt16
(
p
,
(
shor
t
)(
1
+
sizeof
(
ST
)));
buffer_write
<
uint16_t
>
(
p
,
(
uint16_
t
)(
1
+
sizeof
(
ST
)));
BufferIO
::
WriteInt8
(
p
,
proto
);
buffer_write
<
uint8_t
>
(
p
,
proto
);
std
::
memcpy
(
p
,
&
st
,
sizeof
(
ST
));
std
::
memcpy
(
p
,
&
st
,
sizeof
(
ST
));
bufferevent_write
(
client_bev
,
duel_client_write
,
sizeof
(
ST
)
+
3
);
bufferevent_write
(
client_bev
,
duel_client_write
,
sizeof
(
ST
)
+
3
);
}
}
static
void
SendBufferToServer
(
unsigned
char
proto
,
void
*
buffer
,
size_t
len
)
{
static
void
SendBufferToServer
(
unsigned
char
proto
,
void
*
buffer
,
size_t
len
)
{
auto
p
=
duel_client_write
;
auto
p
=
duel_client_write
;
int
blen
=
len
;
if
(
len
>
MAX_DATA_SIZE
)
if
(
blen
<
0
)
len
=
MAX_DATA_SIZE
;
return
;
buffer_write
<
uint16_t
>
(
p
,
(
uint16_t
)(
1
+
len
));
if
(
blen
>
MAX_DATA_SIZE
)
buffer_write
<
uint8_t
>
(
p
,
proto
);
blen
=
MAX_DATA_SIZE
;
std
::
memcpy
(
p
,
buffer
,
len
);
BufferIO
::
WriteInt16
(
p
,
(
short
)(
1
+
blen
));
bufferevent_write
(
client_bev
,
duel_client_write
,
len
+
3
);
BufferIO
::
WriteInt8
(
p
,
proto
);
std
::
memcpy
(
p
,
buffer
,
blen
);
bufferevent_write
(
client_bev
,
duel_client_write
,
blen
+
3
);
}
}
static
std
::
vector
<
HostPacket
>
hosts
;
static
std
::
vector
<
HostPacket
>
hosts
;
...
...
gframe/netserver.cpp
View file @
ced64065
...
@@ -11,7 +11,7 @@ event* NetServer::broadcast_ev = 0;
...
@@ -11,7 +11,7 @@ event* NetServer::broadcast_ev = 0;
evconnlistener
*
NetServer
::
listener
=
0
;
evconnlistener
*
NetServer
::
listener
=
0
;
DuelMode
*
NetServer
::
duel_mode
=
0
;
DuelMode
*
NetServer
::
duel_mode
=
0
;
unsigned
char
NetServer
::
net_server_write
[
SIZE_NETWORK_BUFFER
];
unsigned
char
NetServer
::
net_server_write
[
SIZE_NETWORK_BUFFER
];
unsigned
shor
t
NetServer
::
last_sent
=
0
;
size_
t
NetServer
::
last_sent
=
0
;
bool
NetServer
::
StartServer
(
unsigned
short
port
)
{
bool
NetServer
::
StartServer
(
unsigned
short
port
)
{
if
(
net_evbase
)
if
(
net_evbase
)
...
...
gframe/netserver.h
View file @
ced64065
...
@@ -19,7 +19,7 @@ private:
...
@@ -19,7 +19,7 @@ private:
static
evconnlistener
*
listener
;
static
evconnlistener
*
listener
;
static
DuelMode
*
duel_mode
;
static
DuelMode
*
duel_mode
;
static
unsigned
char
net_server_write
[
SIZE_NETWORK_BUFFER
];
static
unsigned
char
net_server_write
[
SIZE_NETWORK_BUFFER
];
static
unsigned
shor
t
last_sent
;
static
size_
t
last_sent
;
public:
public:
static
bool
StartServer
(
unsigned
short
port
);
static
bool
StartServer
(
unsigned
short
port
);
...
@@ -38,20 +38,19 @@ public:
...
@@ -38,20 +38,19 @@ public:
static
size_t
CreateChatPacket
(
unsigned
char
*
src
,
int
src_size
,
unsigned
char
*
dst
,
uint16_t
dst_player_type
);
static
size_t
CreateChatPacket
(
unsigned
char
*
src
,
int
src_size
,
unsigned
char
*
dst
,
uint16_t
dst_player_type
);
static
void
SendPacketToPlayer
(
DuelPlayer
*
dp
,
unsigned
char
proto
)
{
static
void
SendPacketToPlayer
(
DuelPlayer
*
dp
,
unsigned
char
proto
)
{
auto
p
=
net_server_write
;
auto
p
=
net_server_write
;
BufferIO
::
WriteInt16
(
p
,
1
);
buffer_write
<
uint16_t
>
(
p
,
1
);
BufferIO
::
WriteInt8
(
p
,
proto
);
buffer_write
<
uint8_t
>
(
p
,
proto
);
last_sent
=
3
;
last_sent
=
3
;
if
(
!
dp
)
if
(
dp
)
return
;
bufferevent_write
(
dp
->
bev
,
net_server_write
,
3
);
bufferevent_write
(
dp
->
bev
,
net_server_write
,
3
);
}
}
template
<
typename
ST
>
template
<
typename
ST
>
static
void
SendPacketToPlayer
(
DuelPlayer
*
dp
,
unsigned
char
proto
,
ST
&
st
)
{
static
void
SendPacketToPlayer
(
DuelPlayer
*
dp
,
unsigned
char
proto
,
ST
&
st
)
{
auto
p
=
net_server_write
;
auto
p
=
net_server_write
;
if
(
(
int
)
sizeof
(
ST
)
>
MAX_DATA_SIZE
)
if
(
sizeof
(
ST
)
>
MAX_DATA_SIZE
)
return
;
return
;
BufferIO
::
WriteInt16
(
p
,
(
shor
t
)(
1
+
sizeof
(
ST
)));
buffer_write
<
uint16_t
>
(
p
,
(
uint16_
t
)(
1
+
sizeof
(
ST
)));
BufferIO
::
WriteInt8
(
p
,
proto
);
buffer_write
<
uint8_t
>
(
p
,
proto
);
std
::
memcpy
(
p
,
&
st
,
sizeof
(
ST
));
std
::
memcpy
(
p
,
&
st
,
sizeof
(
ST
));
last_sent
=
sizeof
(
ST
)
+
3
;
last_sent
=
sizeof
(
ST
)
+
3
;
if
(
dp
)
if
(
dp
)
...
@@ -59,17 +58,14 @@ public:
...
@@ -59,17 +58,14 @@ public:
}
}
static
void
SendBufferToPlayer
(
DuelPlayer
*
dp
,
unsigned
char
proto
,
void
*
buffer
,
size_t
len
)
{
static
void
SendBufferToPlayer
(
DuelPlayer
*
dp
,
unsigned
char
proto
,
void
*
buffer
,
size_t
len
)
{
auto
p
=
net_server_write
;
auto
p
=
net_server_write
;
int
blen
=
len
;
if
(
len
>
MAX_DATA_SIZE
)
if
(
blen
<
0
)
len
=
MAX_DATA_SIZE
;
return
;
buffer_write
<
uint16_t
>
(
p
,
(
uint16_t
)(
1
+
len
));
if
(
blen
>
MAX_DATA_SIZE
)
buffer_write
<
uint8_t
>
(
p
,
proto
);
blen
=
MAX_DATA_SIZE
;
std
::
memcpy
(
p
,
buffer
,
len
);
BufferIO
::
WriteInt16
(
p
,
(
short
)(
1
+
blen
));
last_sent
=
len
+
3
;
BufferIO
::
WriteInt8
(
p
,
proto
);
std
::
memcpy
(
p
,
buffer
,
blen
);
last_sent
=
blen
+
3
;
if
(
dp
)
if
(
dp
)
bufferevent_write
(
dp
->
bev
,
net_server_write
,
b
len
+
3
);
bufferevent_write
(
dp
->
bev
,
net_server_write
,
len
+
3
);
}
}
static
void
ReSendToPlayer
(
DuelPlayer
*
dp
)
{
static
void
ReSendToPlayer
(
DuelPlayer
*
dp
)
{
if
(
dp
)
if
(
dp
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment