mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 21:37:17 +01:00
Materialize temporary string obtained from boost path
This commit is contained in:
parent
38ebe28923
commit
490b65dfe2
|
@ -62,7 +62,8 @@ namespace i2p
|
||||||
LogPrint("Error, could not create process group.");
|
LogPrint("Error, could not create process group.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
chdir(i2p::util::filesystem::GetDataDir().string().c_str());
|
std::string d(i2p::util::filesystem::GetDataDir()); // make a copy
|
||||||
|
chdir(d.c_str());
|
||||||
|
|
||||||
// close stdin/stdout/stderr descriptors
|
// close stdin/stdout/stderr descriptors
|
||||||
::close (0);
|
::close (0);
|
||||||
|
|
42
NetDb.cpp
42
NetDb.cpp
|
@ -21,11 +21,7 @@ namespace i2p
|
||||||
{
|
{
|
||||||
namespace data
|
namespace data
|
||||||
{
|
{
|
||||||
#ifndef _WIN32
|
const char NetDb::m_NetDbPath[] = "netDb";
|
||||||
const char NetDb::m_NetDbPath[] = "/netDb";
|
|
||||||
#else
|
|
||||||
const char NetDb::m_NetDbPath[] = "\\netDb";
|
|
||||||
#endif
|
|
||||||
NetDb netdb;
|
NetDb netdb;
|
||||||
|
|
||||||
NetDb::NetDb (): m_IsRunning (false), m_Thread (nullptr), m_Reseeder (nullptr)
|
NetDb::NetDb (): m_IsRunning (false), m_Thread (nullptr), m_Reseeder (nullptr)
|
||||||
|
@ -40,7 +36,7 @@ namespace data
|
||||||
|
|
||||||
void NetDb::Start ()
|
void NetDb::Start ()
|
||||||
{
|
{
|
||||||
Load (m_NetDbPath);
|
Load ();
|
||||||
if (m_RouterInfos.size () < 25) // reseed if # of router less than 50
|
if (m_RouterInfos.size () < 25) // reseed if # of router less than 50
|
||||||
{
|
{
|
||||||
// try SU3 first
|
// try SU3 first
|
||||||
|
@ -55,7 +51,7 @@ namespace data
|
||||||
{
|
{
|
||||||
m_Reseeder->reseedNow();
|
m_Reseeder->reseedNow();
|
||||||
reseedRetries++;
|
reseedRetries++;
|
||||||
Load (m_NetDbPath);
|
Load ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -133,7 +129,7 @@ namespace data
|
||||||
{
|
{
|
||||||
if (lastSave)
|
if (lastSave)
|
||||||
{
|
{
|
||||||
SaveUpdated (m_NetDbPath);
|
SaveUpdated ();
|
||||||
ManageLeaseSets ();
|
ManageLeaseSets ();
|
||||||
}
|
}
|
||||||
lastSave = ts;
|
lastSave = ts;
|
||||||
|
@ -295,10 +291,9 @@ namespace data
|
||||||
LogPrint (eLogWarning, "Failed to reseed after 10 attempts");
|
LogPrint (eLogWarning, "Failed to reseed after 10 attempts");
|
||||||
}
|
}
|
||||||
|
|
||||||
void NetDb::Load (const char * directory)
|
void NetDb::Load ()
|
||||||
{
|
{
|
||||||
boost::filesystem::path p (i2p::util::filesystem::GetDataDir());
|
boost::filesystem::path p(i2p::util::filesystem::GetDataDir() / m_NetDbPath);
|
||||||
p /= (directory);
|
|
||||||
if (!boost::filesystem::exists (p))
|
if (!boost::filesystem::exists (p))
|
||||||
{
|
{
|
||||||
// seems netDb doesn't exist yet
|
// seems netDb doesn't exist yet
|
||||||
|
@ -345,27 +340,15 @@ namespace data
|
||||||
LogPrint (m_Floodfills.size (), " floodfills loaded");
|
LogPrint (m_Floodfills.size (), " floodfills loaded");
|
||||||
}
|
}
|
||||||
|
|
||||||
void NetDb::SaveUpdated (const char * directory)
|
void NetDb::SaveUpdated ()
|
||||||
{
|
{
|
||||||
auto GetFilePath = [](const char * directory, const RouterInfo * routerInfo)
|
auto GetFilePath = [](const boost::filesystem::path& directory, const RouterInfo * routerInfo)
|
||||||
{
|
{
|
||||||
#ifndef _WIN32
|
std::string s(routerInfo->GetIdentHashBase64());
|
||||||
return std::string (directory) + "/r" +
|
return directory / (std::string("r") + s[0]) / ("routerInfo-" + s + ".dat");
|
||||||
routerInfo->GetIdentHashBase64 ()[0] + "/routerInfo-" +
|
|
||||||
#else
|
|
||||||
return std::string (directory) + "\\r" +
|
|
||||||
routerInfo->GetIdentHashBase64 ()[0] + "\\routerInfo-" +
|
|
||||||
#endif
|
|
||||||
routerInfo->GetIdentHashBase64 () + ".dat";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
boost::filesystem::path p (i2p::util::filesystem::GetDataDir());
|
boost::filesystem::path fullDirectory (i2p::util::filesystem::GetDataDir() / m_NetDbPath);
|
||||||
p /= (directory);
|
|
||||||
#if BOOST_VERSION > 10500
|
|
||||||
const char * fullDirectory = p.string().c_str ();
|
|
||||||
#else
|
|
||||||
const char * fullDirectory = p.c_str ();
|
|
||||||
#endif
|
|
||||||
int count = 0, deletedCount = 0;
|
int count = 0, deletedCount = 0;
|
||||||
auto total = m_RouterInfos.size ();
|
auto total = m_RouterInfos.size ();
|
||||||
uint64_t ts = i2p::util::GetMillisecondsSinceEpoch ();
|
uint64_t ts = i2p::util::GetMillisecondsSinceEpoch ();
|
||||||
|
@ -373,7 +356,8 @@ namespace data
|
||||||
{
|
{
|
||||||
if (it.second->IsUpdated ())
|
if (it.second->IsUpdated ())
|
||||||
{
|
{
|
||||||
it.second->SaveToFile (GetFilePath(fullDirectory, it.second.get ()));
|
std::string f = GetFilePath(fullDirectory, it.second.get()).string();
|
||||||
|
it.second->SaveToFile (f);
|
||||||
it.second->SetUpdated (false);
|
it.second->SetUpdated (false);
|
||||||
it.second->SetUnreachable (false);
|
it.second->SetUnreachable (false);
|
||||||
it.second->DeleteBuffer ();
|
it.second->DeleteBuffer ();
|
||||||
|
|
4
NetDb.h
4
NetDb.h
|
@ -68,8 +68,8 @@ namespace data
|
||||||
private:
|
private:
|
||||||
|
|
||||||
bool CreateNetDb(boost::filesystem::path directory);
|
bool CreateNetDb(boost::filesystem::path directory);
|
||||||
void Load (const char * directory);
|
void Load ();
|
||||||
void SaveUpdated (const char * directory);
|
void SaveUpdated ();
|
||||||
void Run (); // exploratory thread
|
void Run (); // exploratory thread
|
||||||
void Explore (int numDestinations);
|
void Explore (int numDestinations);
|
||||||
void Publish ();
|
void Publish ();
|
||||||
|
|
|
@ -447,10 +447,13 @@ namespace data
|
||||||
if (m_Buffer)
|
if (m_Buffer)
|
||||||
{
|
{
|
||||||
std::ofstream f (fullPath, std::ofstream::binary | std::ofstream::out);
|
std::ofstream f (fullPath, std::ofstream::binary | std::ofstream::out);
|
||||||
f.write ((char *)m_Buffer, m_BufferLen);
|
if (f.is_open ())
|
||||||
}
|
f.write ((char *)m_Buffer, m_BufferLen);
|
||||||
|
else
|
||||||
|
LogPrint(eLogError, "Can't save RouterInfo to ", fullPath);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
LogPrint (eLogError, "Can't save to file");
|
LogPrint (eLogError, "Can't save RouterInfo m_Buffer==NULL");
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t RouterInfo::ReadString (char * str, std::istream& s)
|
size_t RouterInfo::ReadString (char * str, std::istream& s)
|
||||||
|
|
Loading…
Reference in a new issue