perf(lib): weed sappyou before shoppyou
This commit is contained in:
parent
94aa958471
commit
5daa0db847
@ -65,28 +65,6 @@ int tanabata_weed(Tanabata *tanabata) {
|
||||
tanabata->sasahyou.database = realloc(tanabata->sasahyou.database, tanabata->sasahyou.size * sizeof(Sasa));
|
||||
tanabata->sasahyou.modified_ts = time(NULL);
|
||||
}
|
||||
hole_cnt = 0;
|
||||
current_kazari = tanabata->shoppyou.database;
|
||||
for (uint64_t i = 0; i < tanabata->shoppyou.size; i++) {
|
||||
if (current_kazari->sasa_id != HOLE_ID && current_kazari->tanzaku_id != HOLE_ID &&
|
||||
current_kazari->sasa_id < tanabata->sasahyou.size &&
|
||||
current_kazari->tanzaku_id < tanabata->sappyou.size) {
|
||||
if (hole_cnt > 0) {
|
||||
*(current_kazari - hole_cnt) = *current_kazari;
|
||||
}
|
||||
} else {
|
||||
hole_cnt++;
|
||||
}
|
||||
current_kazari++;
|
||||
}
|
||||
if (hole_cnt > 0) {
|
||||
tanabata->shoppyou.size -= tanabata->shoppyou.hole_cnt;
|
||||
tanabata->shoppyou.hole_cnt = 0;
|
||||
free(tanabata->shoppyou.holes);
|
||||
tanabata->shoppyou.database = realloc(tanabata->shoppyou.database, tanabata->shoppyou.size * sizeof(Kazari));
|
||||
tanabata->shoppyou.modified_ts = time(NULL);
|
||||
}
|
||||
if (tanabata->sappyou.hole_cnt > 0) {
|
||||
hole_cnt = 0;
|
||||
Tanzaku *current_tanzaku = tanabata->sappyou.database;
|
||||
for (uint64_t i = 0; i < tanabata->sappyou.size; i++) {
|
||||
@ -107,12 +85,34 @@ int tanabata_weed(Tanabata *tanabata) {
|
||||
}
|
||||
current_tanzaku++;
|
||||
}
|
||||
if (hole_cnt > 0) {
|
||||
tanabata->sappyou.size -= tanabata->sappyou.hole_cnt;
|
||||
tanabata->sappyou.hole_cnt = 0;
|
||||
free(tanabata->sappyou.holes);
|
||||
tanabata->sappyou.database = realloc(tanabata->sappyou.database, tanabata->sappyou.size * sizeof(Tanzaku));
|
||||
tanabata->sappyou.modified_ts = time(NULL);
|
||||
}
|
||||
hole_cnt = 0;
|
||||
current_kazari = tanabata->shoppyou.database;
|
||||
for (uint64_t i = 0; i < tanabata->shoppyou.size; i++) {
|
||||
if (current_kazari->sasa_id != HOLE_ID && current_kazari->tanzaku_id != HOLE_ID &&
|
||||
current_kazari->sasa_id < tanabata->sasahyou.size &&
|
||||
current_kazari->tanzaku_id < tanabata->sappyou.size) {
|
||||
if (hole_cnt > 0) {
|
||||
*(current_kazari - hole_cnt) = *current_kazari;
|
||||
}
|
||||
} else {
|
||||
hole_cnt++;
|
||||
}
|
||||
current_kazari++;
|
||||
}
|
||||
if (hole_cnt > 0) {
|
||||
tanabata->shoppyou.size -= tanabata->shoppyou.hole_cnt;
|
||||
tanabata->shoppyou.hole_cnt = 0;
|
||||
free(tanabata->shoppyou.holes);
|
||||
tanabata->shoppyou.database = realloc(tanabata->shoppyou.database, tanabata->shoppyou.size * sizeof(Kazari));
|
||||
tanabata->shoppyou.modified_ts = time(NULL);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user