• Как удалить Ubuntu, установленню рядом с Win10?

    nazarpc
    @nazarpc
    Open Source enthusiast
    Удалить диск + запустить (с установочного диска Windows, к примеру) восстановление загрузчика, чтобы Windows свой прописал на место.
    Ответ написан
    Комментировать
  • Как cконфигурировать git?

    27cm
    @27cm
    TODO: Написать статус
    Ветка - это указатель на коммит, она не может располагаться в какой-то отдельной директории. Разберитесь с теорией, затем почитайте про gitflow.
    Ответ написан
    Комментировать
  • Возможна слежка за пользователями в организации?

    DJZT
    @DJZT
    Laravel - code for you
    Вопрос в конце странно задан. Как буд-то это вам поручили организовать слежку в организации и в инкогнито режиме браузеров. А вообще конечно. Обычный проксирющий сервер видит весь трафик, который идёт через него. Но если организация большая - то его будет сложно просматривать в реальном времени. Но отфильтровать оп IP, если сеть нормально настроена - то проблем вообще не составит
    Ответ написан
  • Как получить множеством дни месяцев текущего года?

    import calendar
    
    year = 2015
    print [
        list(range(1, calendar.monthrange(year, month)[1] + 1))
        for month in range(1, 13)
    ]

    https://docs.python.org/2/library/calendar.html#ca...
    Ответ написан
    Комментировать
  • Как выбрать открытый проект на Python для поддержки?

    EvilsInterrupt
    @EvilsInterrupt
    System programming, Reversing Engineering, C++
    Вливайтесь в сам проект по развитию Python-а. Там же много работы: Перевод, документация, библиотеки, CPython и др. Да. Сразу будет жесть как тяжело, но зато потом, потом будет такая визитная карточка, что достаточно быстро будете находить новую работу.
    Ответ написан
    2 комментария
  • Как выбрать открытый проект на Python для поддержки?

    @bromzh
    Drugs-driven development
    1) Выбираешь проект (для начала небольшой), которым пользуешься сам.
    2) Смотришь список issues
    3) Выбираешь ту, которую сможешь сделать сам (для начала лучше поправить небольшую багу)
    4) Форкаешь проект
    5) Реализуешь issue
    6) Гоняешь тесты
    7) Если всё ок, делаешь пулл-реквест автору
    8) Повторить

    Ну и главное, надо следовать общему стилю всего проекта и про pep-8 помнить.
    Ответ написан
    Комментировать
  • Как сделать POST запрос на Debian?

    DevMan
    @DevMan
    curl -X POST -d '{"PhoneNumber": "номер телефона", "Text": "сообщение"}' -H "Content-Type: application/json" http://сервер.ру/api/Mts/SendMessage
    Ответ написан
    2 комментария
  • Какие знания нужны, что бы написать подобное приложение (см. картинку)?

    Ну, раз вы хотите
    выложить в Google Play
    ,
    логично будет использовать Android SDK.
    В данном случае графические
    движки, типа LibGDX, будут излишни.Вам вполне хватит стандартных
    андройдовских элементов ui.
    Но , если вы хотите сделать кроссплатформенную игру с хорошим дизайном
    и интерфейсом, тогда присмотритесь к LibGDX.
    Ccылки на стандартные курсы(бесплатные, синяя кнопка):
    Android от Google
    LibGDX и 2d Platformer
    Ответ написан
    1 комментарий
  • Как использовать хуки в git?

    yarkov
    @yarkov Автор вопроса
    Помог ответ? Отметь решением.
    1. Переименовать файл pre-commit.sample в pre-commit
    2. Перед всем кодом вписываем строку
    exec python путь/к/скрипту.py
    3. Радуемся )))
    Ответ написан
    Комментировать
  • Как использовать хуки в git?

    DevMan
    @DevMan
    https://git-scm.com/book/en/v2/Customizing-Git-Git...
    https://git-scm.com/book/ru/v1/Настройка-Git-Перех...

    для поставленной задачи необходимо создать pre-commit хук и не забыть сделать его исполняемым.
    Ответ написан
    4 комментария
  • Как создать дерево из большого, сортированного списка словарей?

    angru
    @angru
    накидал на бумажке, работоспособность не проверял. сложность O(n), при условии, что массив отсортирован.

    def transform(data):
        temp = {}
    
        for raw_item in data:
            item = {
                'link': raw_item['link'],
                'parent': raw_item['parent'],
                'children': [],
            }
    
            temp[item['link']] = item
    
            if not item['parent']:
                parent = item
            else:
                temp[item['parent']]['children'].append(item)
    
        return parent
    
    if __name__ == '__main__':
        res = transform(sorted(data, key=lambda x: x['link']))
    Ответ написан
    Комментировать
  • Какой редактор для разработки вы используете?

    zualex
    @zualex
    Senior Software Engineer
    vim
    Ответ написан
    Комментировать
  • Попросили проверить код, на что смотреть нужно?

    index0h
    @index0h
    PHP, Golang. https://github.com/index0h
    Смотря зачем)). Я когда делаю Code Review критерии следующие:

    * Безопасность:
    - Каждый аргумент метода простого типа должен проверяться на тип в случае его проксирования и на граничные значения в случае обработки. Чуть что не так - бросается исключение. Если метод с кучкой аргументов на 80% состоит из поверки из аргументов - это вполне норм))
    - Никаких trigger_error, только исключения.
    - Исключения ДОЛЖНЫ быть человеко-понятны, всякие "Something went wrong" можно отдавать пользователю, но в лог должно попасть исключение со стектрейсом и человеко-понятным описанием, что же там пошло не так.
    - Каждый аргумент (объект) метода должен быть с тайпхинтингом на этот его класс, или интерфейс.
    - За eval как правило шлю на **й.
    - @ допускается только в безвыходных ситуациях, например проверка json_last_error.
    - Перед работой с БД - обязательная проверка данных.
    - Никаких == и !=. Со swtich - единственное исключение, по ситуации.
    - Если метод возвращает не только bool, а еще что-то - жесткая проверка с ===, или !== обязательна.
    - Никаких условий с присваиваниями внутри. while($row = ...) - тоже идет лесом.
    - Магические геттеры/сеттеры разрешаются только в безвыходных ситуациях, в остальном - запрещены.
    - Конкатенации в sql - только в безвыходных ситуациях.
    - Параметры в sql - ТОЛЬКО через плейсхолдеры.
    - Никаких глобальных переменных.
    - Даты в виде строки разрешаются только в шаблонах и в БД, в пхп коде сразу преобразуется в \DateTimeImmutable (в безвыходных ситуациях разрешено \DateTime)
    - Конечно зависит от проекта, но как приавло должно быть всего две точки входа: index.php для web и console(или как-то по другому назваться) - для консоли.

    * Кодстайл PSR-2 + PSR-5 как минимум, + еще куча более жестких требований (для начала все то что в PSR помечено как SHOULD - становится MUST)
    - В PhpStorm ни одна строчка не должна подсвечиваться (исключением является typo ошибки, например словарик не знает какой-то из аббревиатур, принятых в вашем проекте). При этом разрешается использовать /** @noinspection *** */ для безвыходных ситуаций.
    - Если кто-то говорит, что пишет в другом редакторе и у него не подсвечивается, на эти отговорки кладется ВОТ ТАКЕЕЕНЫЙ мужской половой **й и отправляется на доработку)).

    * Организация кода:
    - Никаких глобальных функций.
    - Классы без неймспейса разрешаются только в исключительно безвыходных ситуациях.

    * Тестируемость (в смысле простота тестирования) кода должна быть высокая.
    - Покрытие кода обязательно для всех возможных кейсов использования каждого публичного метода с моками зависимостей.

    * Принципы MVC:
    - Никаких обработок пользовательского ввода в моделях, от слова совсем.
    - Никаких ***ть запросов в БД из шаблонов.
    - Никаких верстки/js/css/sql-ин в контроллерах.
    - В моделях НИКАКОЙ МАГИИ, только приватные свойства + геттеры с сеттерами.
    - В моделях разрешено использовать метод save(при наличии такого разумеется) только в исключительных ситуациях. Во всех остальных - либо insert, либо update.

    * Принципы SOLD:
    - Никаких божественных объектов умеющих во все.
    - Если метод для внутреннего пользования - private, никаких public.
    - Статические методы разрешаются только в случае безвыходности.

    * Принцип DRY разрешено нарушать в случаях:
    - Явного разделения обязанностей
    - В тестах (каждый тест должен быть независимым, на сколько это возможно)

    * Работа с БД:
    - Запрос в цикле должен быть РЕАЛЬНО обоснован.
    - За ORDER BY RAND() - шлю на***й.
    - Поиск не по ключам (конечно если таблица НЕ на 5 строк) запрещен.
    - Поиск без LIMIT (опять же если таблица НЕ на 5 строк) запрещен.
    - SELECT * - запрещен.
    - Денормализация БД должна быть обоснована.
    - MyISAM не используется (так уж)) )
    - Множественные операции обязательно в транзакции, с откатом если чо пошло не так.
    - БД не должна содержать бизнес логики, только данные в целостном виде.
    - Не должно быть нецелесообразного дерганья БД там, где без этого можно обойтись.

    * Кэш должен очищаться по двум условиям (не по одному из, а именно по двум):
    - Время.
    - Протухание по бизнес логике.
    Разрешается по только времени в безвыходных ситуациях, но тогда время - короткий период.
    - При расчете ключей кэша должна использоваться переменная из конфигурации приложения (на случай обновлений кэш сбрасывается кодом, а не флашем кэш-сервера). В случае использования множества серверов - это очень удобный и гибкий инструмент при диплое.

    * О людях:
    - "Я привык писать так и буду дальше" - не вопрос, ревью пройдешь только когда поменяешь свое мнение.
    - "Я пишу в vim-е и мне так удобно" - здорово, код консолью я тоже в нем пишу)) но есть требования к коду, если в них не сможешь - не пройдешь ревью.
    - "Я скопировал этот страшный метод и поменял 2 строчки" - это конечно замечательно, но по блейму автор всего этого метода ты, так что давай без говняшек, хорошо?
    - "Оно же работает!" - вот эта фраза переводится примерно так: "да, я понимаю, что пишу полную хрень, но не могу писать нормально потому, что руки из жо", я правильно тебя понял?))
    - "У меня все работает!" - рад за тебя, а как на счет продакшна?
    - "Там все просто" - не используй слово "просто", от слова "совсем". Вот тебе кусок кода (первого попавшегося с сложной бизнес логикой), где там ошибка (не важно есть она, или нет)? Ты смотришь его уже 2 минуты, в чем проблема, там же все "просто"))

    * Всякое:
    ActiveRecord (это я вам как в прошлом фанат Yii говорю) - полное говно, примите за исходную. По факту у вас бесконтрольно по проекту гуляют модельки с подключением к БД. Не раз натыкался на то, что в тех же шаблонах вызывают save, или update (за такое надо сжигать).
    То, что используется Laravel - это печально((. Что бы выполнить требования приведенные выше, приходится "воевать" с фреймворком.

    Это далеко не полный список требований, очень много зависит от проекта в целом и от принципов, заложенных в нем. Для больших мредж реквестов 200 комментариев к коду - это ок. Дерзайте.

    UPD

    Формализировал данные критерии по ссылочке: https://github.com/index0h/php-conventions
    Ответ написан
    55 комментариев
  • Как получить права доступа на редактирование файла?

    zooks
    @zooks
    Frontend
    Запустить конкретный скрипт от рута.
    Ответ написан
    Комментировать
  • Не работает модуль python-instagram, что не так?

    @AviPaperno Автор вопроса
    Решение найдено здесь. Необходимо в файле hmac.py заменить строчку return HMAC(key, msg, digestmod)
    на
    return HMAC(key.encode(), msg.encode(), digestmod)
    Ответ написан
    3 комментария
  • Как сделать бэкап всей системы в офисе на внешний NAS?

    @LiguidCool
    Windows Backup, Acronis.
    Ответ написан
    Комментировать
  • Фронтенд - каковы шансы пробиться?

    Ewintory
    @Ewintory
    Java / Android developer
    Шансов никаких, если целыми днями глупые вопросы на тостере задавать.
    Ответ написан
    1 комментарий