Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .jules/bolt.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,6 @@
## 2026-05-12 - [Remove Duplicate Static Initialization & Unsafe String Operations]
**Learning:** The previous optimization attempt introduced a bug where 'cached_nodes' was initialized twice as different types (one array of xml_node pointers, one array of const char*). Moreover, directly casting const char* returned from pugixml without assigning to std::string when used in ternary operations can cause operand type mismatches.
**Action:** Removed the redundant array initialization block and cast the char* obtained via `pt.text().get()` from the single cached xml_node array to `std::string` inside the ternary conditional to prevent implicit conversion mismatches.
## 2023-10-27 - [td_to_vakt ve simdiki_zaman_turk string atama optimizasyonu]
**Learning:** `std::string::append` metodu mevcut stringin sonuna ekleme yapar. Constructor'da (veya döngü içinde) sürekli `.append` kullanıldığında, her çağrıda string büyür ve hafıza (memory) sızıntısına/gereksiz tahsislere neden olur. Aynı zamanda yanlış mantıksal değer üretir. `std::string` atamalarında `=` operatörünü kullanmak ve `std::to_string` zincirlemesi yerine (örn: `std::to_string(saat) + ":" + std::to_string(dakika)`) `std::snprintf` ile sabit boyutlu stack buffer (char array) kullanmak, hem gereksiz hafıza tahsislerini (allocation) engeller hem de performansı artırır.
**Action:** Döngüsel olarak veya çok sık çağrılan fonksiyonlarda (örneğin class constructor'larında) `std::to_string` ve `+` (veya `.append`) yerine `std::snprintf` ve stack tabanlı `char` buffer'ları tercih edilmelidir. String değerlerini yenilerken `.append()` yerine her zaman doğrudan atama (`=`) kullanılmalıdır.
Binary file modified run_tests
Binary file not shown.
48 changes: 21 additions & 27 deletions src/src-class/Zaman.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,9 @@ unsigned int zaman::vakt_to_td(const std::string& vakt)

std::string zaman::td_to_vakt(unsigned int td)
{
return std::to_string(int(td / 60) % 12) + ":" + std::to_string(int(td % 60));
char buffer[6];
std::snprintf(buffer, sizeof(buffer), "%02d:%02d", int(td / 60) % 12, int(td % 60));
return std::string(buffer);
}

void zaman::vkt_h_v_d()
Expand Down Expand Up @@ -99,8 +101,6 @@ void zaman::vkt_h_v_d()
throw std::runtime_error("Missing cityinfo node");
}

// ⚡ Bolt Optimizasyonu: XML düğümlerini 'dayofyear' özniteliğine göre önbelleğe alarak O(1) erişim sağla (O(N) doğrusal arama yerine)
// Her nesne örneği oluşturulduğunda O(N) doğrusal arama darboğazını ortadan kaldırır
static pugi::xml_node nodes[400];
for (pugi::xml_node pt = node.child("prayertimes"); pt; pt = pt.next_sibling("prayertimes")) {
int day = pt.attribute("dayofyear").as_int(-1);
Expand All @@ -111,16 +111,8 @@ void zaman::vkt_h_v_d()
return nodes;
}();

static const char* cached_nodes[400] = {nullptr};
static bool cached_nodes_init = []() {
for (pugi::xml_node pt = cached_sehir.child("prayertimes"); pt; pt = pt.next_sibling("prayertimes")) {
int day = std::atoi(pt.attribute("dayofyear").value());
if (day >= 0 && day < 400) cached_nodes[day] = pt.text().get();
}
return true;
}();

zaman::xml_bu_gun = (zaman::h_rakam_gun_senenin >= 0 && zaman::h_rakam_gun_senenin < 400 && cached_nodes[zaman::h_rakam_gun_senenin]) ? cached_nodes[zaman::h_rakam_gun_senenin] : "";
zaman::xml_bu_gun = (zaman::h_rakam_gun_senenin >= 0 && zaman::h_rakam_gun_senenin < 400 && cached_nodes[zaman::h_rakam_gun_senenin]) ? std::string(cached_nodes[zaman::h_rakam_gun_senenin].text().get()) : "";

