]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - win/configure.cpp
Fix the problems GreenReaper found with the windows select engine, this has never...
[user/henk/code/inspircd.git] / win / configure.cpp
index 055e2ed256f1c55b311f45b20543bb2693c4b873..94d1b898c8b91c3bab6cf228c70fc0b3f707fbf7 100644 (file)
@@ -1,12 +1,12 @@
-/*       +------------------------------------+
- *       | Inspire Internet Relay Chat Daemon |
- *       +------------------------------------+
+/*        +------------------------------------+
+ *        | Inspire Internet Relay Chat Daemon |
+ *        +------------------------------------+
  *
  *  InspIRCd: (C) 2002-2008 InspIRCd Development Team
  * See: http://www.inspircd.org/wiki/index.php/Credits
  *
  * This program is free but copyrighted software; see
- *            the file COPYING for details.
+ *                     the file COPYING for details.
  *
  * ---------------------------------------------------
  */
@@ -84,7 +84,7 @@ bool escape_string(char * str, size_t size)
 {
        size_t len = strlen(str);
        char * d_str = (char*)malloc(len * 2);
-    
+       
        size_t i = 0;
        size_t j = 0;
 
@@ -103,7 +103,7 @@ bool escape_string(char * str, size_t size)
 
        d_str[j++] = 0;
 
-    if(j > size)
+       if(j > size)
        {
                free(d_str);
                return false;
@@ -125,23 +125,20 @@ int get_svn_revision(char * buffer, size_t len)
        7033
        */
        char buf[1000];
+       int rev = 0;
+       
        FILE * f = fopen("..\\.svn\\entries", "r");
-       if(!f) goto bad_rev;
-    
-       if(!fgets(buf, 1000, f)) goto bad_rev;
-       if(!fgets(buf, 1000, f)) goto bad_rev;
-       if(!fgets(buf, 1000, f)) goto bad_rev;
-       if(!fgets(buf, 1000, f)) goto bad_rev;
-       int rev = atoi(buf);
-       if(rev == 0) goto bad_rev;
-       sprintf(buffer, "%u", rev);
-       fclose(f);
-       return rev;
+       if (f)
+       {
+               for (int q = 0; q < 4; ++q)
+                       fgets(buf, 1000, f);
+
+               rev = atoi(buf);
+               sprintf(buffer, "%u", rev);
+               fclose(f);
+       }
        
-bad_rev:
-       strcpy(buffer, "non-svn");
-       if(f) fclose(f);
-       return 0;
+       return rev;
 }
 
 int __stdcall WinMain(IN HINSTANCE hInstance, IN HINSTANCE hPrevInstance, IN LPSTR lpCmdLine, IN int nShowCmd )
@@ -173,8 +170,8 @@ void Banner()
 {
        printf_c("\nWelcome to the \033[1mInspIRCd\033[0m Configuration program! (\033[1minteractive mode\033[0m)\n"
                         "\033[1mPackage maintainers: Type ./configure --help for non-interactive help\033[0m\n\n");
-       printf_c("*** If you are unsure of any of these values, leave it blank for    ***\n"
-                        "*** standard settings that will work, and your server will run      ***\n"
+       printf_c("*** If you are unsure of any of these values, leave it blank for      ***\n"
+                        "*** standard settings that will work, and your server will run          ***\n"
                         "*** using them. Please consult your IRC network admin if in doubt.  ***\n\n"
                         "Press \033[1m<RETURN>\033[0m to accept the default for any option, or enter\n"
                         "a new value. Please note: You will \033[1mHAVE\033[0m to read the docs\n"
@@ -184,10 +181,10 @@ void Banner()
 
 void Run()
 {
-       int max_fd = 10200;
        bool use_iocp = false;
-       bool support_ip6links = false;
+       bool support_ip6links = true;
        bool use_openssl = false;
+       bool ipv6 = true;
        char mod_path[MAX_PATH];
        char config_file[MAX_PATH];
        char library_dir[MAX_PATH];
@@ -197,7 +194,6 @@ void Run()
        char openssl_inc_path[MAX_PATH];
        char openssl_lib_path[MAX_PATH];
 
-       int max_clients = 10200;
        int nicklen = 31;
        int chanlen = 64;
        int modechanges = 20;
@@ -236,20 +232,22 @@ void Run()
 #endif
        printf_c("InspIRCd revision ID: \033[1;32m%s \033[0m\n\n", revision ? revision_text : "(Non-SVN build)");
 
-       max_fd = get_int_option("What is the maximum file descriptor count you would like to allow?", 10200);
-
        // detect windows
        if(iswinxp())
        {
                printf_c("You are running Windows 2000 or above, and IOCP support is most likely available.\n"
-                            "Thisis much more efficent but is currently EXPERIMENTAL and UNSUPPORTED.\n"
+                                "Thisis much more efficent but is currently EXPERIMENTAL and UNSUPPORTED.\n"
                                 "If you are unsure, answer no.\n\n");
 
                use_iocp = get_bool_option("Do you want to use the IOCP implementation?", false);
        }
 
-       support_ip6links = get_bool_option("\nYou have chosen to build an \033[1;32mIPV4-only\033[0m server.\nWould you like to enable support for linking to IPV6-enabled InspIRCd servers?\nIf you are using a recent operating system and are unsure, answer yes.\nIf you answer 'no' here, your InspIRCd server will be unable\nto parse IPV6 addresses (e.g. for CIDR bans)", 
-               true);
+       ipv6 = get_bool_option("Do you want to enable IPv6?", false);
+
+       if (!ipv6)
+               support_ip6links = get_bool_option("\nYou have chosen to build an \033[1;32mIPV4-only\033[0m server.\nWould you like to enable support for linking to IPV6-enabled InspIRCd servers?\nIf you are using a recent operating system and are unsure, answer yes.\nIf you answer 'no' here, your InspIRCd server will be unable\nto parse IPV6 addresses (e.g. for CIDR bans)", true);
+       else
+               support_ip6links = true;
        
        printf_c("\033[1mAll paths are relative to the binary directory.\033[0m\n");
        get_string_option("In what directory do you wish to install the InspIRCd base?", "..", base_path);
@@ -266,8 +264,6 @@ void Run()
                "of the 'maximum number of clients' setting which may be different on\n"
                "different servers on the network.\n\n");
 
-    
-       max_clients = get_int_option("Please enter the maximum number of clients at any one time?", 10200);
        nicklen = get_int_option("Please enter the maximum length of nicknames?", 31);
        chanlen = get_int_option("Please enter the maximum length of channel names?", 64);
        modechanges = get_int_option("Please enter the maximum number of mode changes in one line?", 20);
@@ -331,8 +327,6 @@ void Run()
        printf_c("\033[0mModule path:\033[1;32m              %s\n", mod_path);
        printf_c("\033[0mLibrary path:\033[1;32m             %s\n", library_dir);
        printf_c("\033[0mSocket Engine:\033[1;32m            %s\n", use_iocp ? "iocp" : "select");
-       printf_c("\033[0mMax file descriptors:\033[1;32m     %u\n", max_fd);
-       printf_c("\033[0mMax connections:\033[1;32m          %u\n", max_clients);
        printf_c("\033[0mMax nickname length:\033[1;32m      %u\n", nicklen);
        printf_c("\033[0mMax channel length:\033[1;32m       %u\n", chanlen);
        printf_c("\033[0mMax mode length:\033[1;32m          %u\n", modechanges);
@@ -362,12 +356,11 @@ void Run()
        fprintf(f, "#define __CONFIGURATION_AUTO__\n\n");
        if(use_iocp)
                fprintf(f, "#define CONFIG_USE_IOCP 1\n\n");
+       if (ipv6)
+               fprintf(f, "#define IPV6 1\n\n");
 
        fprintf(f, "#define CONFIG_FILE \"%s/inspircd.conf\"\n", config_file);
        fprintf(f, "#define MOD_PATH \"%s\"\n", mod_path);
-       fprintf(f, "#define MAX_DESCRIPTORS %u\n", max_fd);
-       fprintf(f, "#define MAXCLIENTS %u\n", max_clients);
-       fprintf(f, "#define MAXCLIENTS_S \"%u\"\n", max_clients);
        fprintf(f, "#define SOMAXCONN_S \"128\"\n");
        fprintf(f, "#define NICKMAX %u\n", nicklen+1);
        fprintf(f, "#define CHANMAX %u\n", chanlen+1);
@@ -435,12 +428,12 @@ void WriteCompileCommands()
                {
                        strcpy(commands[command_count], fd.cFileName);
                        commands[command_count][strlen(fd.cFileName) - 4] = 0;
-                       printf("    %s\n", commands[command_count]);
+                       printf("        %s\n", commands[command_count]);
                        ++command_count;
                } while(FindNextFile(fh, &fd));
                sc(TNORMAL);
        }
-    
+       
        // Write our spiffy new makefile :D
        // I am such a lazy fucker :P
        FILE * f = fopen("..\\src\\commands\\commands.mak", "w");