X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fcommands%2Fcmd_lusers.cpp;h=4a2f4f7df3f001a6e9533de4b3e018cf12cc290e;hb=10d8e9151d75c1ef81740d56b703fc147086f175;hp=c6b8e8400672a7503f60ee1eedb392130dbed46a;hpb=cd712c40e1b352c05e7ae0f72e0a5e84cdf64323;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/commands/cmd_lusers.cpp b/src/commands/cmd_lusers.cpp index c6b8e8400..4a2f4f7df 100644 --- a/src/commands/cmd_lusers.cpp +++ b/src/commands/cmd_lusers.cpp @@ -55,7 +55,7 @@ CmdResult CommandLusers::Handle (const std::vector&, User *user) unsigned int n_invis = ServerInstance->Users->ModeCount('i'); ProtoServerList serverlist; ServerInstance->PI->GetServerList(serverlist); - int n_serv = 1; + int n_serv = 0; int n_local_servs = 0; for(ProtoServerList::iterator i = serverlist.begin(); i != serverlist.end(); ++i) { @@ -63,6 +63,9 @@ CmdResult CommandLusers::Handle (const std::vector&, User *user) if (i->parentname == ServerInstance->Config->ServerName) n_local_servs++; } + // fix for default GetServerList not returning us + if (!n_serv) + n_serv = 1; // these are updated on every connect (or /lusers invocation), which is good enough if (ServerInstance->Users->LocalUserCount() > max_local) @@ -71,7 +74,7 @@ CmdResult CommandLusers::Handle (const std::vector&, User *user) max_global = n_users; user->WriteNumeric(251, "%s :There are %d users and %d invisible on %d servers",user->nick.c_str(), - n_users, n_users-n_invis, n_serv); + n_users-n_invis, n_invis, n_serv); if (ServerInstance->Users->OperCount()) user->WriteNumeric(252, "%s %d :operator(s) online",user->nick.c_str(),ServerInstance->Users->OperCount()); @@ -79,9 +82,7 @@ CmdResult CommandLusers::Handle (const std::vector&, User *user) if (ServerInstance->Users->UnregisteredUserCount()) user->WriteNumeric(253, "%s %d :unknown connections",user->nick.c_str(),ServerInstance->Users->UnregisteredUserCount()); - if (ServerInstance->ChannelCount()) - user->WriteNumeric(254, "%s %ld :channels formed",user->nick.c_str(),ServerInstance->ChannelCount()); - + user->WriteNumeric(254, "%s %ld :channels formed",user->nick.c_str(),ServerInstance->ChannelCount()); user->WriteNumeric(255, "%s :I have %d clients and %d servers",user->nick.c_str(),ServerInstance->Users->LocalUserCount(),n_local_servs); user->WriteNumeric(265, "%s :Current Local Users: %d Max: %d",user->nick.c_str(),ServerInstance->Users->LocalUserCount(),max_local); user->WriteNumeric(266, "%s :Current Global Users: %d Max: %d",user->nick.c_str(),n_users,max_global);