summaryrefslogtreecommitdiff
path: root/src/messages.cpp
diff options
context:
space:
mode:
authorSadie Powell <sadie@witchery.services>2024-02-26 23:49:36 +0000
committerSadie Powell <sadie@witchery.services>2024-02-26 23:57:55 +0000
commiteb658f87a3a53e7ad2f5815d498aceb9a974dd5e (patch)
treea70db0968060b4382dd2881777c8a0e3c742dbfe /src/messages.cpp
parent1e87849e5c218cc3d99e259f9ea43493bd8bc633 (diff)
Use fstream for accessing files where possible.
Diffstat (limited to 'src/messages.cpp')
-rw-r--r--src/messages.cpp22
1 files changed, 9 insertions, 13 deletions
diff --git a/src/messages.cpp b/src/messages.cpp
index 1d2d28a89..ba9ddfbce 100644
--- a/src/messages.cpp
+++ b/src/messages.cpp
@@ -240,21 +240,17 @@ void MOTD::Run(MessageSource &source, const std::vector<Anope::string> &params,
if (s != Me)
return;
- FILE *f = fopen(Config->GetBlock("serverinfo")->Get<const Anope::string>("motd").c_str(), "r");
- if (f)
+ std::ifstream stream(Config->GetBlock("serverinfo")->Get<const Anope::string>("motd").str());
+ if (!stream.is_open())
{
- IRCD->SendNumeric(375, source.GetSource(), "- " + s->GetName() + " Message of the Day");
- char buf[BUFSIZE];
- while (fgets(buf, sizeof(buf), f))
- {
- buf[strlen(buf) - 1] = 0;
- IRCD->SendNumeric(372, source.GetSource(), Anope::printf("- %s", buf));
- }
- fclose(f);
- IRCD->SendNumeric(376, source.GetSource(), "End of /MOTD command.");
- }
- else
IRCD->SendNumeric(422, source.GetSource(), "- MOTD file not found! Please contact your IRC administrator.");
+ return;
+ }
+
+ IRCD->SendNumeric(375, source.GetSource(), "- " + s->GetName() + " Message of the Day");
+ for (Anope::string line; std::getline(stream, line.str()); )
+ IRCD->SendNumeric(372, source.GetSource(), Anope::printf("- %s", line.c_str()));
+ IRCD->SendNumeric(376, source.GetSource(), "End of /MOTD command.");
}
void Notice::Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags)