1. Pascal / Говнокод #19286

    −2

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    procedure DoDoubleBuffering(const Form: TForm);
    var
      Component: TComponent;
    begin
      Form.DoubleBuffered := True;
      for Component in Form do
        if (Component is TLabel) or (Component is TButton) or (Component is TEdit)
        then
          TButton(Component).DoubleBuffered := True;
    end;
    
    procedure AppendStringToFile(FileName: string; Data: string);
    var
      s: TextFile;
    begin
      if not FileExists(FDir + FileName) then
      begin
        AssignFile(s, FDir + FileName);
        Rewrite(s);
        WriteLn(s, Data);
        CloseFile(s);
      end
      else
      begin
        AssignFile(s, FDir + FileName);
        Append(s);
        WriteLn(s, Data);
        CloseFile(s);
      end;
    end;
    
    function Pars(T_, ForS, _T: string): string;
    var
      a, b: Integer;
    begin
      Result := '';
      if (T_ = '') or (ForS = '') or (_T = '') then
        Exit;
      a := Pos(T_, ForS);
      if a = 0 then
        Exit
      else
        a := a + Length(T_);
      ForS := Copy(ForS, a, Length(ForS) - a + 1);
      b := Pos(_T, ForS);
      if b > 0 then
        Result := Copy(ForS, 1, b - 1);
    end;
    
    procedure LoginAndPassword(const Data: string;
      out Login, Password: string); inline;
    var
      FIndex: Integer;
      FDelimetr: String;
    begin
      FDelimetr := ':';
      if Pos(';', Data) <> 0 then
        FDelimetr := ';';
      FIndex := Pos(FDelimetr, Data);
      Login := Copy(Data, 1, FIndex - 1);
      Password := Copy(Data, FIndex + 1, Length(Data) - FIndex);
    end;
    
    procedure IPAndPort(out IP, Port: string); inline;
    begin
      if TP >= Proxy.Count then
        TP := 0;
      IP := Copy(Proxy.Strings[TP], 1, Pos(':', Proxy.Strings[TP]) - 1);
      Port := Copy(Proxy.Strings[TP], Pos(':', Proxy.Strings[TP]) + 1,
        Length(Proxy.Strings[TP]));
      Inc(TP);
    end;
    
    function ParsIndex(_S: String; S1: String; S_: String; I: Integer): String;
    var
      TS: TStringList;
      s: String;
    begin
      TS := TStringList.Create;
      while Pos(_S, S1) <> 0 do
      begin
        TS.Add(Pars(_S, S1, S_));
        Delete(S1, Pos(_S, S1), 1);
      end;
      Result := TS.Strings[I];
      FreeAndNil(TS);
    end;

    Код великого кодера с BHF.SU имя Грач.

    Gratsh, 10 Января 2016

    Комментарии (22)
  2. Pascal / Говнокод #19285

    −1

    1. 001
    2. 002
    3. 003
    4. 004
    5. 005
    6. 006
    7. 007
    8. 008
    9. 009
    10. 010
    11. 011
    12. 012
    13. 013
    14. 014
    15. 015
    16. 016
    17. 017
    18. 018
    19. 019
    20. 020
    21. 021
    22. 022
    23. 023
    24. 024
    25. 025
    26. 026
    27. 027
    28. 028
    29. 029
    30. 030
    31. 031
    32. 032
    33. 033
    34. 034
    35. 035
    36. 036
    37. 037
    38. 038
    39. 039
    40. 040
    41. 041
    42. 042
    43. 043
    44. 044
    45. 045
    46. 046
    47. 047
    48. 048
    49. 049
    50. 050
    51. 051
    52. 052
    53. 053
    54. 054
    55. 055
    56. 056
    57. 057
    58. 058
    59. 059
    60. 060
    61. 061
    62. 062
    63. 063
    64. 064
    65. 065
    66. 066
    67. 067
    68. 068
    69. 069
    70. 070
    71. 071
    72. 072
    73. 073
    74. 074
    75. 075
    76. 076
    77. 077
    78. 078
    79. 079
    80. 080
    81. 081
    82. 082
    83. 083
    84. 084
    85. 085
    86. 086
    87. 087
    88. 088
    89. 089
    90. 090
    91. 091
    92. 092
    93. 093
    94. 094
    95. 095
    96. 096
    97. 097
    98. 098
    99. 099
    100. 100
    begin
      if Form2.ProxySettingsCheckBox.Checked = True then
      begin
        FKeyHideme := HidemeEdit.Text;
        FTempInfo := '';
        FHTTPTemp := False;
        FSOCKS4Temp := False;
        FSOCKS5Temp := False;
        FKeyBest := BestEdit.Text;
        FUrlHTTP := HTTPEditUrl.Text;
        FLoginOther := LoginEdit.Text;
        FPassOther := PassEdit.Text;
        if HTTPCheckBox.Checked = True then
          FTypeHTTP := True
        else
          FTypeHTTP := False;
        if SOCKS4CheckBox.Checked = True then
          FTypeSOCKS4 := True
        else
          FTypeSOCKS4 := False;
        if SOCKS5CheckBox.Checked = True then
          FTypeSocks5 := True
        else
          FTypeSocks5 := False;
        if FileCheckBox.Checked = True then
          FTemp := 1
        else
          Sleep(0);
        if HidemeCheckBox.Checked = True then
          FTemp := 2
        else
          Sleep(0);
        if BestCheckBox.Checked = True then
          FTemp := 3
        else
          Sleep(0);
        if OtherCheckBox.Checked = True then
          FTemp := 4
        else
          Sleep(0);
        if UrlCheckBox.Checked = True then
          FTemp := 5
        else
          Sleep(0);
        if FTemp = -1 then
        begin
          ShowMessage('Выберите метод загрузки прокси');
        end
        else
        begin
          if (FTypeHTTP = False) and (FTypeSOCKS4 = False) and (FTypeSocks5 = False)
          then
          begin
            ShowMessage
              ('Выберите хотя бы 1 тип прокси который вы хотите использовать!');
          end
          else
          begin
            if FTemp = 1 then
            begin
              if Proxy.Count <> 0 then
              begin
                Form1.CleanButton.Enabled := True;
                Form1.ProxyButton.Enabled := False;
                Form1.Enabled := True;
                Form2.Hide;
                Form1.ProxyLabel.Caption := IntToStr(Proxy.Count);
              end
              else
              begin
                ShowMessage('Прокси не обнаружено!');
              end;
            end
            else
            begin
              if FTemp = 5 then
              begin
                if HTTPEditUrl.Text <> '' then
                begin
                  Thread.Create(False);
                end
                else
                begin
                  ShowMessage('Введите ссылку для получения проксей!');
                end;
              end
              else
              begin
                Thread.Create(False);
              end;
            end;
          end;
        end;
      end
      else
      begin
        Form1.Enabled := True;
        Form2.Hide;
      end;
    end;

    Офигенная реализация блока else.

    Gratsh, 10 Января 2016

    Комментарии (0)
  3. Pascal / Говнокод #19284

    0

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    90. 90
    91. 91
    92. 92
    93. 93
    94. 94
    95. 95
    96. 96
    97. 97
    98. 98
    99. 99
    procedure Thread.Execute;
    label
      ProxyCheck, BadCheck;
    var
      I, s: Integer;
    begin
      try
        while FWork do
        begin
          if not Self.Terminated then
          begin
            EnterCriticalSection(FCriticalSection);
            if FAcc + 1 < FAccounts.Count then
            begin
              Inc(FAcc);
              FCur := FAcc;
            end
            else
              Exit;
            LeaveCriticalSection(FCriticalSection);
            LoginAndPassword(FAccounts.Strings[FCur], Login, Pass);
            HTTP := THTTPSend.Create;
            Scr := TStringList.Create;
            Data := TStringStream.Create;
            HTTP.Timeout := FTimeOut;
            HTTP.Sock.SocksTimeout := FTimeOut;
            HTTP.Sock.SetTimeout(FTimeOut);
            HTTP.Sock.SetSendTimeout(FTimeOut);
            HTTP.Sock.SetRecvTimeout(FTimeOut);
            Rez := 0;
            FErrorCount := 0;
            while Rez = 0 do
            begin
              Inc(FPPSValue);
              if FErrorCount = MaxError then
              begin
                Rez := 3;
              end
              else
              begin
                HTTP.Headers.Clear;
                HTTP.Document.Clear;
                HTTP.Cookies.Clear;
                Data.Clear;
                if FProxyTypes > 0 then
                begin
                ProxyCheck:
                  IPAndPort(IP, Port);
                  case FProxyTypes of
                    1:
                      begin
                        HTTP.ProxyHost := IP;
                        HTTP.ProxyPort := Port;
                      end;
                    2:
                      begin
                        HTTP.Sock.SocksIP := IP;
                        HTTP.Sock.SocksPort := Port;
                        HTTP.Sock.SocksType := ST_Socks4;
                      end;
                    3:
                      begin
                        HTTP.Sock.SocksIP := IP;
                        HTTP.Sock.SocksPort := Port;
                        HTTP.Sock.SocksType := ST_Socks5;
                      end;
                  end;
                  if FCheckProxy = True then
                  begin
                    HTTP.Headers.Clear;
                    HTTP.Document.Clear;
                    HTTP.Cookies.Clear;
                    HTTP.HTTPMethod('GET', 'https://mail.ru');
                    if not HTTP.ResultCode = 200 then
                      goto ProxyCheck;
                  end;
                end;
                HTTP.Headers.Clear;
                HTTP.Document.Clear;
                HTTP.Cookies.Clear;
    
                if Rez = 0 then
                begin
                  Synchronize(Err);
                  InterlockedIncrement(FErrorCount);
                end;
              end;
            end;
            Synchronize(Sync);
            FreeAndNil(HTTP); FreeAndNil(Scr); FreeAndNil(Data);
          end
          else
          begin
            Synchronize(Stop);
          end;
        end;
      finally
      end;
    end;

    Оригинальный способ брута на Delphi XE3 с использованием Synapse. (facepalm)...

    Gratsh, 10 Января 2016

    Комментарии (0)
  4. Pascal / Говнокод #19250

    0

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    function explodeParams(str: string; objDel: char; paramDel: char): ISuperObject;
    var
      i: Integer;
      obj: ISuperObject;
      field: string;
      value: string;
      cuts: string;
      newstr: string;
    begin
      cuts := '';
      newstr := '';
      for i := 1 to Length(str) do
      begin
        if str[i] <> objDel then
        begin
          if str[i] <> paramDel then
          begin
            cuts := cuts + str[i];
          end
          else
          begin
            field := cuts;
            cuts := '';
          end;
        end
        else
        begin
          value := cuts;
          if value = '' then
          begin
            exit;
          end;
          if field = '' then
          begin
            exit;
          end;
          obj := so(['name', field, 'value', StrToInt(value)]);
          newstr := newstr + obj.AsString + ',';
          cuts := '';
        end;
      end;
      if cuts <> '' then
      begin
        obj := so(['name', field, 'value', StrToInt(cuts)]);
        newstr := newstr + obj.AsString + ',';
      end;
      newstr := Copy(newstr, 1, Length(newstr) - 1);
      Result := so('[' + newstr + ']');
    end;

    Отборное г...

    Cynicrus, 26 Декабря 2015

    Комментарии (9)
  5. Pascal / Говнокод #19244

    +9

    1. 1
    if (abs(i-i1)<1) or (abs(j-j1)<0) then continue;

    Модуль меньше нуля.

    Janycz, 25 Декабря 2015

    Комментарии (31)
  6. Pascal / Говнокод #19190

    +5

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    (*
     * Исходный вариант паскалевских текстов Кисы взят
     * с сайта http://hottabych.net/kisa/.
     * Адаптирован к Gnu Pascal и Free Pascal
     * Сергеем Вакуленко, serge@vak.ru.
     *)
    program kisa;
    var
    	input_length, mood, nm: integer;
    	input, lastmess: string;
    	question, reply_needed: boolean;
    	baza: array [1..301] of string;
    	qz: array [1..20] of integer;
    
    procedure init;
    var
    	kj: integer;
    begin
    	{Если пусто или 1 символ}
    	kj := 1;	baza[kj] := 'Ну, венец природы, не стесняйся.';
    	kj := kj+1;	baza[kj] := 'Балуешься?';
    	kj := kj+1;	baza[kj] := 'Скажи уже что-нибудь.';
    	kj := kj+1;	baza[kj] := 'А у Вас Enter запало :-)';
    	kj := kj+1;	baza[kj] := 'Тебе нечего сказать?';
    	kj := kj+1;	baza[kj] := 'Одно и тоже(.';
    	kj := kj+1;	baza[kj] := 'Не стесняйся!';
    	kj := kj+1;	baza[kj] := 'Ты любишь мультики? Какие?';
    	kj := kj+1;	baza[kj] := 'Не бойся!';
    	kj := kj+1;	baza[kj] := 'Сколько тебе лет?';
    	kj := kj+1;	baza[kj] := 'У тебя на клавиатуре только одна кнопка?';
    	kj := kj+1;	baza[kj] := 'Я терпеливая, а ты?';
    	kj := kj+1;	baza[kj] := 'Поговори со мной!';
    	kj := kj+1;	baza[kj] := 'Испытываешь моё терпение?';
    	kj := kj+1;	baza[kj] := 'С тобой так интересно ;-)';
    	kj := kj+1;	{kj=16}

    Я просто оставлю это здесь.

    inkanus-gray, 16 Декабря 2015

    Комментарии (6)
  7. Pascal / Говнокод #19153

    +8

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    procedure PGSK_VSK(xia,xtia:dimer3; kw:tnmatrix; var kw_v:tnmatrix);
    var
      VV,NN,BB:dimer3;
      modu:extended;
      k, i, m, L: Cardinal;
      Mvv:mat33;
    begin
    modu:=md(xtia);
    VV[1]:=xtia[1]/modu; VV[2]:=xtia[2]/modu; VV[3]:=xtia[3]/modu;
    
    NN[1]:=xtia[2]*xia[3]-xia[2]*xtia[3];
    NN[2]:=xtia[3]*xia[1]-xia[3]*xtia[1];
    NN[3]:=xtia[1]*xia[2]-xia[1]*xtia[2];
    modu:=md(NN);
    NN[1]:=NN[1]/modu; NN[2]:=NN[2]/modu; NN[3]:=NN[3]/modu;
    
    BB[1]:=NN[2]*VV[3]-NN[3]*VV[2];
    BB[2]:=NN[3]*VV[1]-NN[1]*VV[3];
    BB[3]:=NN[1]*VV[2]-NN[2]*VV[1];
    for k:=1 to 3 do Mvv[1][k]:=VV[k];
    for k:=1 to 3 do Mvv[2][k]:=NN[k];
    for k:=1 to 3 do Mvv[3][k]:=BB[k];
    
    rm661:=MM0; kw_v:=MM0;
              for k:=1 to 3 do  for l:=1 to 3 do  for m:=1 to 3 do
                rm661[k][l]:=rm661[k][l]+Mvv[k][m]*kw[m][l];
              for k:=1 to 3 do
                for l:=k to 3 do begin
                  for m:=1 to 3 do
                    kw_v[k][l]:=kw_v[k][l]+Mvv[k][m]*rm661[l][m];
                  kw_v[l][k]:=kw_v[k][l];
                                 end;
              for k:=1 to 3 do  for l:=1 to 3 do  for m:=1 to 3 do
                    rm661[k+3][l+3]:=rm661[k+3][l+3]+Mvv[k][m]*kw[m+3][l+3];
              for k:=1 to 3 do
                for l:=k to 3 do begin
                  for m:=1 to 3 do
                    kw_v[k+3][l+3]:=kw_v[k+3][l+3]+Mvv[k][m]*rm661[l+3][m+3];
                  kw_v[l+3][k+3]:=kw_v[k+3][l+3];
                                 end;
    end;

    Мой первый пост - это код преподавателя... я встал и вышел...

    morkovkin, 08 Декабря 2015

    Комментарии (26)
  8. Pascal / Говнокод #19109

    +6

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    procedure TForm1.FormCreate(Sender: TObject);
     
    const BUFSIZE=1; EOLN=#13;
     
    var   TempString : String ;
          Symb       : PChar;
          FText      : TFileStream;
          File_Name:String;
     
    begin
      Memo1.Clear;
     // File_Name:='D:\Projects\Bpl\ТЗ\testlog.txt';
      File_Name:='G:\test1.txt';   //сюда вбиваем имя 
      FText:=TFileStream.Create(File_Name,fmShareDenyNone);   //открываем
      FText.Seek(0,soFromBeginning);    //переходим на начало
      repeat
          GetMem(Symb,BUFSIZE);             //выделяем память под символ для чтения
          FText.Read(Symb^,BUFSIZE);        //читаем
          TempString:=TempString+Symb^;  //складываем символы в строку
          if (Symb^=EOLN) then                 //если конец строки то выводим строку в мемо и "обнуляем"
            begin
              Memo1.Lines.Add(TempString);
              TempString:='';
            end;
      until FText.Read(Symb^,BUFSIZE)=0;   //пока читается
    end;

    Пятиминутка юмора

    Firewa11er, 30 Ноября 2015

    Комментарии (15)
  9. Pascal / Говнокод #19106

    +7

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    TBattleBot = class(TUnit)
       fLetaet,fPlyvet:boolean; fBMSpeed:integer;//skorost' kadrov
       fCBMm:integer;//количество картинок MOVE
       fCBMl:integer;//count lestnica
       fCBMu:integer;//count up lestnica
       fCBMa:integer;//count attack              //
       fCBMd:integer;//count damage
       fCBMk:integer;//count kill
       fMxSp,fMySp,fLxSp,fLySp,fUxSp,fUySp:integer;//skorosti
       fBShow:boolean;
       fxSnarad,fySnarad:integer;//x y vypuskaemogo snarada otnositelno 0:0-fxbm:fybm
       fSxSpeed,fSySpeed:integer;//skorost' snarada
       fSPZh:integer;//PZh snarada
       fSlvl:integer;//lvl snarada    :;
       fSBMSpeed:integer;
       fSxbm,fSybm,fSxr,fSyr,fSxb,fSyb,fSWidthbm,fSHeightbm,fSWidthr,fSHeightr:integer;//har snarada
       fAlgoritm:array [1..10] of TAlgoritm;
       fST:integer;//summa vremeni algoritmov
       fCA:integer;//kolvo povtorov algoritmov
       fTAlgoritm:integer;//Tekushchii algoritm
       fDamage:integer; //ataka
       fDefence:integer;//zashchyta
       fStructure:integer;
       fTStructure:integer;//HP
       Constructor Create(xbm,ybm,xr,yr,Widthr,Heightr,xb,yb,
       CBMm,CBMl,CBMu,CBMa,CBMd,CBMk,BMSpeed,
       xSnarad,ySnarad,Sxr,Syr,Sxb,Syb,SxSpeed,SySpeed,SPZh,Slvl,SBMSpeed,
       SWidthbm,SHeightbm,SWidthr,SHeightr,
       MxSp,MySp,LxSp,LySp,UxSp,UySp,
       c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,Damage,Defence,Structure,TStructure:integer;
       StBM:string;Stan,s1,s2,s3,s4,s5,s6,s7,s8,s9,s10:char;
       Levo,Letaet,Plyvet:boolean);
       Procedure Attack(Alvl:integer);
      end;
    //....
    Constructor TBattleBot.Create(xbm,ybm,xr,yr,Widthr,Heightr,xb,yb,
    CBMm,CBMl,CBMu,CBMa,CBMd,CBMk,BMSpeed,
    xSnarad,ySnarad,Sxr,Syr,Sxb,Syb,SxSpeed,SySpeed,SPZh,Slvl,SBMSpeed,
    SWidthbm,SHeightbm,SWidthr,SHeightr,
    MxSp,MySp,LxSp,LySp,UxSp,UySp,
    c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,Damage,Defence,Structure,TStructure:integer;
    StBM:string;Stan,s1,s2,s3,s4,s5,s6,s7,s8,s9,s10:char;
    Levo,Letaet,Plyvet:boolean);
    begin
    inherited Create(xbm,ybm,xr,yr,Widthr,Heightr,xb,yb,StBM,Stan,Levo);
    fBMSpeed:=BMSpeed;
    fStan:=Stan;
    fCBMm:=CBMm;
    fCBMl:=CBMl;
    fCBMa:=CBMa;
    fCBMd:=CBMd;
    fCBMk:=CBMk;
    fLevo:=Levo;
    fLetaet:=Letaet;
    fPlyvet:=Plyvet;
    fxSnarad:=xSnarad;
    fySnarad:=ySnarad;
    fSxr:=Sxr;
    fSyr:=Syr;
    fSxb:=Sxb;
    fSyb:=Syb;
    fSxSpeed:=SxSpeed;
    fSySpeed:=SySpeed;
    fSPZh:=SPZh;
    fSlvl:=Slvl;
    fSBMSpeed:=SBMSpeed;
    fSWidthbm:=SWidthbm;
    fSHeightbm:=SHeightbm;
    fSWidthr:=SWidthr;
    fSHeightr:=SHeightr;
    fMxSp:=MxSp;
    fMySp:=MySp;
    fLxSp:=LxSp;
    fLySp:=LySp;
    fUxSp:=UxSp;
    fUySp:=UySp;
    fAlgoritm[1].Chastota:=c1;
    fAlgoritm[2].Chastota:=c2;
    //...
    fAlgoritm[1].NStan:=s1;
    fAlgoritm[2].NStan:=s2;
    //...
    fCA:=0;
    fTAlgoritm:=1;
    fDamage:=Damage;
    fDefence:=Defence;
    fStructure:=Structure;
    fTStructure:=TStructure;
    end;

    Так говнокодил мой друг реалтаймовую игрушку.
    Описание юнита.

    Janycz, 29 Ноября 2015

    Комментарии (10)
  10. Pascal / Говнокод #19046

    −3

    1. 001
    2. 002
    3. 003
    4. 004
    5. 005
    6. 006
    7. 007
    8. 008
    9. 009
    10. 010
    11. 011
    12. 012
    13. 013
    14. 014
    15. 015
    16. 016
    17. 017
    18. 018
    19. 019
    20. 020
    21. 021
    22. 022
    23. 023
    24. 024
    25. 025
    26. 026
    27. 027
    28. 028
    29. 029
    30. 030
    31. 031
    32. 032
    33. 033
    34. 034
    35. 035
    36. 036
    37. 037
    38. 038
    39. 039
    40. 040
    41. 041
    42. 042
    43. 043
    44. 044
    45. 045
    46. 046
    47. 047
    48. 048
    49. 049
    50. 050
    51. 051
    52. 052
    53. 053
    54. 054
    55. 055
    56. 056
    57. 057
    58. 058
    59. 059
    60. 060
    61. 061
    62. 062
    63. 063
    64. 064
    65. 065
    66. 066
    67. 067
    68. 068
    69. 069
    70. 070
    71. 071
    72. 072
    73. 073
    74. 074
    75. 075
    76. 076
    77. 077
    78. 078
    79. 079
    80. 080
    81. 081
    82. 082
    83. 083
    84. 084
    85. 085
    86. 086
    87. 087
    88. 088
    89. 089
    90. 090
    91. 091
    92. 092
    93. 093
    94. 094
    95. 095
    96. 096
    97. 097
    98. 098
    99. 099
    100. 100
    uses
      graphabc;
    
    var
      a, b, c, d, e, x: longint;
      a1, a3, b3, a4, b4, b1, c1, c2, y: longint;
      a2, b2: integer;
    
    procedure osordinat;
    begin
      line(325, 25, 325, 425, clblack);
      line(25, 225, 625, 225, clblack);
      line(320, 30, 325, 25, clblack);
      line(330, 30, 325, 25, clblack);
      line(620, 220, 625, 225, clblack);
      line(620, 230, 625, 225, clblack);
    end;
    
    begin
      c1 := 325; c2 := 225;
      Writeln('Уравнение имеет вид A*(X^2)+B*(Y^2)+C*X+D*Y+E = 0');Writeln('Введите параметры A,B,C,D,E');Write('Параметр A = ');read(a);Writeln(a);Write('Параметр B = ');read(b);Writeln(b);Write('Параметр C = ');read(c);Writeln(c);Write('Параметр D = ');read(d);Writeln(d); Write('Параметр E = ');//для сокращения строк, здесь просто ввод данных
      read(e);
      Writeln(e);
      a3 := round((b * sqr(c) + a * sqr(d) - (4 * a * b * e)) / (4 * sqr(a) * b));
      b3 := round((b * sqr(c) + a * sqr(d) - (4 * a * b * e)) / (4 * sqr(b) * a));
      a4 := round((c / (2 * a)));
      b4 := round((d / (2 * b)));
      if a3 < 0 then begin
        if b3 < 0 then writeln('no') else 
        begin
          writeln('Гипербола вида  : ((Y+', b4, ')^2)/', b3, ' - ((X+', a4, ')^2)/', a3, ' = 1');
          a1 := round(sqrt(abs(a3)));b1 := round(sqrt(abs(b3)));a2 := -a4;b2 := -b4;
          x := -1;
          repeat
            if x = 325 then break;
            x := (x + 1);
            if (sqr(x - a2) + sqr(a1)) >= 0 then 
            begin
              if abs(y) > 225 then writeln('Слишком большое значение получается, попробуй снова') else begin
                y := round((b1 / a1) * (sqrt((sqr(x - a2) + sqr(a1))) + b2));
                circle(c1 + 2 * x, c2 - 2 * y, 1);
                circle(c1 + 2 * x, c2 + 2 * y, 1);
                osordinat;
                circle(c1 + 10 * a2, c2 - 10 * b2, 1);
              end;
            end; 
          until abs(y) = 225;
          x := 1;
          repeat
            if x = -325 then break;
            x := (x - 1);
            if (sqr(x - a2) + sqr(a1)) >= 0 then 
            begin
              if abs(y) > 225 then writeln('Слишком большое значение получается, попробуй снова') else begin
                y := round((b1 / a1) * (sqrt((sqr(x - a2) + sqr(a1))) + b2));
                circle(c1 + 2 * x, c2 - 2 * y, 1);
                circle(c1 + 2 * x, c2 + 2 * y, 1);
                osordinat;
                circle(c1 + 10 * a2, c2 - 10 * b2, 1);
              end; 
            end;
          until abs(y) = 225;
        end
      end 
      else  
      begin
        if b3 > 0 then begin
          a1 := round(sqrt(abs(a3)));b1 := round(sqrt(abs(b3)));a2 := (-1 * a4);b2 := (-1 * b4);
          ellipse((c1 + 10 * a1 + 10 * a2), (c2 - 10 * b2 - 10 * b1), (c1 + 10 * a2 - 10 * a1), (c2 - 10 * b2 + 10 * b1));
          osordinat;
          circle(c1 + 10 * a2, c2 - 10 * b2, 1);
          writeln('Элипс вида : ((X+', a4, ')^2)/', a3, ' + ((Y+', b4, ')^2)/', b3, ' = 1');
        end
        else  begin
          writeln('Гипербола вида : ((X+', a4, ')^2)/', a3, ' - ((Y+', b4, ')^2)/', (-1) * b3, ' = 1');
          a1 := round(sqrt(abs(a3)));b1 := round(sqrt(abs(b3)));a2 := -a4;b2 := -b4;
          begin
            x := a2 + a1 - 1;
            repeat
              if x > 325 then break;
              x := (x + 1);
              if (sqr(x - a2) - sqr(a1)) >= 0 then begin
                y := round((b1 / a1) * (sqrt((sqr(x - a2) - sqr(a1))) + b2));
                if abs(y) > 225 then writeln('Слишком большое значение получается, попробуй снова') else begin
                  circle(c1 + 2 * x, c2 - 2 * y, 1);
                  circle(c1 + 2 * x, c2 + 2 * y, 1);
                  osordinat;
                end;
              end; 
            until abs(y) = 225;
            x := a2 - a1 + 1;
            repeat
              if x < -325 then break;
              x := (x - 1);
              if (sqr(x - a2) - sqr(a1)) >= 0 then begin
                if abs(y) > 225 then writeln('Слишком большое значение получается, попробуй снова') else begin
                  y := round((b1 / a1) * (sqrt((sqr(x - a2) - sqr(a2))) + b2));
                  circle(c1 + 2 * x, c2 - 2 * y, 1);
                  circle(c1 + 2 * x, c2 + 2 * y, 1);
                  osordinat;end; end; until abs(y) = 225;end; end;end;end. //Чтобы сократить колличество строк

    Первокурсник, представляю код от бога, который должен рисовать и распознавать по введенным данным кривую 2-го порядка. Если вы умрете со смеху, я не виноват.

    Petr-Koshka, 18 Ноября 2015

    Комментарии (76)