1. Куча / Говнокод #25379

    0

    1. 1
    https://www.bellingcat.com/resources/how-tos/2019/02/14/creating-your-own-citizen-database/

    Новые веяния - код в виде скриншотов, сырцы скачать нельзя.

    syoma, 15 Февраля 2019

    Комментарии (204)
  2. Куча / Говнокод #25374

    0

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    Офигеть, sql-дамп говнокода весит всего 240Мб.
    
    Может переписать на "C++" и держать все индексы в памяти?
    А на фронте будет только обращение к JSON API. И можно хоть мобильное приложение делать на "Electron.js".
    Клиент будет подписан на интересующие его события, например на сток и на ответы на его коменты.
    Никто не хочет заняться по фану?

    guestinxo, 12 Февраля 2019

    Комментарии (49)
  3. Куча / Говнокод #25367

    −1

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    Блестящий результат дает чистка сосудов, а также избавление от паразитов очень простой рецепт — лимон с чесноком:
    
        берете 4 лимона, держите их 10 секунд в горячей воде, потом разрезаете на 2 половинки, выжимаете сок,
        берете 1 головку чеснока, очищаете, натираете на терке,
        соединяете 2 ингредиента, оставляете в шкафу на 3 суток, затем процеживаете,
        жидкость храните в холодильнике.
    
    Утром наливаете 1 ст. л. жидкости в 50 мл воды, выпиваете натощак. 
    Когда состав закончится, делаете второй, третий, четвертый. 
    Ваши сосуды так очистятся, что вы будете не ходить, а летать!

    >держите их 10 секунд в горячей воде
    нахуя?

    >Утром наливаете 1 ст. л. жидкости в 50 мл воды, выпиваете натощак.
    Белиссимо! Браво! Заранее запишитесь к гастроэнтерологу - пойдёте, когда похерите себе желудок.

    cmepmop, 10 Февраля 2019

    Комментарии (25)
  4. Куча / Говнокод #25357

    0

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    Как вы думаете, чем отличаются эти два параметра в Django?
    
    use_tls: EMAIL_USE_TLS
    use_ssl: EMAIL_USE_SSL
    
    ответ в комменте

    EMAIL_USE_TLS
    Whether to use a TLS (secure) connection when talking to the SMTP server

    EMAIL_USE_SSL
    Whether to use an implicit TLS (secure) connection when talking to the SMTP server

    gueest8, 05 Февраля 2019

    Комментарии (41)
  5. Куча / Говнокод #25340

    +1

    1. 1
    https://i.imgur.com/7uRLULs.mp4

    Аппаратная нейросеть в мозгах петуха совершила ошибку классификации.

    j123123, 30 Января 2019

    Комментарии (47)
  6. Куча / Говнокод #25331

    −2

    1. 1
    2. 2
    3. 3
    Кому тут надо вертуху крутануть чтобы добавили больше языков?
    Нынче не 2000й год. Народ уже во всю ебашит на котлинах, скалах (не путать с горными образованиями), го всяких там, расте, эрланге, форте и прочей поеботе.
    В конце то концов, сколько можно ждать? Одмен, пидр, запили языки!!11!

    Lorip1971, 27 Января 2019

    Комментарии (29)
  7. Куча / Говнокод #25329

    0

    1. 1
    Просто оффтоп #2

    #1: http://govnokod.xyz/_20162 https://govnokod.ru/20162

    syoma, 26 Января 2019

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

    0

    1. 1
    IT Оффтоп #10

    #1: http://govnokod.ru/18142 http://govnokod.xyz/_18142
    #2: http://govnokod.ru/18378 http://govnokod.xyz/_18378
    #3: http://govnokod.ru/19667 http://govnokod.xyz/_19667
    #4: http://govnokod.ru/21160 http://govnokod.xyz/_21160
    #5: http://govnokod.ru/21772 http://govnokod.xyz/_21772
    #6: http://govnokod.ru/24063 http://govnokod.xyz/_24063
    #7: http://govnokod.ru/24538 http://govnokod.xyz/_24538
    #8: http://govnokod.ru/24815 (потёр пидор сракер) http://govnokod.xyz/_24815
    #9: http://govnokod.ru/24867 http://govnokod.xyz/_24867

    syoma, 26 Января 2019

    Комментарии (659)
  9. Куча / Говнокод #25312

    −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
    Мне приснился очень странный сон, который отчасти был навеян дебатами между сторонниками и противниками ООП...
    Во сне я видел паперть, на которой выступал лысый человек, похожий на Соловьева. Он очень волновался, ежеминутно протирая платком лицо и макушку.
    Господа! - наконец объявил он. Сегодня исторический день! Мы выслушаем прения сторон, в лице мэтра ООП и адепта функционального стиля. 
    Раздались бурные аплодисменты и на сцену вышли аллегорические фигуры. Мэтром ООП оказался сурового вида старик в пышной золотой мантии и 
    венце, адепт функциональщины - сдержанный юноша, очень элегантно одетый.
    Кроме них двоих, на паперть поднялся также и молодой человек в охотничьей шляпе, с куском оленьей шерсти вместо пера.
    -Томаш Грыштар, представился он, и раскланялся. Он сильно картавил, но был безукоризненно вежлив, едва не падая с ног от услужливости.
    Конферансье потёр руки. Итак господа, перейдём к делу. Сегодня мы поднимем со дна океана (шутка) на свет божий достоинства и недостатки обоих 
    парадигм а поможет нам в этом наш друг Томас. Пусть в споре откроется истина.
    -ООП не нужно, - бесцеремонно выпалил Адепт.
    -О, это очень смелое заявление! -  засмеялся конферансье.
    Мэтр густо покраснел, но не проронил ни слова.
    -Что Вы на это скажете, сударь?
    Мэтр сидел с каменным лицом. Конферансье, не дождавшись ответа, передал право слова Томасу:
    -Полагаю, что наш друг-ассемблерщик тоже имеет право высказаться.
    Тот достал из-за пазухи изящную золотую шкатулочку и, заведя ручку, открыл ее. Раздалась нежная мелодия.
    Мэтр наконец прервал обет молчания:
    -А что сталось с Вашим "Титаном"?
    -Я... Э-э-э... Потерял исходники...
    -Весьма прискорбно. Но  Вы сохранили компилятор?
    -"Фасм", сударь.
    -Господа, господа! Мы ведь собрались ради важного дела, а до сих пор ничего дельного не нашли.
    -ООП нерационально использует память,  - адепт опять вмешался.
    При этих словах Мэтр чуть покачнулся, раздался громкий скрип. Мантия его задралась - и всем стало ясно, что он сидит в инвалидном кресле.
    Томас опять достал шкатулочку, очевидно, чтобы разрядить атмосферу.
    -ООП учит плохому стилю. Адепт вынул розочку из петлицы и стал ее нюхать. Лицо у него было равнодушное.
    Мэтр вздохнул, склонил голову, но ничего не ответил.
    Томас опять достал шкатулочку.
    Конферансье вытер пот со лба и заявил: -Господа, мне кажется, мы напрасно тратим время.
    Шкатулочка вдруг ошиблась. Томас поднял ее над головой, потряс - и о ужас!- раздался громоподобный треск и в мгновение ока Томас был погребен 
    под грудой шестеренок, пружин и коленчатых валов. Конферансье и Мэтр поспешили ему на помощь. Адепт сохранял невозмутимость, не пошевелив 
    даже пальцем. 
    -Дебаты окончены. Конферансье хлопнул в ладоши и сошёл со сцены. Было видно, что он глубоко уязвлен.
    К адепту подошёл человек в сюртуке и похлопал его по плечу. Юноша ойкнул и недовольно обернулся.
    Оказалось, что это полуидиот, очевидно, больной синдромом Дауна. Опекун вручил ему ниточки от красного и жёлтого воздушных шариков, 
    отчего инфантильное лицо юноши озарилось радостью. Они медленно пошли по тропинке...
    Томаш и Мэтр долго смотрели ему вслед.
    -Как Вы думаете, коллега, уместны ли асмовставки в языке высокого уровня?
    -Почему бы и нет?
    -Я рад, что Вы так считаете.

    ...

    cmepmop, 15 Января 2019

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

    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
    fn do_get_summary(req: &HttpRequest<AppState>) -> SummaryFuture {
        let token = req.token().expect("ISE: token not verified during AuthMiddleware stage");
    
        let datetime = req.match_info()
            .get("timestamp")
            .and_then(|s| i64::from_str(s).ok())
            .map(|ts| NaiveDateTime::from_timestamp(ts, 0));
    
        let datetime = match datetime {
            Some(dt) => dt,
            None => return Box::new(future::result(Err(ServiceError::InvalidSetting {
                key: "timestamp".into(),
                hint: "local time in seconds since Unix Epoch".into()
            }.into())))
        };
    
        let db = req.state().db.clone();
    
        let settings = req.state().db
            .send(db::GetSettings(token.clone()))
            .map_err(failure::Error::from)
            // flatten error
            .and_then(|res| match res {
                Ok(settings) => Ok(settings),
                Err(err) => Err(err)
            });
    
        let fitbit = req.state().db
            .send(db::GetSettingsFitbit(token))
            .map_err(failure::Error::from)
            // Check if there is token and flatten error
            .and_then(|res| match res {
                Ok(fitbit) => {
                    if fitbit.client_token.is_none() {
                        Err(ServiceError::TokenExpired.into())
                    } else {
                        Ok(fitbit)
                    }
                },
                Err(err) => Err(err)
            });
    
        let headmaster = req.state().headmaster.clone();
    
        let summary_and_token = settings.join(fitbit)
            .and_then(move |(settings, fitbit)| -> Box<dyn Future<Item = (Summary, FitbitToken), Error = failure::Error>> {
                // Deserialize token
                let token = fitbit.client_token.expect("ISE: token option is not cleared");
                let fitbit_token = match FitbitToken::from_json(&token) {
                    Ok(token) => token,
                    Err(err) => return Box::new(future::err(ServiceError::TokenExpired.into()))
                };
    
                let headmaster_config = master::HeadmasterConfig {
                    minimum_active_time: settings.hourly_activity_goal,
                    max_accounted_active_minutes: settings.hourly_activity_limit.unwrap_or(settings.hourly_activity_goal * 3),
                    debt_limit: settings.hourly_debt_limit.unwrap_or(settings.hourly_activity_goal * 3),
                    day_begins_at: settings.day_starts_at,
                    day_ends_at: settings.day_ends_at,
                    day_length: settings.day_length.unwrap_or((settings.day_ends_at.hour() - settings.day_starts_at.hour()) as i32),
                    user_date_time: datetime,
                };
    
                let auth_data = FitbitAuthData {
                    id: fitbit.client_id,
                    secret: fitbit.client_secret,
                    token: fitbit_token,
                };
    
                let future = headmaster.send(master::GetSummary::<FitbitActivityGrabber>::new(headmaster_config, auth_data))
                    .map_err(failure::Error::from)
                    // flatten error
                    .and_then(|res| res);
    
                Box::new(future)
            });
    
        let summary = summary_and_token
            .and_then(move |(summary, fitbit_token)| {
                db.send(db::UpdateSettingsFitbit::new(
                    token, db::models::UpdateFitbitCredentials {
                        client_token: Some(Some(fitbit_token.to_json())),
                        ..Default::default()
                    }))
                    .map_err(failure::Error::from)
                    .and_then(|_| Ok(summary))
            });
    
        Box::new(summary)
    }

    Фьючи в Rust до рефакторинга -- тот еще говнокод

    mersinvald, 12 Января 2019

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