zaman::h_aksam = zaman::xml_bu_gun.substr(50, 6);
zaman::h_istibak_nucum = zaman::xml_bu_gun.substr(56, 6);
Expand All @@ -130,7 +122,7 @@ void zaman::vkt_h_v_d()
//buradaka kodları yeniliyoruz çünkü bir sonraki gün kılacağız verileri:

int next_day = zaman::h_rakam_gun_senenin + 1;
zaman::xml_bu_gun = (next_day >= 0 && next_day < 400 && cached_nodes[next_day]) ? cached_nodes[next_day] : "";
zaman::xml_bu_gun = (next_day >= 0 && next_day < 400 && cached_nodes[next_day]) ? std::string(cached_nodes[next_day].text().get()) : "";

zaman::h_imsak = zaman::xml_bu_gun.substr(0, 4) ;
zaman::h_sabah = zaman::xml_bu_gun.substr(5, 5) ;
Expand Down Expand Up @@ -177,19 +169,19 @@ void zaman::vkt_turk_v_d()
zaman::kible_saati_td = (1440 - zaman::h_aksam_td) + zaman::h_kible_saati_td ;

zaman::aksam = "00:00";
zaman::istibak_nucum.append( td_to_vakt(istibak_nucum_td) );
zaman::yatsi.append( td_to_vakt(yatsi_td) );
zaman::isa_sani.append( td_to_vakt(isa_sani_td) );
zaman::imsak.append( td_to_vakt(imsak_td) );
zaman::sabah.append( td_to_vakt(sabah_td) );
zaman::gunes.append( td_to_vakt(gunes_td) );
zaman::israk.append( td_to_vakt(israk_td) );
zaman::kerahet.append( td_to_vakt(kerahet_td) );
zaman::ogle.append( td_to_vakt(ogle_td) );
zaman::ikindi.append( td_to_vakt(ikindi_td) );
zaman::asr_sani.append( td_to_vakt(asr_sani_td) );
zaman::isfirar_sems.append( td_to_vakt(isfirar_sems_td) );
zaman::kible_saati.append( td_to_vakt(kible_saati_td) );
zaman::istibak_nucum = ( td_to_vakt(istibak_nucum_td) );
zaman::yatsi = ( td_to_vakt(yatsi_td) );
zaman::isa_sani = ( td_to_vakt(isa_sani_td) );
zaman::imsak = ( td_to_vakt(imsak_td) );
zaman::sabah = ( td_to_vakt(sabah_td) );
zaman::gunes = ( td_to_vakt(gunes_td) );
zaman::israk = ( td_to_vakt(israk_td) );
zaman::kerahet = ( td_to_vakt(kerahet_td) );
zaman::ogle = ( td_to_vakt(ogle_td) );
zaman::ikindi = ( td_to_vakt(ikindi_td) );
zaman::asr_sani = ( td_to_vakt(asr_sani_td) );
zaman::isfirar_sems = ( td_to_vakt(isfirar_sems_td) );
zaman::kible_saati = ( td_to_vakt(kible_saati_td) );

};

Expand All @@ -208,7 +200,9 @@ void zaman::sat_turk_v_d()
zaman::dakika = int(( zaman::zaman_td / 60) % 60 ) ;
zaman::saniye = int(( zaman::zaman_td ) % 60) ;

zaman::simdiki_zaman_turk.append(std::to_string(zaman::saat) + ":" + std::to_string(zaman::dakika) + ":" + std::to_string(zaman::saniye));
char buffer[12];
std::snprintf(buffer, sizeof(buffer), "%d:%d:%d", zaman::saat, zaman::dakika, zaman::saniye);
zaman::simdiki_zaman_turk = std::string(buffer);

};

Expand Down