1. Лучший говнокод

    В номинации:
    За время:
  2. Куча / Говнокод #25662

    −102

    1. 1
    Гниль

    Всё - гниль.

    AHCKujlbHblu_netyx, 05 Июня 2019

    Комментарии (16)
  3. Си / Говнокод #25440

    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
    // https://patents.google.com/patent/US20160357533A1/en
    // Generating code in statically typed programming languages for dynamically typed array-based language 
    /*
    Example 2
    
    The cell array is classified as heterogeneous and translated into a C structure. Source code includes the following array, which is classified as belonging to a heterogeneous class.
    	
    x = {‘add’, d1, ‘multiply’, d2, ‘add’, 1, ‘add’, 1};
    ...
    function y = process (x)
     ...
     y = 0;
     for i = 1:2:numel(x)
      if ~strcmp(x{i}, ‘add’)
       y = y + x{i+ 1};
      elseif ~strcmp(x{i}, ‘multiply’)
       y = y * x{i+1};
      end
     end
    end
    
    C code generated in the STPL contains a C structure type that is used for the variable “x”:
    */
    typedef struct {
        char f1[3];
        double f2;
        char f3[8];
        double f4;
        char f5[3];
        double f6;
        char f7[3];
        double f8;
      } cell_0;
    static double process(const cell_0 x)
    {
      ...
    }

    Сраные софтерные патенты. Блядь, вдумайтесь в эту хуйню. Вам дан динамически-типизированный язык, вот типа есть такой "массив" в котором элементы могут быть произвольной поеботой, например строками, флоатами. Как нам это оттранслировать? Да запросто, вот допустим есть такое говно: x = {‘add’, d1, ‘multiply’, d2, ‘add’, 1, ‘add’, 1}; - хуйнуть структуру надо
    typedef struct {
      char f1[3]; // тут сука 3 буквы потому что слово "add" из трех букв
      double f2;
      char f3[8]; // тут сука 8 букв потому что слово "multiply" из 8 букв
      double f4;
      char f5[3]; // тут сука 3 буквы потому что слово "add" из трех букв
      double f6;
      char f7[3]; // тут сука 3 буквы потому что слово "add" из трех букв
      double f8;
    } cell_0;

    А нахуй? Ну т.е. вот потом там будет сгенерен в сишке код, который будет через memcmp проверять этот char f1[3] что там "add", и потом будет еще код, который проверит что char f3[8] это "multiply", да? Ну т.е. у вас структура специализирована под конкретную поебень x = {‘add’, d1, ‘multiply’, d2, ‘add’, 1, ‘add’, 1}; и там блядь и так понятно, что вот там будет add, там будет multiply, и что вот такое количество элементов, это ясно из самого определения структуры, нахуй это говно вообще? И это говно еще запатентовали

    j123123, 10 Марта 2019

    Комментарии (16)
  4. Си / Говнокод #25289

    +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
    int etm_readl_cp14(u32 reg, unsigned int *val)
    {
    	switch (reg) {
    	case ETMCR:
    		*val = etm_read(ETMCR);
    		return 0;
    	case ETMCCR:
    		*val = etm_read(ETMCCR);
    		return 0;
    	case ETMTRIGGER:
    		*val = etm_read(ETMTRIGGER);
    		return 0;
    	case ETMSR:
    		*val = etm_read(ETMSR);
    		return 0;
    	case ETMSCR:
    		*val = etm_read(ETMSCR);
    		return 0;
    	case ETMTSSCR:
    		*val = etm_read(ETMTSSCR);
    		return 0;
    	case ETMTEEVR:
    		*val = etm_read(ETMTEEVR);
    		return 0;
    	case ETMTECR1:
    		*val = etm_read(ETMTECR1);
    		return 0;
    	case ETMFFLR:
    		*val = etm_read(ETMFFLR);
    		return 0;
    	case ETMACVRn(0):
    		*val = etm_read(ETMACVR0);
    		return 0;
    	case ETMACVRn(1):
    		*val = etm_read(ETMACVR1);
    		return 0;
    	case ETMACVRn(2):
    		*val = etm_read(ETMACVR2);
    		return 0;
    	case ETMACVRn(3):
    		*val = etm_read(ETMACVR3);
    		return 0;
    	case ETMACVRn(4):
    		*val = etm_read(ETMACVR4);
    		return 0;
    	case ETMACVRn(5):
    		*val = etm_read(ETMACVR5);
    		return 0;
    	case ETMACVRn(6):
    		*val = etm_read(ETMACVR6);
    		return 0;
    	case ETMACVRn(7):
    		*val = etm_read(ETMACVR7);
    		return 0;
    	case ETMACVRn(8):
    		*val = etm_read(ETMACVR8);
    		return 0;
    	case ETMACVRn(9):
    		*val = etm_read(ETMACVR9);
    		return 0;
    	case ETMACVRn(10):
    		*val = etm_read(ETMACVR10);
    		return 0;
    	case ETMACVRn(11):
    		*val = etm_read(ETMACVR11);
    		return 0;
    	case ETMACVRn(12):
    		*val = etm_read(ETMACVR12);
    		return 0;
    	case ETMACVRn(13):
    		*val = etm_read(ETMACVR13);
    		return 0;
    	case ETMACVRn(14):
    		*val = etm_read(ETMACVR14);
    		return 0;
    	case ETMACVRn(15):
    		*val = etm_read(ETMACVR15);
    		return 0;
    	case ETMACTRn(0):
    		*val = etm_read(ETMACTR0);
    		return 0;
    	case ETMACTRn(1):
    		*val = etm_read(ETMACTR1);
    		return 0;
    	case ETMACTRn(2):
    		*val = etm_read(ETMACTR2);
    		return 0;
    	case ETMACTRn(3):
    		*val = etm_read(ETMACTR3);
    		return 0;
    	case ETMACTRn(4):
    		*val = etm_read(ETMACTR4);
    		return 0;
    	case ETMACTRn(5):
    		*val = etm_read(ETMACTR5);
    		return 0;
    	case ETMACTRn(6):
    		*val = etm_read(ETMACTR6);
    		return 0;
    	...

    Вроде и да, а вроде и нет

    Ksyrx, 06 Января 2019

    Комментарии (16)
  5. Python / Говнокод #24866

    −12

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    7. 7
    #Было:
    sorted(lst, key=lambda x: x['key'])
    #или
    sorted(lst, key=operator.itemgetter('key')
    
    #стало:
    sorted(lst, key=S_['key'])

    Говнокоданы, как вам такая идея?

    syoma, 07 Октября 2018

    Комментарии (16)
  6. Си / Говнокод #24864

    −10

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    7. 7
    val = atoi(curstr);
    count = 0;
    while (val) {
                buf[count] = (val & 0x7f);
                val = val >> 7;
                count++;
    }

    Ноль не число.
    Отсюда:
    https://dxr.mozilla.org/mozilla-central/source/security/nss/cmd/oidcalc/oidcalc.c

    PAAMAYIM_NEKUDOTAYIM, 05 Октября 2018

    Комментарии (16)
  7. 1C / Говнокод #24852

    0

    1. 1
    2. 2
    |			И (ПериодическийРегистрСведенийПриход.ВидДвижения = ЗНАЧЕНИЕ(Перечисление.ОРГ_ВидыДвижений.Приход))
    |			И (ПериодическийРегистрСведений.ВидДвижения = ЗНАЧЕНИЕ(Перечисление.ОРГ_ВидыДвижений.Расход))

    Регистр накопления? Не, это не для нас.

    Vukhdjaaz, 03 Октября 2018

    Комментарии (16)
  8. Куча / Говнокод #24715

    −3

    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
    Dies irae, dies illa
    solvet saeclum in favilla
    teste David cum Sibylla
    
    Quantus tremor est futurus
    quando judex est venturus
    cuncta stricte discussurus
    
    Tuba mirum spargens sonum
    Per sepulcra regionum,
    Coget omnes ante thronum.
    
    Mors stupebit et natura
    Cum resurget creatura
    judicanti responsura
    
    Liber scriptus proferetur
    in quo totum continetur
    unde mundus judicetur
    
    Judex ergo cum sedebit
    quidquid latet apparebit
    nil inultum remanebit
    
    Quid sum miser tunc dicturus
    quem patronum rogaturus
    cum vix justus sit securus?
    
    Rex tremendae majestatis,
    qui salvandos salvas gratis,
    salva me, fons pietatis.
    
    Recordare, Jesu pie,
    quod sum causa tuae viae:
    ne me perdas illa die.
    
    Quaerens me sedisti lassus;
    redemisti crucem passus.
    Tantus labor non sit cassus.
    
    Juste Judex ultionis
    donum fac remissionis
    ante diem rationis.
    
    Ingemisco tanquam reus:
    culpa rubet vultus meus.
    supplicanti parce, Deus.
    
    Qui Mariam absolvisti
    et latronem exaudisti,
    mihi quoque spem dedisti.
    
    Preces meae non sunt dignae,
    sed tu bonus fac benigne,
    ne perenni cremer igne.
    
    Inter oves locum praesta
    et ab haedis me sequestra,
    statuens in parte dextra.
    
    Confutatis maledictis
    flammis acribus addictis,
    voca me cum benedictis.
    
    Oro supplex et acclinis
    cor contritum quasi cinis,
    gere curam mei finis.
    
    Lacrimosa dies illa
    qua resurget ex favilla
    judicandus homo reus.
    
    huic ergo parce, Deus.
    Pie Jesu Domine,
    dona eis requiem.
    
    Amen.

    yet_another_one_shit, 666_N33D135

    Милосердный Господи Админе,
    Даруй им покой!

    Админь.

    ASMOZDOT, 03 Сентября 2018

    Комментарии (16)
  9. Си / Говнокод #24655

    −4

    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
    https://docs.microsoft.com/en-us/windows/desktop/api/winsock/nf-winsock-wsaasyncselect
    int WSAAsyncSelect(
      SOCKET s,
      HWND   hWnd,
      u_int  wMsg,
      long   lEvent
    );
    
    /*
    
    hWnd
    
    A handle that identifies the window that will receive a message when a network event occurs.
    */

    Почему виндовые асинхронные (или правильно говорить "небликирующиеся") сокеты так черезжопно сделаны? Нафига им через HWND надо месседжи слать? Что, другого способа нет для оповещений?
    Требовать для работы асинхронных сокетов чтоб какое-то окно было это как требовать зубную щетку для входа в туалет чтоб посрать

    j123123, 24 Августа 2018

    Комментарии (16)
  10. Куча / Говнокод #24503

    −1

    1. 1
    Keyword Substitution

    Котаны, что мы думаем про keyword Substitution?

    Для тех, кто в танке: была в прошлом веке такая VCS RCS.
    В ней можно было в файле указать

    $Id$

    И в момент чекаута эта строчка заменялась на
    pitushok.txt,v 1.41 02.06.1991 petya

    Где 1.41 -- ревизия, дальше дата и login того кто делал checkout.
    Когда ты потом собирал дистрибутив из сырцов то у каждого файла всегда была инфа о том, кто (И когда) последний его трогал.
    Чуваки умели делать
    static char* id ="$id$";

    В результате чего эта инфа сохранялась в бинарниках, ее можно было выдрать через комманду ident ну или вывести как-то иначе.

    Субж перекочевал в CVS, оттуда в SVN, а в gitе он был признан порочной практикой и там так никто не делает.

    Опенбздуны, например, сидящие на CVS, до сих пор имеют профит. Там везде написано
    $OpenBSD: cat.1,v 1.35 2015/11/04 21:28:01 tedu Exp $


    ...а в линуксах -- нет.

    Знаете про keywords subst? Использовали? что думаете?

    roskomgovno, 17 Июля 2018

    Комментарии (16)
  11. Куча / Говнокод #24445

    −1

    1. 1
    2. 2
    3. 3
    Яндекс начал индексировать Google Документы с паролями
    
    https://habr.com/post/416219/

    А в чем, собственно, здесь вина "Яндекс"? То что пользователи-долбоёбы держат пароли в общедоступных документах?
    В таком случае я и без "Яндекс" могу получить к ним доступ.

    CrashTesteAnusov, 05 Июля 2018

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