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
da4aac8b
Commit
da4aac8b
authored
May 11, 2012
by
argon.sun
Browse files
Options
Browse Files
Download
Plain Diff
merge
parents
f23cbe45
a1621ee4
Changes
19
Hide whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
122 additions
and
97 deletions
+122
-97
gframe/duelclient.cpp
gframe/duelclient.cpp
+21
-20
gframe/replay_mode.cpp
gframe/replay_mode.cpp
+1
-1
gframe/single_duel.cpp
gframe/single_duel.cpp
+3
-7
gframe/tag_duel.cpp
gframe/tag_duel.cpp
+50
-46
gframe/tag_duel.h
gframe/tag_duel.h
+1
-1
ocgcore/field.cpp
ocgcore/field.cpp
+4
-10
ocgcore/ocgapi.cpp
ocgcore/ocgapi.cpp
+24
-0
ocgcore/processor.cpp
ocgcore/processor.cpp
+2
-2
script/c31768112.lua
script/c31768112.lua
+1
-1
script/c32391631.lua
script/c32391631.lua
+1
-1
script/c39695323.lua
script/c39695323.lua
+1
-0
script/c48686504.lua
script/c48686504.lua
+2
-1
script/c4906301.lua
script/c4906301.lua
+1
-1
script/c55501446.lua
script/c55501446.lua
+1
-1
script/c73417207.lua
script/c73417207.lua
+1
-1
script/c79229522.lua
script/c79229522.lua
+1
-1
script/c93542102.lua
script/c93542102.lua
+1
-1
script/c93717133.lua
script/c93717133.lua
+2
-2
system.conf
system.conf
+4
-0
No files found.
gframe/duelclient.cpp
View file @
da4aac8b
...
...
@@ -2576,25 +2576,23 @@ int DuelClient::ClientAnalyze(char* msg, unsigned int len) {
int
ecount
=
BufferIO
::
ReadInt8
(
pbuf
);
int
hcount
=
BufferIO
::
ReadInt8
(
pbuf
);
int
topcode
=
BufferIO
::
ReadInt32
(
pbuf
);
for
(
int
i
=
0
;
i
<
mainGame
->
dField
.
deck
[
player
].
size
();
++
i
)
mainGame
->
dField
.
deck
[
player
][
i
]
->
code
=
0
;
for
(
auto
cit
=
mainGame
->
dField
.
deck
[
player
].
begin
();
cit
!=
mainGame
->
dField
.
deck
[
player
].
end
();
++
cit
)
{
if
(
player
==
0
)
(
*
cit
)
->
dPos
.
Y
=
1.0
f
;
else
(
*
cit
)
->
dPos
.
Y
=
-
1.0
f
;
if
(
player
==
0
)
(
*
cit
)
->
dPos
.
Y
=
0.4
f
;
else
(
*
cit
)
->
dPos
.
Y
=
-
0.4
f
;
(
*
cit
)
->
dRot
=
irr
::
core
::
vector3df
(
0
,
0
,
0
);
(
*
cit
)
->
is_moving
=
true
;
(
*
cit
)
->
aniFrame
=
5
;
}
for
(
auto
cit
=
mainGame
->
dField
.
hand
[
player
].
begin
();
cit
!=
mainGame
->
dField
.
hand
[
player
].
end
();
++
cit
)
{
if
(
player
==
0
)
(
*
cit
)
->
dPos
.
Y
=
1.0
f
;
else
(
*
cit
)
->
dPos
.
Y
=
-
1.0
f
;
if
(
player
==
0
)
(
*
cit
)
->
dPos
.
Y
=
0.4
f
;
else
(
*
cit
)
->
dPos
.
Y
=
-
0.4
f
;
(
*
cit
)
->
dRot
=
irr
::
core
::
vector3df
(
0
,
0
,
0
);
(
*
cit
)
->
is_moving
=
true
;
(
*
cit
)
->
aniFrame
=
5
;
}
for
(
auto
cit
=
mainGame
->
dField
.
extra
[
player
].
begin
();
cit
!=
mainGame
->
dField
.
extra
[
player
].
end
();
++
cit
)
{
if
(
player
==
0
)
(
*
cit
)
->
dPos
.
Y
=
1.0
f
;
else
(
*
cit
)
->
dPos
.
Y
=
-
1.0
f
;
if
(
player
==
0
)
(
*
cit
)
->
dPos
.
Y
=
0.4
f
;
else
(
*
cit
)
->
dPos
.
Y
=
-
0.4
f
;
(
*
cit
)
->
dRot
=
irr
::
core
::
vector3df
(
0
,
0
,
0
);
(
*
cit
)
->
is_moving
=
true
;
(
*
cit
)
->
aniFrame
=
5
;
...
...
@@ -2617,14 +2615,14 @@ int DuelClient::ClientAnalyze(char* msg, unsigned int len) {
mainGame
->
dField
.
deck
[
player
].
push_back
(
ccard
);
}
}
if
(
mainGame
->
dField
.
hand
[
player
].
size
()
>
m
count
)
{
for
(
int
i
=
0
;
i
<
mainGame
->
dField
.
hand
[
player
].
size
()
-
m
count
;
++
i
)
{
if
(
mainGame
->
dField
.
hand
[
player
].
size
()
>
h
count
)
{
for
(
int
i
=
0
;
i
<
mainGame
->
dField
.
hand
[
player
].
size
()
-
h
count
;
++
i
)
{
ClientCard
*
ccard
=
*
mainGame
->
dField
.
hand
[
player
].
rbegin
();
mainGame
->
dField
.
hand
[
player
].
pop_back
();
delete
ccard
;
}
}
else
{
for
(
int
i
=
0
;
i
<
m
count
-
mainGame
->
dField
.
hand
[
player
].
size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
h
count
-
mainGame
->
dField
.
hand
[
player
].
size
();
++
i
)
{
ClientCard
*
ccard
=
new
ClientCard
();
ccard
->
controler
=
player
;
ccard
->
location
=
LOCATION_HAND
;
...
...
@@ -2632,14 +2630,14 @@ int DuelClient::ClientAnalyze(char* msg, unsigned int len) {
mainGame
->
dField
.
hand
[
player
].
push_back
(
ccard
);
}
}
if
(
mainGame
->
dField
.
extra
[
player
].
size
()
>
m
count
)
{
for
(
int
i
=
0
;
i
<
mainGame
->
dField
.
extra
[
player
].
size
()
-
m
count
;
++
i
)
{
if
(
mainGame
->
dField
.
extra
[
player
].
size
()
>
e
count
)
{
for
(
int
i
=
0
;
i
<
mainGame
->
dField
.
extra
[
player
].
size
()
-
e
count
;
++
i
)
{
ClientCard
*
ccard
=
*
mainGame
->
dField
.
extra
[
player
].
rbegin
();
mainGame
->
dField
.
extra
[
player
].
pop_back
();
delete
ccard
;
}
}
else
{
for
(
int
i
=
0
;
i
<
m
count
-
mainGame
->
dField
.
extra
[
player
].
size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
e
count
-
mainGame
->
dField
.
extra
[
player
].
size
();
++
i
)
{
ClientCard
*
ccard
=
new
ClientCard
();
ccard
->
controler
=
player
;
ccard
->
location
=
LOCATION_EXTRA
;
...
...
@@ -2652,22 +2650,25 @@ int DuelClient::ClientAnalyze(char* msg, unsigned int len) {
for
(
auto
cit
=
mainGame
->
dField
.
deck
[
player
].
begin
();
cit
!=
mainGame
->
dField
.
deck
[
player
].
end
();
++
cit
)
{
ClientCard
*
pcard
=
*
cit
;
mainGame
->
dField
.
GetCardLocation
(
pcard
,
&
pcard
->
curPos
,
&
pcard
->
curRot
);
if
(
player
==
0
)
pcard
->
curPos
.
Y
+=
5
.0
f
;
else
pcard
->
curPos
.
Y
-=
5
.0
f
;
if
(
player
==
0
)
pcard
->
curPos
.
Y
+=
2
.0
f
;
else
pcard
->
curPos
.
Y
-=
2
.0
f
;
mainGame
->
dField
.
MoveCard
(
*
cit
,
5
);
}
if
(
mainGame
->
dField
.
deck
[
player
].
size
())
(
*
mainGame
->
dField
.
deck
[
player
].
rbegin
())
->
code
=
topcode
;
for
(
auto
cit
=
mainGame
->
dField
.
hand
[
player
].
begin
();
cit
!=
mainGame
->
dField
.
hand
[
player
].
end
();
++
cit
)
{
ClientCard
*
pcard
=
*
cit
;
pcard
->
code
=
BufferIO
::
ReadInt32
(
pbuf
);
mainGame
->
dField
.
GetCardLocation
(
pcard
,
&
pcard
->
curPos
,
&
pcard
->
curRot
);
if
(
player
==
0
)
pcard
->
curPos
.
Y
+=
5
.0
f
;
else
pcard
->
curPos
.
Y
-=
5
.0
f
;
if
(
player
==
0
)
pcard
->
curPos
.
Y
+=
2
.0
f
;
else
pcard
->
curPos
.
Y
-=
2
.0
f
;
mainGame
->
dField
.
MoveCard
(
*
cit
,
5
);
}
for
(
auto
cit
=
mainGame
->
dField
.
extra
[
player
].
begin
();
cit
!=
mainGame
->
dField
.
extra
[
player
].
end
();
++
cit
)
{
ClientCard
*
pcard
=
*
cit
;
mainGame
->
dField
.
GetCardLocation
(
pcard
,
&
pcard
->
curPos
,
&
pcard
->
curRot
);
if
(
player
==
0
)
pcard
->
curPos
.
Y
+=
5
.0
f
;
else
pcard
->
curPos
.
Y
-=
5
.0
f
;
if
(
player
==
0
)
pcard
->
curPos
.
Y
+=
2
.0
f
;
else
pcard
->
curPos
.
Y
-=
2
.0
f
;
mainGame
->
dField
.
MoveCard
(
*
cit
,
5
);
}
mainGame
->
WaitFrameSignal
(
5
);
...
...
gframe/replay_mode.cpp
View file @
da4aac8b
...
...
@@ -596,7 +596,7 @@ bool ReplayMode::ReplayAnalyze(char* msg, unsigned int len) {
break
;
}
case
MSG_TAG_SWAP
:
{
pbuf
+=
pbuf
[
4
]
*
4
+
8
;
pbuf
+=
pbuf
[
3
]
*
4
+
8
;
DuelClient
::
ClientAnalyze
(
offset
,
pbuf
-
offset
);
break
;
}
...
...
gframe/single_duel.cpp
View file @
da4aac8b
...
...
@@ -380,15 +380,11 @@ void SingleDuel::TPResult(DuelPlayer* dp, unsigned char tp) {
if
(
!
host_info
.
no_shuffle_deck
)
{
for
(
int
i
=
0
;
i
<
pdeck
[
0
].
main
.
size
();
++
i
)
{
int
swap
=
rnd
.
real
()
*
pdeck
[
0
].
main
.
size
();
auto
tmp
=
pdeck
[
0
].
main
[
i
];
pdeck
[
0
].
main
[
i
]
=
pdeck
[
0
].
main
[
swap
];
pdeck
[
0
].
main
[
swap
]
=
tmp
;
std
::
swap
(
pdeck
[
0
].
main
[
i
],
pdeck
[
0
].
main
[
swap
]);
}
for
(
int
i
=
0
;
i
<
pdeck
[
1
].
main
.
size
();
++
i
)
{
int
swap
=
rnd
.
real
()
*
pdeck
[
1
].
main
.
size
();
auto
tmp
=
pdeck
[
1
].
main
[
i
];
pdeck
[
1
].
main
[
i
]
=
pdeck
[
1
].
main
[
swap
];
pdeck
[
1
].
main
[
swap
]
=
tmp
;
std
::
swap
(
pdeck
[
1
].
main
[
i
],
pdeck
[
1
].
main
[
swap
]);
}
}
time_limit
[
0
]
=
host_info
.
time_limit
;
...
...
@@ -1082,7 +1078,7 @@ int SingleDuel::Analyze(char* msgbuffer, unsigned int len) {
pbuf
+=
count
*
4
;
NetServer
::
SendBufferToPlayer
(
players
[
player
],
STOC_GAME_MSG
,
offset
,
pbuf
-
offset
);
for
(
int
i
=
0
;
i
<
count
;
++
i
)
{
if
(
!
(
pbufw
[
i
]
&
0x8000000
0
))
if
(
!
(
pbufw
[
3
]
&
0x8
0
))
BufferIO
::
WriteInt32
(
pbufw
,
0
);
else
pbufw
+=
4
;
...
...
gframe/tag_duel.cpp
View file @
da4aac8b
...
...
@@ -99,11 +99,11 @@ void TagDuel::JoinGame(DuelPlayer* dp, void* pdata, bool is_creater) {
if
(
players
[
i
])
{
STOC_HS_PlayerEnter
scpe
;
BufferIO
::
CopyWStr
(
players
[
i
]
->
name
,
scpe
.
name
,
20
);
scpe
.
pos
=
0
;
scpe
.
pos
=
i
;
NetServer
::
SendPacketToPlayer
(
dp
,
STOC_HS_PLAYER_ENTER
,
scpe
);
if
(
ready
[
i
])
{
STOC_HS_PlayerChange
scpc
;
scpc
.
status
=
PLAYERCHANGE_READY
;
scpc
.
status
=
(
i
<<
4
)
|
PLAYERCHANGE_READY
;
NetServer
::
SendPacketToPlayer
(
dp
,
STOC_HS_PLAYER_CHANGE
,
scpc
);
}
}
...
...
@@ -182,7 +182,7 @@ void TagDuel::ToDuelist(DuelPlayer* dp) {
return
;
uint8
dptype
=
(
dp
->
type
+
1
)
%
4
;
while
(
players
[
dptype
])
dptype
=
(
dp
->
type
+
1
)
%
4
;
dptype
=
(
dptype
+
1
)
%
4
;
STOC_HS_PlayerChange
scpc
;
scpc
.
status
=
(
dp
->
type
<<
4
)
|
dptype
;
for
(
int
i
=
0
;
i
<
4
;
++
i
)
...
...
@@ -304,14 +304,12 @@ void TagDuel::HandResult(DuelPlayer* dp, unsigned char res) {
||
(
hand_result
[
0
]
==
2
&&
hand_result
[
1
]
==
3
)
||
(
hand_result
[
0
]
==
3
&&
hand_result
[
1
]
==
1
))
{
NetServer
::
SendPacketToPlayer
(
players
[
2
],
CTOS_TP_RESULT
);
tp_player
=
1
;
players
[
0
]
->
state
=
0xff
;
players
[
2
]
->
state
=
CTOS_TP_RESULT
;
}
else
{
NetServer
::
SendPacketToPlayer
(
players
[
0
],
CTOS_TP_RESULT
);
players
[
2
]
->
state
=
0xff
;
players
[
0
]
->
state
=
CTOS_TP_RESULT
;
tp_player
=
0
;
}
}
}
...
...
@@ -335,8 +333,8 @@ void TagDuel::TPResult(DuelPlayer* dp, unsigned char tp) {
std
::
swap
(
pdeck
[
1
],
pdeck
[
3
]);
swapped
=
true
;
}
t
p_player
=
0
;
cur_player
[
0
]
=
players
[
1
];
t
urn_count
=
0
;
cur_player
[
0
]
=
players
[
0
];
cur_player
[
1
]
=
players
[
3
];
dp
->
state
=
CTOS_RESPONSE
;
ReplayHeader
rh
;
...
...
@@ -353,15 +351,19 @@ void TagDuel::TPResult(DuelPlayer* dp, unsigned char tp) {
if
(
!
host_info
.
no_shuffle_deck
)
{
for
(
int
i
=
0
;
i
<
pdeck
[
0
].
main
.
size
();
++
i
)
{
int
swap
=
rnd
.
real
()
*
pdeck
[
0
].
main
.
size
();
auto
tmp
=
pdeck
[
0
].
main
[
i
];
pdeck
[
0
].
main
[
i
]
=
pdeck
[
0
].
main
[
swap
];
pdeck
[
0
].
main
[
swap
]
=
tmp
;
std
::
swap
(
pdeck
[
0
].
main
[
i
],
pdeck
[
0
].
main
[
swap
]);
}
for
(
int
i
=
0
;
i
<
pdeck
[
1
].
main
.
size
();
++
i
)
{
int
swap
=
rnd
.
real
()
*
pdeck
[
1
].
main
.
size
();
auto
tmp
=
pdeck
[
1
].
main
[
i
];
pdeck
[
1
].
main
[
i
]
=
pdeck
[
1
].
main
[
swap
];
pdeck
[
1
].
main
[
swap
]
=
tmp
;
std
::
swap
(
pdeck
[
1
].
main
[
i
],
pdeck
[
1
].
main
[
swap
]);
}
for
(
int
i
=
0
;
i
<
pdeck
[
2
].
main
.
size
();
++
i
)
{
int
swap
=
rnd
.
real
()
*
pdeck
[
2
].
main
.
size
();
std
::
swap
(
pdeck
[
2
].
main
[
i
],
pdeck
[
2
].
main
[
swap
]);
}
for
(
int
i
=
0
;
i
<
pdeck
[
3
].
main
.
size
();
++
i
)
{
int
swap
=
rnd
.
real
()
*
pdeck
[
3
].
main
.
size
();
std
::
swap
(
pdeck
[
3
].
main
[
i
],
pdeck
[
3
].
main
[
swap
]);
}
}
time_limit
[
0
]
=
host_info
.
time_limit
;
...
...
@@ -406,27 +408,27 @@ void TagDuel::TPResult(DuelPlayer* dp, unsigned char tp) {
last_replay
.
WriteInt32
(
pdeck
[
1
].
extra
[
i
]
->
first
,
false
);
}
//
last_replay
.
WriteInt32
(
pdeck
[
2
].
main
.
size
(),
false
);
for
(
int
i
=
pdeck
[
2
].
main
.
size
()
-
1
;
i
>=
0
;
--
i
)
{
new_card
(
pduel
,
pdeck
[
2
].
main
[
i
]
->
first
,
1
,
1
,
LOCATION_DECK
,
0
,
0
);
last_replay
.
WriteInt32
(
pdeck
[
2
].
main
[
i
]
->
first
,
false
);
}
last_replay
.
WriteInt32
(
pdeck
[
2
].
extra
.
size
(),
false
);
for
(
int
i
=
pdeck
[
2
].
extra
.
size
()
-
1
;
i
>=
0
;
--
i
)
{
new_card
(
pduel
,
pdeck
[
2
].
extra
[
i
]
->
first
,
1
,
1
,
LOCATION_EXTRA
,
0
,
0
);
last_replay
.
WriteInt32
(
pdeck
[
2
].
extra
[
i
]
->
first
,
false
);
}
//
last_replay
.
WriteInt32
(
pdeck
[
3
].
main
.
size
(),
false
);
for
(
int
i
=
pdeck
[
3
].
main
.
size
()
-
1
;
i
>=
0
;
--
i
)
{
new_
tag_card
(
pduel
,
pdeck
[
3
].
main
[
i
]
->
first
,
0
,
LOCATION_DECK
);
new_
card
(
pduel
,
pdeck
[
3
].
main
[
i
]
->
first
,
1
,
1
,
LOCATION_DECK
,
0
,
0
);
last_replay
.
WriteInt32
(
pdeck
[
3
].
main
[
i
]
->
first
,
false
);
}
last_replay
.
WriteInt32
(
pdeck
[
3
].
extra
.
size
(),
false
);
for
(
int
i
=
pdeck
[
3
].
extra
.
size
()
-
1
;
i
>=
0
;
--
i
)
{
new_
tag_card
(
pduel
,
pdeck
[
3
].
extra
[
i
]
->
first
,
0
,
LOCATION_EXTRA
);
new_
card
(
pduel
,
pdeck
[
3
].
extra
[
i
]
->
first
,
1
,
1
,
LOCATION_EXTRA
,
0
,
0
);
last_replay
.
WriteInt32
(
pdeck
[
3
].
extra
[
i
]
->
first
,
false
);
}
//
last_replay
.
WriteInt32
(
pdeck
[
2
].
main
.
size
(),
false
);
for
(
int
i
=
pdeck
[
2
].
main
.
size
()
-
1
;
i
>=
0
;
--
i
)
{
new_tag_card
(
pduel
,
pdeck
[
2
].
main
[
i
]
->
first
,
1
,
LOCATION_DECK
);
last_replay
.
WriteInt32
(
pdeck
[
2
].
main
[
i
]
->
first
,
false
);
}
last_replay
.
WriteInt32
(
pdeck
[
2
].
extra
.
size
(),
false
);
for
(
int
i
=
pdeck
[
2
].
extra
.
size
()
-
1
;
i
>=
0
;
--
i
)
{
new_tag_card
(
pduel
,
pdeck
[
2
].
extra
[
i
]
->
first
,
1
,
LOCATION_EXTRA
);
last_replay
.
WriteInt32
(
pdeck
[
2
].
extra
[
i
]
->
first
,
false
);
}
last_replay
.
Flush
();
char
startbuf
[
32
],
*
pbuf
=
startbuf
;
BufferIO
::
WriteInt8
(
pbuf
,
MSG_START
);
...
...
@@ -773,12 +775,6 @@ int TagDuel::Analyze(char* msgbuffer, unsigned int len) {
break
;
}
case
MSG_NEW_TURN
:
{
RefreshMzone
(
0
);
RefreshMzone
(
1
);
RefreshSzone
(
0
);
RefreshSzone
(
1
);
RefreshHand
(
0
);
RefreshHand
(
1
);
pbuf
++
;
time_limit
[
0
]
=
host_info
.
time_limit
;
time_limit
[
1
]
=
host_info
.
time_limit
;
...
...
@@ -788,18 +784,26 @@ int TagDuel::Analyze(char* msgbuffer, unsigned int len) {
NetServer
::
ReSendToPlayer
(
players
[
3
]);
for
(
auto
oit
=
observers
.
begin
();
oit
!=
observers
.
end
();
++
oit
)
NetServer
::
ReSendToPlayer
(
*
oit
);
if
(
tp_player
==
0
)
{
if
(
cur_player
[
0
]
==
players
[
0
])
cur_player
[
0
]
=
players
[
1
];
else
cur_player
[
0
]
=
players
[
0
];
}
else
{
if
(
cur_player
[
1
]
==
players
[
2
])
cur_player
[
1
]
=
players
[
3
];
else
cur_player
[
1
]
=
players
[
2
];
if
(
turn_count
>
0
)
{
if
(
turn_count
%
2
==
0
)
{
if
(
cur_player
[
0
]
==
players
[
0
])
cur_player
[
0
]
=
players
[
1
];
else
cur_player
[
0
]
=
players
[
0
];
}
else
{
if
(
cur_player
[
1
]
==
players
[
2
])
cur_player
[
1
]
=
players
[
3
];
else
cur_player
[
1
]
=
players
[
2
];
}
}
tp_player
=
1
-
tp_player
;
turn_count
++
;
RefreshMzone
(
0
);
RefreshMzone
(
1
);
RefreshSzone
(
0
);
RefreshSzone
(
1
);
RefreshHand
(
0
);
RefreshHand
(
1
);
break
;
}
case
MSG_NEW_PHASE
:
{
...
...
@@ -1092,7 +1096,7 @@ int TagDuel::Analyze(char* msgbuffer, unsigned int len) {
pbuf
+=
count
*
4
;
NetServer
::
SendBufferToPlayer
(
cur_player
[
player
],
STOC_GAME_MSG
,
offset
,
pbuf
-
offset
);
for
(
int
i
=
0
;
i
<
count
;
++
i
)
{
if
(
!
(
pbufw
[
i
]
&
0x8000000
0
))
if
(
!
(
pbufw
[
3
]
&
0x8
0
))
BufferIO
::
WriteInt32
(
pbufw
,
0
);
else
pbufw
+=
4
;
...
...
@@ -1332,7 +1336,7 @@ int TagDuel::Analyze(char* msgbuffer, unsigned int len) {
pbuf
+=
hcount
*
4
+
4
;
NetServer
::
SendBufferToPlayer
(
cur_player
[
player
],
STOC_GAME_MSG
,
offset
,
pbuf
-
offset
);
for
(
int
i
=
0
;
i
<
hcount
;
++
i
)
{
if
(
!
(
pbufw
[
i
]
&
0x8000000
0
))
if
(
!
(
pbufw
[
3
]
&
0x8
0
))
BufferIO
::
WriteInt32
(
pbufw
,
0
);
else
pbufw
+=
4
;
...
...
@@ -1403,7 +1407,7 @@ void TagDuel::WaitforResponse(int playerid) {
void
TagDuel
::
TimeConfirm
(
DuelPlayer
*
dp
)
{
if
(
host_info
.
time_limit
==
0
)
return
;
if
(
dp
->
type
!=
last_response
)
if
(
dp
!=
cur_player
[
last_response
]
)
return
;
cur_player
[
last_response
]
->
state
=
CTOS_RESPONSE
;
time_elapsed
=
0
;
...
...
gframe/tag_duel.h
View file @
da4aac8b
...
...
@@ -51,7 +51,7 @@ protected:
unsigned
char
hand_result
[
2
];
unsigned
char
last_response
;
Replay
last_replay
;
unsigned
char
t
p_player
;
unsigned
char
t
urn_count
;
unsigned
short
time_limit
[
2
];
unsigned
short
time_elapsed
;
};
...
...
ocgcore/field.cpp
View file @
da4aac8b
...
...
@@ -552,9 +552,7 @@ void field::tag_swap(uint8 playerid) {
(
*
clit
)
->
enable_field_effect
(
false
);
(
*
clit
)
->
cancel_field_effect
();
}
card_vector
cl
=
player
[
playerid
].
list_grave
;
player
[
playerid
].
list_main
=
player
[
playerid
].
tag_list_main
;
player
[
playerid
].
list_main
=
cl
;
std
::
swap
(
player
[
playerid
].
list_main
,
player
[
playerid
].
tag_list_main
);
for
(
clit
=
player
[
playerid
].
list_main
.
begin
();
clit
!=
player
[
playerid
].
list_main
.
end
();
++
clit
)
{
(
*
clit
)
->
apply_field_effect
();
(
*
clit
)
->
enable_field_effect
(
true
);
...
...
@@ -564,9 +562,7 @@ void field::tag_swap(uint8 playerid) {
(
*
clit
)
->
enable_field_effect
(
false
);
(
*
clit
)
->
cancel_field_effect
();
}
cl
=
player
[
playerid
].
list_grave
;
player
[
playerid
].
list_hand
=
player
[
playerid
].
tag_list_hand
;
player
[
playerid
].
list_hand
=
cl
;
std
::
swap
(
player
[
playerid
].
list_hand
,
player
[
playerid
].
tag_list_hand
);
for
(
clit
=
player
[
playerid
].
list_hand
.
begin
();
clit
!=
player
[
playerid
].
list_hand
.
end
();
++
clit
)
{
(
*
clit
)
->
apply_field_effect
();
(
*
clit
)
->
enable_field_effect
(
true
);
...
...
@@ -576,9 +572,7 @@ void field::tag_swap(uint8 playerid) {
(
*
clit
)
->
enable_field_effect
(
false
);
(
*
clit
)
->
cancel_field_effect
();
}
cl
=
player
[
playerid
].
list_grave
;
player
[
playerid
].
list_extra
=
player
[
playerid
].
tag_list_extra
;
player
[
playerid
].
list_extra
=
cl
;
std
::
swap
(
player
[
playerid
].
list_extra
,
player
[
playerid
].
tag_list_extra
);
for
(
clit
=
player
[
playerid
].
list_extra
.
begin
();
clit
!=
player
[
playerid
].
list_extra
.
end
();
++
clit
)
{
(
*
clit
)
->
apply_field_effect
();
(
*
clit
)
->
enable_field_effect
(
true
);
...
...
@@ -588,7 +582,7 @@ void field::tag_swap(uint8 playerid) {
pduel
->
write_buffer8
(
player
[
playerid
].
list_main
.
size
());
pduel
->
write_buffer8
(
player
[
playerid
].
list_extra
.
size
());
pduel
->
write_buffer8
(
player
[
playerid
].
list_hand
.
size
());
if
(
core
.
deck_reversed
)
if
(
core
.
deck_reversed
&&
player
[
playerid
].
list_main
.
size
()
)
pduel
->
write_buffer32
((
*
player
[
playerid
].
list_main
.
rbegin
())
->
data
.
code
);
else
pduel
->
write_buffer32
(
0
);
...
...
ocgcore/ocgapi.cpp
View file @
da4aac8b
...
...
@@ -77,6 +77,24 @@ extern "C" DECL_DLLEXPORT void start_duel(ptr pduel, int options) {
pd
->
game_field
->
draw
(
0
,
REASON_RULE
,
PLAYER_NONE
,
0
,
pd
->
game_field
->
player
[
0
].
start_count
);
if
(
pd
->
game_field
->
player
[
1
].
start_count
>
0
)
pd
->
game_field
->
draw
(
0
,
REASON_RULE
,
PLAYER_NONE
,
1
,
pd
->
game_field
->
player
[
1
].
start_count
);
if
(
options
&
DUEL_TAG_MODE
)
{
for
(
int
i
=
0
;
i
<
pd
->
game_field
->
player
[
0
].
start_count
&&
pd
->
game_field
->
player
[
0
].
tag_list_main
.
size
();
++
i
)
{
card
*
pcard
=
*
pd
->
game_field
->
player
[
0
].
tag_list_main
.
rbegin
();
pd
->
game_field
->
player
[
0
].
tag_list_main
.
pop_back
();
pd
->
game_field
->
player
[
0
].
tag_list_hand
.
push_back
(
pcard
);
pcard
->
current
.
controler
=
0
;
pcard
->
current
.
location
=
LOCATION_HAND
;
pcard
->
current
.
sequence
=
pd
->
game_field
->
player
[
0
].
tag_list_hand
.
size
()
-
1
;
}
for
(
int
i
=
0
;
i
<
pd
->
game_field
->
player
[
1
].
start_count
&&
pd
->
game_field
->
player
[
1
].
tag_list_main
.
size
();
++
i
)
{
card
*
pcard
=
*
pd
->
game_field
->
player
[
1
].
tag_list_main
.
rbegin
();
pd
->
game_field
->
player
[
1
].
tag_list_main
.
pop_back
();
pd
->
game_field
->
player
[
1
].
tag_list_hand
.
push_back
(
pcard
);
pcard
->
current
.
controler
=
1
;
pcard
->
current
.
location
=
LOCATION_HAND
;
pcard
->
current
.
sequence
=
pd
->
game_field
->
player
[
1
].
tag_list_hand
.
size
()
-
1
;
}
}
pd
->
game_field
->
add_process
(
PROCESSOR_TURN
,
0
,
0
,
0
,
0
,
0
);
}
extern
"C"
DECL_DLLEXPORT
void
end_duel
(
ptr
pduel
)
{
...
...
@@ -135,9 +153,15 @@ extern "C" DECL_DLLEXPORT void new_tag_card(ptr pduel, uint32 code, uint8 owner,
switch
(
location
)
{
case
LOCATION_DECK
:
ptduel
->
game_field
->
player
[
owner
].
tag_list_main
.
push_back
(
pcard
);
pcard
->
current
.
controler
=
owner
;
pcard
->
current
.
location
=
LOCATION_DECK
;
pcard
->
current
.
sequence
=
ptduel
->
game_field
->
player
[
owner
].
tag_list_main
.
size
()
-
1
;
break
;
case
LOCATION_EXTRA
:
ptduel
->
game_field
->
player
[
owner
].
tag_list_extra
.
push_back
(
pcard
);
pcard
->
current
.
controler
=
owner
;
pcard
->
current
.
location
=
LOCATION_EXTRA
;
pcard
->
current
.
sequence
=
ptduel
->
game_field
->
player
[
owner
].
tag_list_extra
.
size
()
-
1
;
break
;
}
}
...
...
ocgcore/processor.cpp
View file @
da4aac8b
...
...
@@ -3519,10 +3519,10 @@ int32 field::process_turn(uint16 step, uint8 turn_player) {
(
*
rit
)
->
recharge
();
infos
.
turn_id
++
;
infos
.
turn_player
=
turn_player
;
if
(
core
.
duel_options
&
DUEL_TAG_MODE
)
tag_swap
(
turn_player
);
pduel
->
write_buffer8
(
MSG_NEW_TURN
);
pduel
->
write_buffer8
(
turn_player
);
if
((
core
.
duel_options
&
DUEL_TAG_MODE
)
&&
infos
.
turn_id
!=
1
)
tag_swap
(
turn_player
);
if
(
is_player_affected_by_effect
(
infos
.
turn_player
,
EFFECT_SKIP_TURN
))
{
core
.
units
.
begin
()
->
step
=
17
;
reset_phase
(
PHASE_DRAW
);
...
...
script/c31768112.lua
View file @
da4aac8b
...
...
@@ -86,7 +86,7 @@ end
function
c31768112
.
spop
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
local
c
=
e
:
GetHandler
()
if
c
:
IsRelateToEffect
(
e
)
then
Duel
.
SpecialSummon
(
c
,
0
,
tp
,
tp
,
true
,
false
,
POS_FACEUP
)
Duel
.
SpecialSummon
(
c
,
0
,
tp
,
tp
,
true
,
false
,
POS_FACEUP
_ATTACK
)
end
end
function
c31768112
.
drcon
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
...
...
script/c32391631.lua
View file @
da4aac8b
...
...
@@ -55,7 +55,7 @@ function c32391631.recop(e,tp,eg,ep,ev,re,r,rp)
Duel
.
Recover
(
p
,
d
,
REASON_EFFECT
)
end
function
c32391631
.
becon
(
e
)
return
Duel
.
IsExistingMatchingCard
(
Card
.
IsAttack
Pos
able
,
Duel
.
GetTurnPlayer
(),
LOCATION_MZONE
,
0
,
1
,
nil
)
return
Duel
.
IsExistingMatchingCard
(
Card
.
IsAttackable
,
Duel
.
GetTurnPlayer
(),
LOCATION_MZONE
,
0
,
1
,
nil
)
end
function
c32391631
.
desfilter
(
c
)
return
c
:
IsPosition
(
POS_FACEUP_ATTACK
)
and
c
:
GetAttackedCount
()
==
0
and
c
:
IsDestructable
()
...
...
script/c39695323.lua
View file @
da4aac8b
...
...
@@ -35,6 +35,7 @@ function c39695323.spop(e,tp,eg,ep,ev,re,r,rp)
local
c
=
e
:
GetHandler
()
local
tc
=
Duel
.
GetFirstTarget
()
if
tc
:
IsRelateToEffect
(
e
)
and
Duel
.
SpecialSummon
(
tc
,
0
,
tp
,
tp
,
false
,
false
,
POS_FACEUP_DEFENCE
)
~=
0
then
Duel
.
BreakEffect
()
if
c
:
IsRelateToEffect
(
e
)
and
c
:
IsFaceup
()
then
Duel
.
ChangePosition
(
e
:
GetHandler
(),
POS_FACEUP_DEFENCE
)
end
...
...
script/c48686504.lua
View file @
da4aac8b
...
...
@@ -24,7 +24,8 @@ function c48686504.filter(c,e,tp)
return
c
:
IsRace
(
RACE_PLANT
)
and
c
:
IsCanBeSpecialSummoned
(
e
,
0
,
tp
,
false
,
false
)
end
function
c48686504
.
target
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
)
if
chk
==
0
then
return
Duel
.
IsExistingMatchingCard
(
c48686504
.
filter
,
tp
,
LOCATION_DECK
,
0
,
1
,
nil
,
e
,
tp
)
end
if
chk
==
0
then
return
Duel
.
GetLocationCount
(
tp
,
LOCATION_MZONE
)
>-
1
and
Duel
.
IsExistingMatchingCard
(
c48686504
.
filter
,
tp
,
LOCATION_DECK
,
0
,
1
,
nil
,
e
,
tp
)
end
Duel
.
SetOperationInfo
(
0
,
CATEGORY_SPECIAL_SUMMON
,
nil
,
1
,
0
,
LOCATION_DECK
)
end
function
c48686504
.
operation
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
...
...
script/c4906301.lua
View file @
da4aac8b
...
...
@@ -15,7 +15,7 @@ end
function
c4906301
.
condition
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
local
ph
=
Duel
.
GetCurrentPhase
()
return
Duel
.
GetTurnPlayer
()
~=
tp
and
ph
~=
PHASE_MAIN2
and
ph
~=
PHASE_END
and
Duel
.
IsExistingMatchingCard
(
Card
.
IsAttack
Pos
able
,
tp
,
0
,
LOCATION_MZONE
,
1
,
nil
)
and
Duel
.
IsExistingMatchingCard
(
Card
.
IsAttackable
,
tp
,
0
,
LOCATION_MZONE
,
1
,
nil
)
end
function
c4906301
.
cost
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
)
if
chk
==
0
then
return
e
:
GetHandler
():
IsAbleToRemoveAsCost
()
end
...
...
script/c55501446.lua
View file @
da4aac8b
...
...
@@ -5,7 +5,7 @@ function c55501446.initial_effect(c)
e1
:
SetDescription
(
aux
.
Stringid
(
55501446
,
0
))
e1
:
SetCategory
(
CATEGORY_SPECIAL_SUMMON
)
e1
:
SetType
(
EFFECT_TYPE_SINGLE
+
EFFECT_TYPE_TRIGGER_O
)
e1
:
SetProperty
(
EFFECT_FLAG_DELAY
)
e1
:
SetProperty
(
EFFECT_FLAG_DELAY
+
EFFECT_FLAG_DAMAGE_STEP
)
e1
:
SetCode
(
EVENT_TO_GRAVE
)
e1
:
SetCondition
(
c55501446
.
spcon
)
e1
:
SetTarget
(
c55501446
.
sptg
)
...
...
script/c73417207.lua
View file @
da4aac8b
...
...
@@ -23,7 +23,7 @@ function c73417207.target(e,syncard,f,minc,maxc)
end
function
c73417207
.
operation
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
syncard
,
f
,
minc
,
maxc
)
local
lv
=
syncard
:
GetLevel
()
-
e
:
GetHandler
():
GetLevel
()
local
g
=
Duel
.
GetMatchingGroup
(
c73417207
.
synfilter
,
syncard
:
GetControler
(),
LOCATION_HAND
,
LOCATION_HAND
,
c
,
syncard
,
f
)
local
g
=
Duel
.
GetMatchingGroup
(
c73417207
.
synfilter
,
syncard
:
GetControler
(),
LOCATION_HAND
,
0
,
c
,
syncard
,
f
)
local
sg
=
g
:
SelectWithSumEqual
(
tp
,
Card
.
GetSynchroLevel
,
lv
,
2
,
2
,
syncard
)
Duel
.
SetSynchroMaterial
(
sg
)
end
script/c79229522.lua
View file @
da4aac8b
...
...
@@ -54,7 +54,7 @@ function c79229522.sprop(e,tp,eg,ep,ev,re,r,rp,c)
local
e1
=
Effect
.
CreateEffect
(
c
)
e1
:
SetType
(
EFFECT_TYPE_SINGLE
)
e1
:
SetCode
(
EFFECT_SET_BASE_ATTACK
)
e1
:
SetReset
(
RESET_EVENT
+
0xf
e
0000
)
e1
:
SetReset
(
RESET_EVENT
+
0xf
f
0000
)
e1
:
SetValue
(
g1
:
GetCount
()
*
1000
)
c
:
RegisterEffect
(
e1
)
end
script/c93542102.lua
View file @
da4aac8b
...
...
@@ -32,7 +32,7 @@ function c93542102.cfilter(c)
return
c
:
IsLevelBelow
(
4
)
and
c
:
IsSetCard
(
0x26
)
and
c
:
IsType
(
TYPE_MONSTER
)
end
function
c93542102
.
tg
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
)
if
chk
==
0
then
return
Duel
.
GetFieldGroupCount
(
tp
,
LOCATION_DECK
,
0
)
>
0
if
chk
==
0
then
return
Duel
.
Get
LocationCount
(
tp
,
LOCATION_MZONE
)
>
0
and
Duel
.
Get
FieldGroupCount
(
tp
,
LOCATION_DECK
,
0
)
>
0
and
Duel
.
IsExistingMatchingCard
(
c93542102
.
cfilter
,
tp
,
LOCATION_DECK
,
0
,
1
,
nil
)
end
end
function
c93542102
.
filter
(
c
,
e
,
tp
)
...
...
script/c93717133.lua
View file @
da4aac8b
...
...
@@ -24,10 +24,10 @@ function c93717133.initial_effect(c)
end
function
c93717133
.
spcon
(
e
,
c
)
if
c
==
nil
then
return
true
end
return
Duel
.
CheckReleaseGroup
(
c
:
GetControler
(),
Card
.
IsAttack
Pos
Above
,
2
,
nil
,
2000
)
return
Duel
.
CheckReleaseGroup
(
c
:
GetControler
(),
Card
.
IsAttackAbove
,
2
,
nil
,
2000
)
end
function
c93717133
.
spop
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
c
)
local
g
=
Duel
.
SelectReleaseGroup
(
c
:
GetControler
(),
Card
.
IsAttack
Pos
Above
,
2
,
2
,
nil
,
2000
)
local
g
=
Duel
.
SelectReleaseGroup
(
c
:
GetControler
(),
Card
.
IsAttackAbove
,
2
,
2
,
nil
,
2000
)
Duel
.
Release
(
g
,
REASON_COST
)
end
function
c93717133
.
rmcon
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
...
...
system.conf
View file @
da4aac8b
...
...
@@ -9,5 +9,9 @@ lastdeck = T1
textfont
=
c
:/
windows
/
fonts
/
simsun
.
ttc
14
numfont
=
c
:/
windows
/
fonts
/
arialbd
.
ttf
serverport
=
7911
<<<<<<<
HEAD
lastip
=
192
.
168
.
2
.
100
=======
lastip
=
192
.
168
.
3
.
235
>>>>>>>
a1621ee4c3685938a41fc0922899db9827f882fe
lastport
=
7911
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