From f9bc7a311d4a9d7b6eb581c21d2105b692b42b8d Mon Sep 17 00:00:00 2001 From: brain Date: Wed, 14 Dec 2005 17:40:06 +0000 Subject: Made inspircd itself a class, and called its instance TittyBiscuits, just because. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@2425 e03df62e-2008-0410-955e-edbf42e46eb7 --- include/inspircd.h | 10 +++++++--- include/typedefs.h | 1 + src/inspircd.cpp | 27 +++++++++++++++++---------- 3 files changed, 25 insertions(+), 13 deletions(-) diff --git a/include/inspircd.h b/include/inspircd.h index 16f767ac3..236f99db0 100644 --- a/include/inspircd.h +++ b/include/inspircd.h @@ -90,10 +90,15 @@ class serverstats } }; -typedef void (handlerfunc) (char**, int, userrec*); + +class InspIRCd +{ + public: + InspIRCd(int argc, char** argv); + int Run(); +}; /* prototypes */ -int InspIRCd(char** argv, int argc); void force_nickchange(userrec* user,const char* newnick); void kill_link(userrec *user,const char* r); void kill_link_silent(userrec *user,const char* r); @@ -118,6 +123,5 @@ std::string GetVersionString(); void* dns_task(void* arg); void process_buffer(const char* cmdbuf,userrec *user); void FullConnectUser(userrec* user); -chanrec* ForceChan(chanrec* Ptr,ucrec &a,userrec* user, int created); #endif diff --git a/include/typedefs.h b/include/typedefs.h index 05cf9e8db..558a93757 100644 --- a/include/typedefs.h +++ b/include/typedefs.h @@ -25,5 +25,6 @@ typedef std::deque command_table; typedef std::vector servernamelist; typedef std::vector ExtModeList; typedef ExtModeList::iterator ExtModeListIter; +typedef void (handlerfunc) (char**, int, userrec*); #endif diff --git a/src/inspircd.cpp b/src/inspircd.cpp index 0da0f580c..60e0c11bd 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -428,7 +428,7 @@ void kill_link_silent(userrec *user,const char* r) } -int main(int argc, char** argv) +InspIRCd::InspIRCd(int argc, char** argv) { Start(); srand(time(NULL)); @@ -468,14 +468,7 @@ int main(int argc, char** argv) lowermap[(unsigned)']'] = '}'; lowermap[(unsigned)'\\'] = '|'; - if (InspIRCd(argv,argc) == ERROR) - { - log(DEFAULT,"main: daemon function bailed"); - printf("ERROR: could not initialise. Shutting down.\n"); - Exit(ERROR); - } - Exit(TRUE); - return 0; + return; } template inline string ConvToStr(const T &in) @@ -1543,7 +1536,7 @@ int BindPorts() return boundPortCount; } -int InspIRCd(char** argv, int argc) +int InspIRCd::Run() { bool expire_run = false; std::vector activefds; @@ -1753,3 +1746,17 @@ int InspIRCd(char** argv, int argc) return 0; } +/**********************************************************************************/ + +/** + * An ircd in four lines! bwahahaha. ahahahahaha. ahahah *cough*. + */ + +int main(int argc, char** argv) +{ + InspIRCd TittyBiscuits = new InspIRCd(argc, argv); + TittyBiscuits->Run(); + delete TittyBiscuits; + return 0; +} + -- cgit v1.2.3