From 703c7bad9913aae28b65cc731b7874c6440b655e Mon Sep 17 00:00:00 2001 From: Khorevaa Date: Mon, 20 Feb 2017 22:47:21 +0300 Subject: [PATCH 01/11] =?UTF-8?q?=D0=A0=D0=B5=D1=84=D0=B0=D0=BA=D1=82?= =?UTF-8?q?=D0=BE=D1=80=D0=B8=D0=BD=D0=B3=20=D0=BF=D0=BE=D0=B4=20app-templ?= =?UTF-8?q?ate?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitignore | 1 + packagedef | 3 +- src/opm.os | 113 +++--- ...20\266\320\265\320\275\320\270\321\217.os" | 343 ------------------ ...320\260\320\275\320\264\320\260Opm_App.os" | 71 ++++ ...0\260\320\275\320\264\320\260Opm_Build.os" | 30 ++ ...\260\320\275\320\264\320\260Opm_Config.os" | 24 ++ ...260\320\275\320\264\320\260Opm_Install.os" | 44 +++ ...20\260\320\275\320\264\320\260Opm_List.os" | 55 +++ ...260\320\275\320\264\320\260Opm_Prepare.os" | 26 ++ ...320\260\320\275\320\264\320\260Opm_Run.os" | 27 ++ ...20\260\320\275\320\264\320\260Opm_Test.os" | 28 ++ ...\260\320\275\320\264\320\260Opm_Update.os" | 36 ++ ...260\320\275\320\264\320\260Opm_Version.os" | 18 + ...20\265\321\202\321\200\320\260\320\274.os" | 74 ++++ ...20\262\320\245\320\260\320\261\320\260.os" | 4 +- ...20\272\320\265\321\202\320\276\320\262.os" | 4 +- ...20\260\320\272\320\265\321\202\320\260.os" | 10 +- ...20\260\320\272\320\265\321\202\320\260.os" | 20 +- ...0\260\320\275\320\264\321\213.os-template" | 16 + ...202\320\260\320\275\321\202\321\213Opm.os" | 0 ...266\320\265\320\275\320\270\321\217Opm.os" | 50 +++ ...266\320\265\320\275\320\270\321\217Opm.os" | 0 ...201\321\202\320\265\320\274\321\213Opm.os" | 29 ++ ...21\201\320\270\321\217\320\274\320\270.os" | 2 +- ...20\260\320\272\320\265\321\202\320\260.os" | 2 +- tasks/test.os | 22 ++ tests/build-install-test.os | 8 +- tests/mft-serializer-test.os | 3 +- tests/packagedef-test.os | 2 +- tests/packagelist.os | 1 - tests/pkg-cache.os | 2 - tests/versions-test.os | 1 - 33 files changed, 649 insertions(+), 420 deletions(-) delete mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\224\320\270\321\201\320\277\320\265\321\202\321\207\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_App.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Build.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Config.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Install.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_List.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Prepare.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Run.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Test.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Update.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Version.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260\320\241\320\277\321\200\320\260\320\262\320\272\320\260\320\237\320\276\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\320\260\320\274.os" create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\250\320\260\320\261\320\273\320\276\320\275\320\232\320\276\320\274\320\260\320\275\320\264\321\213.os-template" rename "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" => "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" (100%) create mode 100644 "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" rename "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\235\320\260\321\201\321\202\321\200\320\276\320\271\320\272\320\270\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" => "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\235\320\260\321\201\321\202\321\200\320\276\320\271\320\272\320\270\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" (100%) create mode 100644 "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\321\213\320\241\320\270\321\201\321\202\320\265\320\274\321\213Opm.os" create mode 100644 tasks/test.os diff --git a/.gitignore b/.gitignore index a8aec03..e60a48d 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ oscript_modules/ +test-reports/ \ No newline at end of file diff --git a/packagedef b/packagedef index 1b25574..66d5e07 100644 --- a/packagedef +++ b/packagedef @@ -1,5 +1,5 @@ -ПутьКСценариюКонстант = ОбъединитьПути(ТекущийСценарий().Каталог, "src", "Модули", "Константы.os"); +ПутьКСценариюКонстант = ОбъединитьПути(ТекущийСценарий().Каталог, "src", "Модули", "КонстантыOpm.os"); Константы_ЛокальнаяВерсия = ЗагрузитьСценарий(ПутьКСценариюКонстант); Описание.Имя("opm") @@ -8,6 +8,7 @@ .ЗависитОт("logos") .ЗависитОт("cmdline") .ЗависитОт("tempfiles") + .ЗависитОт("1testrunner") .ВключитьФайл("src") .ОпределяетКласс("ОписаниеПакета", "src/Классы/ОписаниеПакета.os") .ИсполняемыйФайл("src/opm.os"); diff --git a/src/opm.os b/src/opm.os index 78fb0cd..94241b7 100644 --- a/src/opm.os +++ b/src/opm.os @@ -1,60 +1,87 @@ -///////////////////////////////////////////////////////////////////////// +//////////////////////////////////////////////////////////////////////// // -// OneScript Package Manager -// Установщик пакетов для OneScript -// Выполняется, как os-приложение в командной строке: +// CLI-интерфейс для oscript-app +// +//The MIT License (MIT) +// +// Copyright (c) 2016 Andrei Ovsiankin +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in all +// copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +// SOFTWARE. // -// opm install my-package.ospx -// -///////////////////////////////////////////////////////////////////////// +/////////////////////////////////////////////////////////////////////// #Использовать cmdline -#Использовать logos - #Использовать "." Перем Лог; -Процедура ВыполнитьКоманду(Знач Аргументы) - - ОбработкаКоманд = СоздатьОбработчикКоманд(); - Парсер = Новый ПарсерАргументовКоманднойСтроки(); - - ОбработкаКоманд.ДобавитьОписанияКоманд(Парсер); - - ПараметрыКоманды = Парсер.РазобратьКоманду(Аргументы); - Если ПараметрыКоманды = Неопределено Тогда - ВывестиСправкуПоКомандам(ОбработкаКоманд); - ЗавершитьРаботу(1); - КонецЕсли; - - Попытка - ОбработкаКоманд.ВыполнитьКоманду(ПараметрыКоманды); - Исключение - Лог.Отладка(ОписаниеОшибки()); - Лог.Информация(КраткоеПредставлениеОшибки(ИнформацияОбОшибке())); - ЗавершитьРаботу(1); - КонецПопытки; - -КонецПроцедуры +///////////////////////////////////////////////////////////////////////////////////////// -Процедура ВывестиСправкуПоКомандам(Знач ОбработкаКоманд) - - ОбработкаКоманд.ВывестиСправкуПоКомандам(); +Функция ПолучитьПарсерКоманднойСтроки() + + Парсер = Новый ПарсерАргументовКоманднойСтроки(); + + МенеджерКомандПриложенияOpm.ЗарегистрироватьКоманды(Парсер); + + Возврат Парсер; + +КонецФункции + +Функция ПолезнаяРабота() + ПараметрыЗапуска = РазобратьАргументыКоманднойСтроки(); + Если ПараметрыЗапуска = Неопределено или ПараметрыЗапуска.Количество() = 0 Тогда + Лог.Ошибка("Некорректные аргументы командной строки"); + МенеджерКомандПриложенияOpm.ПоказатьСправкуПоКомандам(); + Возврат 1; + КонецЕсли; -КонецПроцедуры + НастройкиПриложенияOpm.УстановитьФайлНастроек(ОбъединитьПути(СтартовыйСценарий().Каталог, "opm.cfg")); -///////////////////////////////////////////////////////////////////////// -// Вспомогательные функции + Если ТипЗнч(ПараметрыЗапуска) = Тип("Структура") Тогда + // это команда + Команда = ПараметрыЗапуска.Команда; + ЗначенияПараметров = ПараметрыЗапуска.ЗначенияПараметров; + ИначеЕсли ЗначениеЗаполнено(ПараметрыСистемыOpm.ИмяКомандыПоУмолчанию()) Тогда + // это команда по-умолчанию + Команда = ПараметрыСистемыOpm.ИмяКомандыПоУмолчанию(); + ЗначенияПараметров = ПараметрыЗапуска; + Иначе + ВызватьИсключение "Некорректно настроено имя команды по-умолчанию."; + КонецЕсли; + + Возврат МенеджерКомандПриложенияOpm.ВыполнитьКоманду(Команда, ЗначенияПараметров); + +КонецФункции -Функция СоздатьОбработчикКоманд() - Возврат Новый ДиспетчерКомандПриложения(); +Функция РазобратьАргументыКоманднойСтроки() + Парсер = ПолучитьПарсерКоманднойСтроки(); + Возврат Парсер.Разобрать(АргументыКоманднойСтроки); КонецФункции ///////////////////////////////////////////////////////////////////////// -// Точка входа -Лог = Логирование.ПолучитьЛог(Константы.ИмяЛога); +Лог = Логирование.ПолучитьЛог(ПараметрыСистемыOpm.ИмяЛогаСистемы()); +МенеджерКомандПриложенияOpm.РегистраторКоманд(ПараметрыСистемыOpm); -НастройкиПриложения.УстановитьФайлНастроек(ОбъединитьПути(СтартовыйСценарий().Каталог, "opm.cfg")); -ВыполнитьКоманду(АргументыКоманднойСтроки); \ No newline at end of file +Попытка + ЗавершитьРаботу(ПолезнаяРабота()); +Исключение + Лог.КритичнаяОшибка(ОписаниеОшибки()); + ЗавершитьРаботу(255); +КонецПопытки; diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\224\320\270\321\201\320\277\320\265\321\202\321\207\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\224\320\270\321\201\320\277\320\265\321\202\321\207\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" deleted file mode 100644 index 05edf9e..0000000 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\224\320\270\321\201\320\277\320\265\321\202\321\207\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" +++ /dev/null @@ -1,343 +0,0 @@ - -#Использовать logos - -Перем Лог; -Перем ЭтоWindows; - -Процедура ДобавитьОписанияКоманд(Знач Парсер) Экспорт - ДобавитьКомандуBuild(Парсер); - ДобавитьКомандуRun(Парсер); - ДобавитьКомандуTest(Парсер); - ДобавитьКомандуPrepare(Парсер); - ДобавитьКомандуInstall(Парсер); - ДобавитьКомандуUpdate(Парсер); - ДобавитьКомандуApp(Парсер); - ДобавитьКомандуConfig(Парсер); - ДобавитьКомандуList(Парсер); - ДобавитьКомандуVersion(Парсер); - ДобавитьКомандуHelp(Парсер); -КонецПроцедуры - -///////////////////////////////////////////////////////////////////////// -// Описания команд - -Процедура ДобавитьКомандуPrepare(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("prepare", "Подготовить новый каталог разрабатываемого пакета"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "КаталогСборкиПакета", "Каталог, в котором будет вестись разработка"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуBuild(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("build", "Собрать пакет из исходников"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "КаталогИсходников", "Каталог исходников"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-mf", "Файл манифеста сборки (packagedef)"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-out", "Выходной каталог"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуRun(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("run", "Выполнить произвольную задачу"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "ИмяЗадачи", "Имя выполняемой задачи."); - Парсер.ДобавитьПараметрКоллекцияКоманды(Команда, "ПараметрыЗадачи", "Коллекция параметров, передаваемых задаче"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуTest(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("test", "Выполнить тестирование проекта"); - Парсер.ДобавитьПараметрКоллекцияКоманды(Команда, "ПараметрыЗадачи", "Коллекция параметров, передаваемых задаче тестирования"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуInstall(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("install", "Выполнить установку. Если указано имя пакета, происходит установка из хаба или из файла. В обратном случае устанавливаются зависимости текущего пакета по файлу packagedef."); - Парсер.ДобавитьПараметрФлагКоманды(Команда, "-all", "Установить все пакеты, зарегистрированные в хабе"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-f", "Указать файл из которого нужно установить пакет"); - Парсер.ДобавитьПараметрФлагКоманды(Команда, "-l", "Установить пакеты в локальный каталог oscript_modules"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "ИмяПакета", "Имя пакета в хабе. Чтобы установить конкретную версию, используйте ИмяПакета@ВерсияПакета"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуUpdate(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("update", "Обновить пакет"); - Парсер.ДобавитьПараметрФлагКоманды(Команда, "-all", "Обновить все установленные пакеты"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-f", "Указать файл из которого нужно установить пакет"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "ИмяПакета", "Имя пакета в хабе. Чтобы установить конкретную версию, используйте ИмяПакета@ВерсияПакета"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуApp(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("app", "Создать " + ?(ЭтоWindows, "bat", "sh") + "-файл для запуска скрипта в указанном каталоге"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "ИмяСкрипта", "Имя скрипта в текущем каталоге или полный путь скрипта"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "Каталог", "(необязательно) Каталог, в котором будет создан скрипт запуска. По умолчанию """ + КаталогПрограммы() + """"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-name", "Имя генерируемого исполняемого файла"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуConfig(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("config", "Задать пользовательские настройки"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-winCreateBashLauncher","Создавать sh-скрипт запуска для пакетов приложений в среде Windows"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "-proxyusedefault","Использовать ПроксиПоУмолчанию (системные настройки)"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-proxyserver", "Адрес прокси"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-proxyport", "Порт прокси"); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-proxyuser", "Пользователь прокси "); - Парсер.ДобавитьИменованныйПараметрКоманды(Команда, "-proxypass", "Пароль прокси"); - Парсер.ДобавитьКоманду(Команда); - КонецПроцедуры - -Процедура ДобавитьКомандуList(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("list", "Вывести список пакетов"); - Парсер.ДобавитьПараметрФлагКоманды(Команда, "-q", """Тихий"" режим вывода без лишних сообщений."); - Парсер.ДобавитьПараметрФлагКоманды(Команда, "-remote", "Вывести список пакетов в хабе"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуVersion(Знач Парсер) - Команда = Парсер.ОписаниеКоманды("version", "Вывести версию продукта"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ДобавитьКомандуHelp(Знач Парсер) Экспорт - Команда = Парсер.ОписаниеКоманды("help", "Справка по командам"); - Парсер.ДобавитьПозиционныйПараметрКоманды(Команда, "ИмяКоманды", "Имя команды по которой надо получить справку"); - Парсер.ДобавитьКоманду(Команда); -КонецПроцедуры - -Процедура ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт - - Если ПараметрыКоманды.Команда <> "version" И ПараметрыКоманды.Команда <> "help" Тогда - ВывестиВерсию(); - КонецЕсли; - - ЗначенияПараметров = ПараметрыКоманды.ЗначенияПараметров; - Если ПараметрыКоманды.Команда = "build" Тогда - ВыполнитьСборку(ЗначенияПараметров["КаталогИсходников"], ЗначенияПараметров["-mf"], ЗначенияПараметров["-out"]); - ИначеЕсли ПараметрыКоманды.Команда = "run" Тогда - ВыполнитьЗадачу(ЗначенияПараметров["ИмяЗадачи"], ЗначенияПараметров["ПараметрыЗадачи"]); - ИначеЕсли ПараметрыКоманды.Команда = "test" Тогда - ВыполнитьЗадачу("test", ЗначенияПараметров["ПараметрыЗадачи"]); - ИначеЕсли ПараметрыКоманды.Команда = "prepare" Тогда - ПодготовитьКаталогПроекта(ЗначенияПараметров["КаталогСборкиПакета"]); - ИначеЕсли ПараметрыКоманды.Команда = "install" Тогда - УстановитьПакет(ЗначенияПараметров); - ИначеЕсли ПараметрыКоманды.Команда = "update" Тогда - ОбновитьПакет(ЗначенияПараметров); - ИначеЕсли ПараметрыКоманды.Команда = "app" Тогда - СоздатьСкриптЗапуска(ЗначенияПараметров["ИмяСкрипта"], ЗначенияПараметров["Каталог"], ЗначенияПараметров["-name"]); - ИначеЕсли ПараметрыКоманды.Команда = "config" Тогда - НастройкиПриложения.СохранитьНастройки(ЗначенияПараметров); - ИначеЕсли ПараметрыКоманды.Команда = "list" Тогда - ВывестиСписокПакетов(ЗначенияПараметров); - ИначеЕсли ПараметрыКоманды.Команда = "version" Тогда - ВывестиВерсиюКратко(); - ИначеЕсли ПараметрыКоманды.Команда = "help" Тогда - ВывестиСправку(ЗначенияПараметров); - КонецЕсли; - -КонецПроцедуры - -///////////////////////////////////////////////////////////////////////// -// Реализация команд - -Процедура УстановитьПакет(Знач ЗначенияПараметров) Экспорт - - Установщик = Новый УстановкаПакета; - - Если ЗначенияПараметров["-l"] Тогда - Установщик.УстановитьРежимУстановкиПакетов(РежимУстановкиПакетов.Локально); - Иначе - Установщик.УстановитьРежимУстановкиПакетов(РежимУстановкиПакетов.Глобально); - КонецЕсли; - - Если ЗначенияПараметров["-all"] Тогда - Установщик.УстановитьВсеПакетыИзОблака(); - ИначеЕсли ЗначенияПараметров["-f"] = Неопределено И ЗначенияПараметров["ИмяПакета"] = Неопределено Тогда - Установщик.УстановитьПакетыПоОписаниюПакета(); - ИначеЕсли ЗначенияПараметров["-f"] <> Неопределено Тогда - Установщик.УстановитьПакетИзАрхива(ЗначенияПараметров["-f"]); - Иначе - Установщик.УстановитьПакетИзОблака(ЗначенияПараметров["ИмяПакета"]); - КонецЕсли; - -КонецПроцедуры - -Процедура ВыполнитьСборку(Знач КаталогИсходников, Знач ФайлМанифеста, Знач ВыходнойКаталог) Экспорт - - Сборщик = Новый СборщикПакета(); - Сборщик.СобратьПакет(КаталогИсходников, ФайлМанифеста, ВыходнойКаталог); - -КонецПроцедуры - -Процедура ПодготовитьКаталогПроекта(Знач ВыходнойКаталог) Экспорт - - Сборщик = Новый СборщикПакета(); - Сборщик.ПодготовитьКаталогПроекта(ВыходнойКаталог); - -КонецПроцедуры - -Процедура ВыполнитьЗадачу(Знач ИмяЗадачи, Знач ПараметрыЗадачи) - - ИсполнительЗадач = Новый ИсполнительЗадач(); - ИсполнительЗадач.ВыполнитьЗадачу(ИмяЗадачи, ПараметрыЗадачи); - -КонецПроцедуры - -Процедура ОбновитьПакет(Знач ЗначенияПараметров) Экспорт - - Установщик = Новый УстановкаПакета; - Если ЗначенияПараметров["-all"] Тогда - Установщик.ОбновитьУстановленныеПакеты(); - ИначеЕсли ЗначенияПараметров["-f"] <> Неопределено Тогда - Установщик.УстановитьПакетИзАрхива(ЗначенияПараметров["-f"]); - Иначе - Установщик.ОбновитьПакетИзОблака(ЗначенияПараметров["ИмяПакета"]); - КонецЕсли; - -КонецПроцедуры - -Процедура СоздатьСкриптЗапуска(Знач ИмяСкрипта, Знач Каталог, Знач ИмяФайлаЗапуска) Экспорт - Если ИмяСкрипта = Неопределено Тогда - ВызватьИсключение "Не указано имя файла скрипта"; - КонецЕсли; - - ФайлСкрипта = Новый Файл(ИмяСкрипта); - ПолноеИмяСкрипта = ФайлСкрипта.ПолноеИмя; - Если Не ФайлСкрипта.Существует() Тогда - ФайлСкрипта = Новый Файл(ИмяСкрипта + ".os"); - Если Не ФайлСкрипта.Существует() Тогда - ВызватьИсключение "Файл скрипта """ + ПолноеИмяСкрипта + """ не найден"; - Иначе - ПолноеИмяСкрипта = ФайлСкрипта.ПолноеИмя; - КонецЕсли; - КонецЕсли; - - Если Не ФайлСкрипта.ЭтоФайл() Тогда - ВызватьИсключение "Указанный скрипт """ + ПолноеИмяСкрипта + """ не является файлом"; - КонецЕсли; - - Если Каталог = Неопределено Тогда - Каталог = КаталогПрограммы(); - КонецЕсли; - - ФайлКаталога = Новый Файл(Каталог); - Каталог = ФайлКаталога.ПолноеИмя; - Если ФайлКаталога.Существует() Тогда - Если ФайлКаталога.ЭтоФайл() Тогда - ВызватьИсключение "Указанный каталог """ + Каталог + """ является файлом"; - КонецЕсли; - Иначе - СоздатьКаталог(Каталог); - Если Не ФайлКаталога.Существует() Тогда - ВызватьИсключение "Не удалось создать каталог """ + Каталог + """"; - КонецЕсли; - КонецЕсли; - - ИмяСкриптаЗапуска = ?(ИмяФайлаЗапуска = Неопределено, ФайлСкрипта.ИмяБезРасширения, ИмяФайлаЗапуска); - Установщик = Новый УстановкаПакета; - Установщик.СоздатьСкриптЗапуска(ИмяСкриптаЗапуска, ПолноеИмяСкрипта, Каталог); - -КонецПроцедуры - -Процедура ВывестиСписокПакетов(Знач ЗначенияПараметров) - - ТихийРежим = ЗначенияПараметров["-q"]; - - Если ЗначенияПараметров["-remote"] Тогда - ТекстСообщения = СтрШаблон("Пакеты в хабе:"); - КэшПакетовВХабе = Новый КэшПакетовХаба(); - УстановленныеПакеты = КэшПакетовВХабе.ПолучитьПакетыХаба(); - Иначе - - ПутьККаталогуПакетов = ПолучитьЗначениеСистемнойНастройки("lib.system"); - ТекстСообщения = СтрШаблон("Пакеты в системном каталоге библиотек <%1>:", ПутьККаталогуПакетов); - - КэшУстановленныхПакетов = Новый КэшУстановленныхПакетов(); - УстановленныеПакеты = КэшУстановленныхПакетов.ПолучитьУстановленныеПакеты(); - КонецЕсли; - - Если НЕ ТихийРежим Тогда - Сообщить(ТекстСообщения); - КонецЕсли; - - Для Каждого УстановленныйПакет Из УстановленныеПакеты Цикл - СтрокаСообщения = УстановленныйПакет.Ключ; - Если ТипЗнч(УстановленныйПакет.Значение) = Тип("ОписаниеПакета") Тогда - ОписаниеПакета = УстановленныйПакет.Значение; - СтрокаСообщения = СтрокаСообщения + "@" + ОписаниеПакета.Свойства().Версия; - КонецЕсли; - Сообщить(СтрокаСообщения); - КонецЦикла; - -КонецПроцедуры - -Процедура ВывестиВерсиюКратко() - Сообщить(Константы.ВерсияПродукта); -КонецПроцедуры - -Процедура ВывестиВерсию() - Сообщить("OneScript Package Manager v" + Константы.ВерсияПродукта); - Сообщить(""); -КонецПроцедуры - -Процедура ВывестиСправку(Знач ЗначенияПараметров) - Если ЗначенияПараметров["ИмяКоманды"] = Неопределено Тогда - ВывестиСправкуПоКомандам(); - Иначе - ВывестиСправкуПоКоманде(ЗначенияПараметров["ИмяКоманды"]); - КонецЕсли; -КонецПроцедуры - -Процедура ВывестиСправкуПоКомандам() Экспорт - - Парсер = Новый ПарсерАргументовКоманднойСтроки; - ДобавитьОписанияКоманд(Парсер); - - ВозможныеКоманды = Парсер.СправкаВозможныеКоманды(); - ВывестиВерсию(); - Сообщить("Возможные команды:"); - - МаксШирина = 0; - Поле = " "; - Для Каждого Команда Из ВозможныеКоманды Цикл - ТекШирина = СтрДлина(Команда.Команда); - Если ТекШирина > МаксШирина Тогда - МаксШирина = ТекШирина; - КонецЕсли; - КонецЦикла; - - Для Каждого Команда Из ВозможныеКоманды Цикл - Сообщить(" " + Лев(Команда.Команда + Поле, МаксШирина + 2) + "- " + Команда.Пояснение); - КонецЦикла; - - Сообщить("Наберите opm help <команда>, чтобы вывести справку по команде"); - -КонецПроцедуры - -Процедура ВывестиСправкуПоКоманде(Знач ИмяКоманды) - - Парсер = Новый ПарсерАргументовКоманднойСтроки; - ДобавитьОписанияКоманд(Парсер); - - ВозможныеКоманды = Парсер.СправкаВозможныеКоманды(); - ОписаниеКоманды = ВозможныеКоманды.Найти(ИмяКоманды, "Команда"); - Если ОписаниеКоманды = Неопределено Тогда - Сообщить("Команда отсуствует: " + ИмяКоманды); - Возврат; - КонецЕсли; - - Сообщить("" + ОписаниеКоманды.Команда + " - " + ОписаниеКоманды.Пояснение); - Сообщить("Параметры:"); - Для Каждого СтрПараметр Из ОписаниеКоманды.Параметры Цикл - Если Не СтрПараметр.ЭтоИменованныйПараметр Тогда - Сообщить(СтрШаблон(" <%1> - %2", СтрПараметр.Имя, СтрПараметр.Пояснение)); - Иначе - Сообщить(СтрШаблон(" %1 - %2", СтрПараметр.Имя, СтрПараметр.Пояснение)); - КонецЕсли; - КонецЦикла; - -КонецПроцедуры - -///////////////////////////////////////////////////////////////////// - -Лог = Логирование.ПолучитьЛог(Константы.ИмяЛога); -СистемнаяИнформация = Новый СистемнаяИнформация; -ЭтоWindows = Найти(НРег(СистемнаяИнформация.ВерсияОС), "windows") > 0; diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_App.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_App.os" new file mode 100644 index 0000000..538a069 --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_App.os" @@ -0,0 +1,71 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс +Перем ЭтоWindows; + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Создать " + ?(ЭтоWindows, "bat", "sh") + "-файл для запуска скрипта в указанном каталоге"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "ИмяСкрипта", "Имя скрипта в текущем каталоге или полный путь скрипта"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "Каталог", "(необязательно) Каталог, в котором будет создан скрипт запуска. По умолчанию """ + КаталогПрограммы() + """"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-name", "Имя генерируемого исполняемого файла"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + + СоздатьСкриптЗапуска(ПараметрыКоманды["ИмяСкрипта"], ПараметрыКоманды["Каталог"], ПараметрыКоманды["-name"]); + +КонецФункции + + +Процедура СоздатьСкриптЗапуска(Знач ИмяСкрипта, Знач Каталог, Знач ИмяФайлаЗапуска) Экспорт + Если ИмяСкрипта = Неопределено Тогда + ВызватьИсключение "Не указано имя файла скрипта"; + КонецЕсли; + + ФайлСкрипта = Новый Файл(ИмяСкрипта); + ПолноеИмяСкрипта = ФайлСкрипта.ПолноеИмя; + Если Не ФайлСкрипта.Существует() Тогда + ФайлСкрипта = Новый Файл(ИмяСкрипта + ".os"); + Если Не ФайлСкрипта.Существует() Тогда + ВызватьИсключение "Файл скрипта """ + ПолноеИмяСкрипта + """ не найден"; + Иначе + ПолноеИмяСкрипта = ФайлСкрипта.ПолноеИмя; + КонецЕсли; + КонецЕсли; + + Если Не ФайлСкрипта.ЭтоФайл() Тогда + ВызватьИсключение "Указанный скрипт """ + ПолноеИмяСкрипта + """ не является файлом"; + КонецЕсли; + + Если Каталог = Неопределено Тогда + Каталог = КаталогПрограммы(); + КонецЕсли; + + ФайлКаталога = Новый Файл(Каталог); + Каталог = ФайлКаталога.ПолноеИмя; + Если ФайлКаталога.Существует() Тогда + Если ФайлКаталога.ЭтоФайл() Тогда + ВызватьИсключение "Указанный каталог """ + Каталог + """ является файлом"; + КонецЕсли; + Иначе + СоздатьКаталог(Каталог); + Если Не ФайлКаталога.Существует() Тогда + ВызватьИсключение "Не удалось создать каталог """ + Каталог + """"; + КонецЕсли; + КонецЕсли; + + ИмяСкриптаЗапуска = ?(ИмяФайлаЗапуска = Неопределено, ФайлСкрипта.ИмяБезРасширения, ИмяФайлаЗапуска); + Установщик = Новый УстановкаПакета; + Установщик.СоздатьСкриптЗапуска(ИмяСкриптаЗапуска, ПолноеИмяСкрипта, Каталог); + +КонецПроцедуры + +СистемнаяИнформация = Новый СистемнаяИнформация; +ЭтоWindows = Найти(НРег(СистемнаяИнформация.ВерсияОС), "windows") > 0; \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Build.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Build.os" new file mode 100644 index 0000000..65bef8f --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Build.os" @@ -0,0 +1,30 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Собрать пакет из исходников"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "КаталогИсходников", "Каталог исходников"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-mf", "Файл манифеста сборки (packagedef)"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-out", "Выходной каталог"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + + ВыполнитьСборку(ПараметрыКоманды["КаталогИсходников"], ПараметрыКоманды["-mf"], ПараметрыКоманды["-out"]); + +КонецФункции + +Процедура ВыполнитьСборку(Знач КаталогИсходников, Знач ФайлМанифеста, Знач ВыходнойКаталог) Экспорт + + Сборщик = Новый СборщикПакета(); + Сборщик.СобратьПакет(КаталогИсходников, ФайлМанифеста, ВыходнойКаталог); + +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Config.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Config.os" new file mode 100644 index 0000000..c1ca043 --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Config.os" @@ -0,0 +1,24 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Задать пользовательские настройки"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-winCreateBashLauncher","Создавать sh-скрипт запуска для пакетов приложений в среде Windows"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "-proxyusedefault","Использовать ПроксиПоУмолчанию (системные настройки)"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-proxyserver", "Адрес прокси"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-proxyport", "Порт прокси"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-proxyuser", "Пользователь прокси "); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-proxypass", "Пароль прокси"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + НастройкиПриложенияOpm.СохранитьНастройки(ПараметрыКоманды); +КонецФункции \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Install.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Install.os" new file mode 100644 index 0000000..7cfe890 --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Install.os" @@ -0,0 +1,44 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Выполнить установку. Если указано имя пакета, происходит установка из хаба или из файла. В обратном случае устанавливаются зависимости текущего пакета по файлу packagedef."); + Парсер.ДобавитьПараметрФлагКоманды(ОписаниеКоманды, "-all", "Установить все пакеты, зарегистрированные в хабе"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-f", "Указать файл из которого нужно установить пакет"); + Парсер.ДобавитьПараметрФлагКоманды(ОписаниеКоманды, "-l", "Установить пакеты в локальный каталог oscript_modules"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "ИмяПакета", "Имя пакета в хабе. Чтобы установить конкретную версию, используйте ИмяПакета@ВерсияПакета"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + УстановитьПакет(ПараметрыКоманды); +КонецФункции + +Процедура УстановитьПакет(Знач ЗначенияПараметров) Экспорт + + Установщик = Новый УстановкаПакета; + + Если ЗначенияПараметров["-l"] Тогда + Установщик.УстановитьРежимУстановкиПакетов(РежимУстановкиПакетов.Локально); + Иначе + Установщик.УстановитьРежимУстановкиПакетов(РежимУстановкиПакетов.Глобально); + КонецЕсли; + + Если ЗначенияПараметров["-all"] Тогда + Установщик.УстановитьВсеПакетыИзОблака(); + ИначеЕсли ЗначенияПараметров["-f"] = Неопределено И ЗначенияПараметров["ИмяПакета"] = Неопределено Тогда + Установщик.УстановитьПакетыПоОписаниюПакета(); + ИначеЕсли ЗначенияПараметров["-f"] <> Неопределено Тогда + Установщик.УстановитьПакетИзАрхива(ЗначенияПараметров["-f"]); + Иначе + Установщик.УстановитьПакетИзОблака(ЗначенияПараметров["ИмяПакета"]); + КонецЕсли; + +КонецПроцедуры diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_List.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_List.os" new file mode 100644 index 0000000..de72d1f --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_List.os" @@ -0,0 +1,55 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Вывести список пакетов"); + Парсер.ДобавитьПараметрФлагКоманды(ОписаниеКоманды, "-q", """Тихий"" режим вывода без лишних сообщений."); + Парсер.ДобавитьПараметрФлагКоманды(ОписаниеКоманды, "-remote", "Вывести список пакетов в хабе"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + + ВывестиСписокПакетов(ПараметрыКоманды); + +КонецФункции + + +Процедура ВывестиСписокПакетов(Знач ЗначенияПараметров) + + ТихийРежим = ЗначенияПараметров["-q"]; + + Если ЗначенияПараметров["-remote"] Тогда + ТекстСообщения = СтрШаблон("Пакеты в хабе:"); + КэшПакетовВХабе = Новый КэшПакетовХаба(); + УстановленныеПакеты = КэшПакетовВХабе.ПолучитьПакетыХаба(); + Иначе + + ПутьККаталогуПакетов = ПолучитьЗначениеСистемнойНастройки("lib.system"); + ТекстСообщения = СтрШаблон("Пакеты в системном каталоге библиотек <%1>:", ПутьККаталогуПакетов); + + КэшУстановленныхПакетов = Новый КэшУстановленныхПакетов(); + УстановленныеПакеты = КэшУстановленныхПакетов.ПолучитьУстановленныеПакеты(); + КонецЕсли; + + Если НЕ ТихийРежим Тогда + Сообщить(ТекстСообщения); + КонецЕсли; + + Для Каждого УстановленныйПакет Из УстановленныеПакеты Цикл + СтрокаСообщения = УстановленныйПакет.Ключ; + Если ТипЗнч(УстановленныйПакет.Значение) = Тип("ОписаниеПакета") Тогда + ОписаниеПакета = УстановленныйПакет.Значение; + СтрокаСообщения = СтрокаСообщения + "@" + ОписаниеПакета.Свойства().Версия; + КонецЕсли; + Сообщить(СтрокаСообщения); + КонецЦикла; + +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Prepare.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Prepare.os" new file mode 100644 index 0000000..29d2349 --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Prepare.os" @@ -0,0 +1,26 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Подготовить новый каталог разрабатываемого пакета"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "КаталогСборкиПакета", "Каталог, в котором будет вестись разработка"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + ПодготовитьКаталогПроекта(ПараметрыКоманды["КаталогСборкиПакета"]); +КонецФункции + +Процедура ПодготовитьКаталогПроекта(Знач ВыходнойКаталог) Экспорт + + Сборщик = Новый СборщикПакета(); + Сборщик.ПодготовитьКаталогПроекта(ВыходнойКаталог); + +КонецПроцедуры diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Run.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Run.os" new file mode 100644 index 0000000..3f01f25 --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Run.os" @@ -0,0 +1,27 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Выполнить произвольную задачу"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "ИмяЗадачи", "Имя выполняемой задачи."); + Парсер.ДобавитьПараметрКоллекцияКоманды(ОписаниеКоманды, "ПараметрыЗадачи", "Коллекция параметров, передаваемых задаче"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + ВыполнитьЗадачу(ПараметрыКоманды["ИмяЗадачи"], ПараметрыКоманды["ПараметрыЗадачи"]); +КонецФункции + +Процедура ВыполнитьЗадачу(Знач ИмяЗадачи, Знач ПараметрыЗадачи) + + ИсполнительЗадач = Новый ИсполнительЗадач(); + ИсполнительЗадач.ВыполнитьЗадачу(ИмяЗадачи, ПараметрыЗадачи); + +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Test.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Test.os" new file mode 100644 index 0000000..752d21a --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Test.os" @@ -0,0 +1,28 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Выполнить тестирование проекта"); + Парсер.ДобавитьПараметрКоллекцияКоманды(ОписаниеКоманды, "ПараметрыЗадачи", "Коллекция параметров, передаваемых задаче тестирования"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + + ВыполнитьЗадачу("test", ПараметрыКоманды["ПараметрыЗадачи"]); + +КонецФункции + +Процедура ВыполнитьЗадачу(Знач ИмяЗадачи, Знач ПараметрыЗадачи) + + ИсполнительЗадач = Новый ИсполнительЗадач(); + ИсполнительЗадач.ВыполнитьЗадачу(ИмяЗадачи, ПараметрыЗадачи); + +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Update.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Update.os" new file mode 100644 index 0000000..e6cd489 --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Update.os" @@ -0,0 +1,36 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Обновить пакет"); + Парсер.ДобавитьПараметрФлагКоманды(ОписаниеКоманды, "-all", "Обновить все установленные пакеты"); + Парсер.ДобавитьИменованныйПараметрКоманды(ОписаниеКоманды, "-f", "Указать файл из которого нужно установить пакет"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "ИмяПакета", "Имя пакета в хабе. Чтобы установить конкретную версию, используйте ИмяПакета@ВерсияПакета"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + + ОбновитьПакет(ПараметрыКоманды); + +КонецФункции + +Процедура ОбновитьПакет(Знач ЗначенияПараметров) Экспорт + + Установщик = Новый УстановкаПакета; + Если ЗначенияПараметров["-all"] Тогда + Установщик.ОбновитьУстановленныеПакеты(); + ИначеЕсли ЗначенияПараметров["-f"] <> Неопределено Тогда + Установщик.УстановитьПакетИзАрхива(ЗначенияПараметров["-f"]); + Иначе + Установщик.ОбновитьПакетИзОблака(ЗначенияПараметров["ИмяПакета"]); + КонецЕсли; + +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Version.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Version.os" new file mode 100644 index 0000000..2742f7a --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260Opm_Version.os" @@ -0,0 +1,18 @@ +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Вывести версию продукта"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + Сообщить(КонстантыOpm.ВерсияПродукта); +КонецФункции \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260\320\241\320\277\321\200\320\260\320\262\320\272\320\260\320\237\320\276\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\320\260\320\274.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260\320\241\320\277\321\200\320\260\320\262\320\272\320\260\320\237\320\276\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\320\260\320\274.os" new file mode 100644 index 0000000..83e699a --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\320\276\320\274\320\260\320\275\320\264\320\260\320\241\320\277\321\200\320\260\320\262\320\272\320\260\320\237\320\276\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\320\260\320\274.os" @@ -0,0 +1,74 @@ + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + ОписаниеКоманды = Парсер.ОписаниеКоманды(ИмяКоманды, "Вывод справки по параметрам"); + Парсер.ДобавитьПозиционныйПараметрКоманды(ОписаниеКоманды, "Команда"); + Парсер.ДобавитьКоманду(ОписаниеКоманды); +КонецПроцедуры + +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + + Парсер = Новый ПарсерАргументовКоманднойСтроки; + + МенеджерКомандПриложенияOpm.ЗарегистрироватьКоманды(Парсер); + + Если ПараметрыКоманды["Команда"] = Неопределено Тогда + ПоказатьВозможныеКоманды(Парсер); + Иначе + ПоказатьСправкуПоКоманде(Парсер, ПараметрыКоманды["Команда"]); + КонецЕсли; + + Возврат 0; + +КонецФункции + +Процедура ПоказатьВозможныеКоманды(Знач Парсер) + + ВозможныеКоманды = Парсер.СправкаВозможныеКоманды(); + Сообщить("Возможные команды:"); + + МаксШирина = 0; + Поле = " "; + Для Каждого Команда Из ВозможныеКоманды Цикл + ТекШирина = СтрДлина(Команда.Команда); + Если ТекШирина > МаксШирина Тогда + МаксШирина = ТекШирина; + КонецЕсли; + КонецЦикла; + + Для Каждого Команда Из ВозможныеКоманды Цикл + Сообщить(" " + Лев(Команда.Команда + Поле, МаксШирина + 2) + "- " + Команда.Пояснение); + КонецЦикла; + + Сообщить("Для подсказки по конкретной команде наберите help <команда>"); + +КонецПроцедуры + +Процедура ПоказатьСправкуПоКоманде(Знач Парсер, Знач ИмяКоманды) + + ВозможныеКоманды = Парсер.СправкаВозможныеКоманды(); + ОписаниеКоманды = ВозможныеКоманды.Найти(ИмяКоманды, "Команда"); + Если ОписаниеКоманды = Неопределено Тогда + Сообщить("Команда отсуствует: " + ИмяКоманды); + Возврат; + КонецЕсли; + + Сообщить("" + ОписаниеКоманды.Команда + " - " + ОписаниеКоманды.Пояснение); + ВывестиПараметры(ОписаниеКоманды.Параметры); + +КонецПроцедуры + +Процедура ВывестиПараметры(Знач ОписаниеПараметров) + + Сообщить("Параметры:"); + Для Каждого СтрПараметр Из ОписаниеПараметров Цикл + Если Не СтрПараметр.ЭтоИменованныйПараметр Тогда + Сообщить(СтрШаблон(" <%1> - %2", СтрПараметр.Имя, СтрПараметр.Пояснение)); + Иначе + Сообщить(СтрШаблон(" %1 - %2", СтрПараметр.Имя, СтрПараметр.Пояснение)); + КонецЕсли; + КонецЦикла; + +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" index 31a2500..fd8834d 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" @@ -8,9 +8,9 @@ Процедура Обновить() Экспорт УстановкаПакета = Новый Установкапакета(); - Сервер = Константы.СерверУдаленногоХранилища; + Сервер = КонстантыOpm.СерверУдаленногоХранилища; Соединение = УстановкаПакета.ИнициализироватьСоединение(Сервер); - Ресурс = Константы.ПутьВХранилище + "list.txt"; + Ресурс = КонстантыOpm.ПутьВХранилище + "list.txt"; Запрос = Новый HTTPЗапрос(Ресурс); Ответ = Соединение.Получить(Запрос); diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" index 0f4978f..35e3fa3 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" @@ -13,7 +13,7 @@ ПутьКФайлуМетаданных = ОбъединитьПути( КаталогБиблиотек, ОписаниеЗависимости.ИмяПакета, - Константы.ИмяФайлаМетаданныхПакета + КонстантыOpm.ИмяФайлаМетаданныхПакета ); ФайлМетаданных = Новый Файл(ПутьКФайлуМетаданных); Если ФайлМетаданных.Существует() Тогда @@ -62,7 +62,7 @@ Процедура ДобавитьУстановленныйПакет(Знач ФайлКаталога) - ПутьКФайлуМетаданных = ОбъединитьПути(ФайлКаталога.ПолноеИмя, Константы.ИмяФайлаМетаданныхПакета); + ПутьКФайлуМетаданных = ОбъединитьПути(ФайлКаталога.ПолноеИмя, КонстантыOpm.ИмяФайлаМетаданныхПакета); ФайлМетаданных = Новый Файл(ПутьКФайлуМетаданных); Если ФайлМетаданных.Существует() Тогда МетаОписаниеПакета = ПрочитатьМетаданныеПакета(ПутьКФайлуМетаданных); diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\261\320\276\321\200\321\211\320\270\320\272\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\261\320\276\321\200\321\211\320\270\320\272\320\237\320\260\320\272\320\265\321\202\320\260.os" index 14e538f..5737d65 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\261\320\276\321\200\321\211\320\270\320\272\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\261\320\276\321\200\321\211\320\270\320\272\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -53,7 +53,7 @@ Если ФайлМанифеста = Неопределено Тогда - ФайлОбъект = Новый Файл(Константы.ИмяФайлаСпецификацииПакета); + ФайлОбъект = Новый Файл(КонстантыOpm.ИмяФайлаСпецификацииПакета); Если ФайлОбъект.Существует() и ФайлОбъект.ЭтоФайл() Тогда Лог.Информация("Найден файл манифеста"); ФайлМанифеста = ФайлОбъект.ПолноеИмя; @@ -223,7 +223,7 @@ Лог.Информация("Создаю заготовку скрипта установки/удаления"); - ИмяФайла = ОбъединитьПути(Каталог, Константы.ИмяФайлаСкриптаУстановки); + ИмяФайла = ОбъединитьПути(Каталог, КонстантыOpm.ИмяФайлаСкриптаУстановки); ЗаписьТекста = Новый ЗаписьТекста(ИмяФайла); ЗаписьТекста.ЗаписатьСтроку("///////////////////////////////////////////////////////////////////"); ЗаписьТекста.ЗаписатьСтроку("// Сценарий установки и удаления пакета с клиентской машины "); @@ -269,7 +269,7 @@ Лог.Информация("Создаю заготовку описания пакета"); - ЗаписьТекста = Новый ЗаписьТекста(ОбъединитьПути(Каталог, Константы.ИмяФайлаСпецификацииПакета)); + ЗаписьТекста = Новый ЗаписьТекста(ОбъединитьПути(Каталог, КонстантыOpm.ИмяФайлаСпецификацииПакета)); ЗаписьТекста.ЗаписатьСтроку("////////////////////////////////////////////////////////////"); ЗаписьТекста.ЗаписатьСтроку("// Описание пакета для сборки и установки"); @@ -286,7 +286,7 @@ | .ВключитьФайл(""src"") | .ВключитьФайл(""doc"") | .ВключитьФайл(""tests"") - | .ВключитьФайл("""+Константы.ИмяФайлаСкриптаУстановки+""") + | .ВключитьФайл("""+КонстантыOpm.ИмяФайлаСкриптаУстановки+""") | //.ЗависитОт(""package1"", "">=2.0"") | //.ЗависитОт(""package2"", "">=1.1"", ""<2.0"") | //.ОпределяетКласс(""УправлениеВселенной"", ""src/universe-mngr.os"") @@ -297,4 +297,4 @@ КонецПроцедуры -Лог = Логирование.ПолучитьЛог(Константы.ИмяЛога); +Лог = Логирование.ПолучитьЛог(КонстантыOpm.ИмяЛога); diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" index 420ff97..c814fbf 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -23,8 +23,8 @@ ЧтениеПакета = Новый ЧтениеZipФайла; ЧтениеПакета.Открыть(ФайлАрхива); - ФайлСодержимого = ИзвлечьОбязательныйФайл(ЧтениеПакета, Константы.ИмяФайлаСодержимогоПакета); - ФайлМетаданных = ИзвлечьОбязательныйФайл(ЧтениеПакета, Константы.ИмяФайлаМетаданныхПакета); + ФайлСодержимого = ИзвлечьОбязательныйФайл(ЧтениеПакета, КонстантыOpm.ИмяФайлаСодержимогоПакета); + ФайлМетаданных = ИзвлечьОбязательныйФайл(ЧтениеПакета, КонстантыOpm.ИмяФайлаМетаданныхПакета); Метаданные = ПрочитатьМетаданныеПакета(ФайлМетаданных); ИмяПакета = Метаданные.Свойства().Имя; @@ -150,7 +150,7 @@ Функция НайтиСоздатьКаталогУстановки(Знач ИдентификаторПакета) Если мРежимУстановкиПакетов = РежимУстановкиПакетов.Локально Тогда - КаталогБиблиотек = Константы.ЛокальныйКаталогУстановкиПакетов; + КаталогБиблиотек = КонстантыOpm.ЛокальныйКаталогУстановкиПакетов; ИначеЕсли мРежимУстановкиПакетов = РежимУстановкиПакетов.Глобально Тогда КаталогБиблиотек = КаталогСистемныхБиблиотек(); Иначе @@ -212,8 +212,8 @@ ФайлПакета = ИмяПакета + ".ospx"; КонецЕсли; - Сервер = Константы.СерверУдаленногоХранилища; - Ресурс = Константы.ПутьВХранилище + ИмяПакета + "/" + ФайлПакета; + Сервер = КонстантыOpm.СерверУдаленногоХранилища; + Ресурс = КонстантыOpm.ПутьВХранилище + ИмяПакета + "/" + ФайлПакета; Соединение = ИнициализироватьСоединение(Сервер); Запрос = Новый HTTPЗапрос(Ресурс); @@ -243,7 +243,7 @@ Функция ИнициализироватьСоединение(Сервер) Экспорт - НастройкиПрокси = НастройкиПриложения.Получить().Прокси; + НастройкиПрокси = НастройкиПриложенияOpm.Получить().Прокси; Если НастройкиПрокси.ИспользоватьПрокси = Истина Тогда Прокси = Новый ИнтернетПрокси(НастройкиПрокси.ПроксиПоУмолчанию); Если НастройкиПрокси.ПроксиПоУмолчанию = Ложь Тогда @@ -306,7 +306,7 @@ ЧтениеСодержимого = Новый ЧтениеZipФайла(ФайлСодержимого); Попытка - ИмяСкриптаУстановки = Константы.ИмяФайлаСкриптаУстановки; + ИмяСкриптаУстановки = КонстантыOpm.ИмяФайлаСкриптаУстановки; ЭлементСкриптаУстановки = ЧтениеСодержимого.Элементы.Найти(ИмяСкриптаУстановки); Если ЭлементСкриптаУстановки <> Неопределено Тогда Лог.Отладка("Найден скрипт установки пакета"); @@ -379,7 +379,7 @@ КонецЕсли; Если мРежимУстановкиПакетов = РежимУстановкиПакетов.Локально Тогда - КаталогУстановкиСкриптовЗапускаПриложений = ОбъединитьПути(Константы.ЛокальныйКаталогУстановкиПакетов, "bin"); + КаталогУстановкиСкриптовЗапускаПриложений = ОбъединитьПути(КонстантыOpm.ЛокальныйКаталогУстановкиПакетов, "bin"); ФС.ОбеспечитьКаталог(КаталогУстановкиСкриптовЗапускаПриложений); КаталогУстановкиСкриптовЗапускаПриложений = Новый Файл(КаталогУстановкиСкриптовЗапускаПриложений).ПолноеИмя; ИначеЕсли мРежимУстановкиПакетов = РежимУстановкиПакетов.Глобально Тогда @@ -404,7 +404,7 @@ ФайлЗапуска.Закрыть(); КонецЕсли; - Если (ЭтоWindows И НастройкиПриложения.Получить().СоздаватьShСкриптЗапуска) ИЛИ НЕ ЭтоWindows Тогда + Если (ЭтоWindows И НастройкиПриложенияOpm.Получить().СоздаватьShСкриптЗапуска) ИЛИ НЕ ЭтоWindows Тогда ПолныйПутьКСкриптуЗапуска = ОбъединитьПути(Каталог, ИмяСкриптаЗапуска); ФайлЗапуска = Новый ЗаписьТекста(ПолныйПутьКСкриптуЗапуска, КодировкаТекста.UTF8NoBOM); ФайлЗапуска.ЗаписатьСтроку("#!/bin/bash"); @@ -447,7 +447,7 @@ Процедура СохранитьФайлМетаданныхПакета(Знач КаталогУстановки, Знач ПутьКФайлуМетаданных) - ПутьСохранения = ОбъединитьПути(КаталогУстановки, Константы.ИмяФайлаМетаданныхПакета); + ПутьСохранения = ОбъединитьПути(КаталогУстановки, КонстантыOpm.ИмяФайлаМетаданныхПакета); ДанныеФайла = Новый ДвоичныеДанные(ПутьКФайлуМетаданных); ДанныеФайла.Записать(ПутьСохранения); diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\250\320\260\320\261\320\273\320\276\320\275\320\232\320\276\320\274\320\260\320\275\320\264\321\213.os-template" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\250\320\260\320\261\320\273\320\276\320\275\320\232\320\276\320\274\320\260\320\275\320\264\321\213.os-template" new file mode 100644 index 0000000..df26def --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\250\320\260\320\261\320\273\320\276\320\275\320\232\320\276\320\274\320\260\320\275\320\264\321\213.os-template" @@ -0,0 +1,16 @@ + +/////////////////////////////////////////////////////////////////////////////////////////////////// +// Прикладной интерфейс + +Процедура ЗарегистрироватьКоманду(Знач ИмяКоманды, Знач Парсер) Экспорт + +КонецПроцедуры + +// Выполняет логику команды +// +// Параметры: +// ПараметрыКоманды - Соответствие ключей командной строки и их значений +// +Функция ВыполнитьКоманду(Знач ПараметрыКоманды) Экспорт + ВызватьИсключение "Не реализовано" +КонецФункции \ No newline at end of file diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" similarity index 100% rename from "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" rename to "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" new file mode 100644 index 0000000..61c8009 --- /dev/null +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\232\320\276\320\274\320\260\320\275\320\264\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" @@ -0,0 +1,50 @@ + +Перем мИсполнителиКоманд; +Перем мРегистраторКоманд; + +Процедура ЗарегистрироватьКоманды(Знач Парсер) Экспорт + + КомандыИРеализация = Новый Соответствие; + мРегистраторКоманд.ПриРегистрацииКомандПриложения(КомандыИРеализация); + + Для Каждого КлючИЗначение Из КомандыИРеализация Цикл + ДобавитьКоманду(КлючИЗначение.Ключ, КлючИЗначение.Значение, Парсер); + КонецЦикла; + +КонецПроцедуры + +Процедура РегистраторКоманд(Знач ОбъектРегистратор) Экспорт + мИсполнителиКоманд = Новый Соответствие; + мРегистраторКоманд = ОбъектРегистратор; +КонецПроцедуры + +Функция ПолучитьКоманду(Знач ИмяКоманды) Экспорт + + КлассРеализации = мИсполнителиКоманд[ИмяКоманды]; + Если КлассРеализации = Неопределено Тогда + ВызватьИсключение "Неверная операция. Команда '"+ИмяКоманды+"' не предусмотрена"; + КонецЕсли; + + Возврат КлассРеализации; + +КонецФункции + +Функция ВыполнитьКоманду(Знач ИмяКоманды, Знач ПараметрыКоманды) Экспорт + + Команда = ПолучитьКоманду(ИмяКоманды); + + Возврат Команда.ВыполнитьКоманду(ПараметрыКоманды); + +КонецФункции + +Процедура ДобавитьКоманду(Знач ИмяКоманды, Знач КлассРеализации, Знач Парсер) + + РеализацияКоманды = Новый(КлассРеализации); + РеализацияКоманды.ЗарегистрироватьКоманду(ИмяКоманды, Парсер); + мИсполнителиКоманд.Вставить(ИмяКоманды, РеализацияКоманды); + +КонецПроцедуры + +Процедура ПоказатьСправкуПоКомандам() Экспорт + ВыполнитьКоманду("help", Новый Соответствие); +КонецПроцедуры \ No newline at end of file diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\235\320\260\321\201\321\202\321\200\320\276\320\271\320\272\320\270\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\235\320\260\321\201\321\202\321\200\320\276\320\271\320\272\320\270\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" similarity index 100% rename from "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\235\320\260\321\201\321\202\321\200\320\276\320\271\320\272\320\270\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" rename to "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\235\320\260\321\201\321\202\321\200\320\276\320\271\320\272\320\270\320\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217Opm.os" diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\321\213\320\241\320\270\321\201\321\202\320\265\320\274\321\213Opm.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\321\213\320\241\320\270\321\201\321\202\320\265\320\274\321\213Opm.os" new file mode 100644 index 0000000..acc6fa1 --- /dev/null +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\237\320\260\321\200\320\260\320\274\320\265\321\202\321\200\321\213\320\241\320\270\321\201\321\202\320\265\320\274\321\213Opm.os" @@ -0,0 +1,29 @@ + +Функция ИмяЛогаСистемы() Экспорт + Возврат "oscript.app.opm"; +КонецФункции + +Процедура ПриРегистрацииКомандПриложения(Знач КлассыРеализацииКоманд) Экспорт + + КлассыРеализацииКоманд["help"] = "КомандаСправкаПоПараметрам"; + КлассыРеализацииКоманд["app"] = "КомандаOpm_App"; + КлассыРеализацииКоманд["build"] = "КомандаOpm_Build"; + КлассыРеализацииКоманд["config"] = "КомандаOpm_Config"; + КлассыРеализацииКоманд["install"] = "КомандаOpm_Install"; + КлассыРеализацииКоманд["list"] = "КомандаOpm_List"; + КлассыРеализацииКоманд["prepare"] = "КомандаOpm_Prepare"; + КлассыРеализацииКоманд["run"] = "КомандаOpm_Run"; + КлассыРеализацииКоманд["test"] = "КомандаOpm_Test"; + КлассыРеализацииКоманд["update"] = "КомандаOpm_Update"; + КлассыРеализацииКоманд["version"] = "КомандаOpm_Version"; + //... + //КлассыРеализацииКоманд["<имя команды>"] = "<КлассРеализации>"; + +КонецПроцедуры + +// Одна из команд может вызываться неявно, без указания команды. +// Иными словами, здесь указывается какой обработчик надо вызывать, если приложение запущено без какой-либо команды +// myapp /home/user/somefile.txt будет аналогично myapp default-action /home/user/somefile.txt +Функция ИмяКомандыПоУмолчанию() Экспорт + Возврат "version"; +КонецФункции \ No newline at end of file diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\222\320\265\321\200\321\201\320\270\321\217\320\274\320\270.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\222\320\265\321\200\321\201\320\270\321\217\320\274\320\270.os" index e7f36f9..61e5c9e 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\222\320\265\321\200\321\201\320\270\321\217\320\274\320\270.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\222\320\265\321\200\321\201\320\270\321\217\320\274\320\270.os" @@ -160,4 +160,4 @@ КонецФункции -Лог = Логирование.ПолучитьЛог(Константы.ИмяЛога); +Лог = Логирование.ПолучитьЛог(КонстантыOpm.ИмяЛога); diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\236\320\277\320\270\321\201\320\260\320\275\320\270\320\265\320\274\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\236\320\277\320\270\321\201\320\260\320\275\320\270\320\265\320\274\320\237\320\260\320\272\320\265\321\202\320\260.os" index 804a28d..e66dc66 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\236\320\277\320\270\321\201\320\260\320\275\320\270\320\265\320\274\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\240\320\260\320\261\320\276\321\202\320\260\320\241\320\236\320\277\320\270\321\201\320\260\320\275\320\270\320\265\320\274\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -2,7 +2,7 @@ Описание = Новый ОписаниеПакета(); - ПутьКМанифесту = ОбъединитьПути(ТекущийКаталог(), Константы.ИмяФайлаСпецификацииПакета); + ПутьКМанифесту = ОбъединитьПути(ТекущийКаталог(), КонстантыOpm.ИмяФайлаСпецификацииПакета); Файл_Манифест = Новый Файл(ПутьКМанифесту); Если Файл_Манифест.Существует() Тогда diff --git a/tasks/test.os b/tasks/test.os new file mode 100644 index 0000000..25ef7da --- /dev/null +++ b/tasks/test.os @@ -0,0 +1,22 @@ +#Использовать 1testrunner +#Использовать "../src" + +Процедура ПровестиТестирование() + + Тестер = Новый Тестер; + + КаталогПроекта = ОбъединитьПути(ТекущийСценарий().Каталог, ".."); + + ФайлРезультатовТестовПакета = Новый Файл(ОбъединитьПути(КаталогПроекта,"test-reports")); + Если Не ФайлРезультатовТестовПакета.Существует() Тогда + СоздатьКаталог(ФайлРезультатовТестовПакета.ПолноеИмя); + КонецЕслИ; + + КаталогТестов = Новый Файл(ОбъединитьПути(КаталогПроекта, "tests")); + + РезультатТестирования = Тестер.ТестироватьКаталог(КаталогТестов, ФайлРезультатовТестовПакета); + +КонецПроцедуры + + +ПровестиТестирование(); \ No newline at end of file diff --git a/tests/build-install-test.os b/tests/build-install-test.os index a21cde6..834d332 100644 --- a/tests/build-install-test.os +++ b/tests/build-install-test.os @@ -1,9 +1,7 @@ #Использовать asserts #Использовать fs #Использовать tempfiles - -#Использовать "../src" - +//#Использовать "../src/Модули" Перем юТест; Перем мВременныеФайлы; @@ -95,11 +93,11 @@ Установщик.УстановитьПакетИзАрхива(ФайлПакетаВерсии1.ПолноеИмя); ПутьКФайлуOsТестовогоПакета = ОбъединитьПути( - Константы.ЛокальныйКаталогУстановкиПакетов, "test","folder","src.os"); + КонстантыOpm.ЛокальныйКаталогУстановкиПакетов, "test","folder","src.os"); ФайлOsИзСтарогоПакета = Новый Файл(ПутьКФайлуOsТестовогоПакета); ПутьКФайлуDllТестовогоПакета = ОбъединитьПути( - Константы.ЛокальныйКаталогУстановкиПакетов, "test","folder","src.dll"); + КонстантыOpm.ЛокальныйКаталогУстановкиПакетов, "test","folder","src.dll"); ФайлDllИзСтарогоПакета = Новый Файл(ПутьКФайлуDllТестовогоПакета); Ожидаем.Что(ФайлOsИзСтарогоПакета.Существует(), "Файл src.os должен существовать").ЭтоИстина(); diff --git a/tests/mft-serializer-test.os b/tests/mft-serializer-test.os index a5b304a..c260562 100644 --- a/tests/mft-serializer-test.os +++ b/tests/mft-serializer-test.os @@ -1,7 +1,6 @@ #Использовать asserts - #Использовать logos -#Использовать "../src" + Перем юТест; diff --git a/tests/packagedef-test.os b/tests/packagedef-test.os index dab69f1..860ca18 100644 --- a/tests/packagedef-test.os +++ b/tests/packagedef-test.os @@ -1,5 +1,5 @@ #Использовать asserts -#Использовать "../src" + Перем юТест; diff --git a/tests/packagelist.os b/tests/packagelist.os index 950a55b..7480b9f 100644 --- a/tests/packagelist.os +++ b/tests/packagelist.os @@ -1,6 +1,5 @@  #Использовать asserts -#Использовать "../src" Перем юТест; diff --git a/tests/pkg-cache.os b/tests/pkg-cache.os index de3e6be..059b8af 100644 --- a/tests/pkg-cache.os +++ b/tests/pkg-cache.os @@ -1,7 +1,5 @@ #Использовать asserts -#Использовать "../src" - Перем юТест; Функция ПолучитьСписокТестов(Знач Тестирование) Экспорт diff --git a/tests/versions-test.os b/tests/versions-test.os index aef8042..fa18823 100644 --- a/tests/versions-test.os +++ b/tests/versions-test.os @@ -1,6 +1,5 @@  #Использовать asserts -#Использовать "../src" Перем юТест; From 64d7c2832fede2e2f55386fe009a8477a0131f62 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Wed, 1 Mar 2017 18:45:07 +0300 Subject: [PATCH 02/11] =?UTF-8?q?Fixes=20#25:=20=D0=A0=D0=B0=D0=B1=D0=BE?= =?UTF-8?q?=D1=82=D0=B0=20=D1=81=20=D0=B4=D0=BE=D0=BF=D0=BE=D0=BB=D0=BD?= =?UTF-8?q?=D0=B8=D1=82=D0=B5=D0=BB=D1=8C=D0=BD=D1=8B=D0=BC=20=D1=85=D1=80?= =?UTF-8?q?=D0=B0=D0=BD=D0=B8=D0=BB=D0=B8=D1=89=D0=B5=D0=BC.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/opm.os | 20 ++++- ...21\200\320\272\320\260\320\273\320\276.os" | 45 ++++++++++ ...20\262\320\245\320\260\320\261\320\260.os" | 13 +-- ...20\260\320\272\320\265\321\202\320\260.os" | 12 +-- ...21\200\320\272\320\260\320\273\320\260.os" | 83 +++++++++++++++++++ ...21\202\320\260\320\275\321\202\321\213.os" | 4 + 6 files changed, 157 insertions(+), 20 deletions(-) create mode 100644 "src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" create mode 100644 "src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" diff --git a/src/opm.os b/src/opm.os index 78fb0cd..e7b3769 100644 --- a/src/opm.os +++ b/src/opm.os @@ -51,10 +51,26 @@ Возврат Новый ДиспетчерКомандПриложения(); КонецФункции +Процедура Инициализация() + + ОсновноеЗеркало = Новый Зеркало; + ОсновноеЗеркало.СерверУдаленногоХранилища = Константы.СерверУдаленногоХранилища; + ОсновноеЗеркало.ПутьВХранилище = Константы.ПутьВХранилище; + + ЗапасноеЗеркало = Новый Зеркало; + ЗапасноеЗеркало.СерверУдаленногоХранилища = Константы.СерверЗапасногоХранилища; + ЗапасноеЗеркало.ПутьВХранилище = Константы.ПутьВЗапасномХранилище; + + Зеркала.Добавить(ОсновноеЗеркало); + Зеркала.Добавить(ЗапасноеЗеркало); + +КонецПроцедуры + ///////////////////////////////////////////////////////////////////////// // Точка входа Лог = Логирование.ПолучитьЛог(Константы.ИмяЛога); - НастройкиПриложения.УстановитьФайлНастроек(ОбъединитьПути(СтартовыйСценарий().Каталог, "opm.cfg")); -ВыполнитьКоманду(АргументыКоманднойСтроки); \ No newline at end of file +Инициализация(); + +ВыполнитьКоманду(АргументыКоманднойСтроки); diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" new file mode 100644 index 0000000..64fa1ca --- /dev/null +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" @@ -0,0 +1,45 @@ +Перем СерверУдаленногоХранилища Экспорт; +Перем ПутьВХранилище Экспорт; + +Перем Соединение; + +Функция ИнициализироватьСоединение() Экспорт + + Если Не Соединение = Неопределено Тогда + Возврат Соединение; + КонецЕсли; + + НастройкиПрокси = НастройкиПриложения.Получить().Прокси; + Если НастройкиПрокси.ИспользоватьПрокси = Истина Тогда + Прокси = Новый ИнтернетПрокси(НастройкиПрокси.ПроксиПоУмолчанию); + Если НастройкиПрокси.ПроксиПоУмолчанию = Ложь Тогда + Прокси.Установить("http",НастройкиПрокси.Сервер,НастройкиПрокси.Порт,НастройкиПрокси.Пользователь,НастройкиПрокси.Пароль,НастройкиПрокси.ИспользоватьАутентификациюОС); + КонецЕсли; + Соединение = Новый HTTPСоединение(СерверУдаленногоХранилища,,,,Прокси); + Иначе + Соединение = Новый HTTPСоединение(СерверУдаленногоХранилища); + КонецЕсли; + + Возврат Соединение; + +КонецФункции + +// ИмяРесурса - имя файла относительно "Сервер/ПутьВХранилище" +// Возвращает HttpОтвет +Функция ПолучитьРесурс(Знач ИмяРесурса) Экспорт + + Соединение = ИнициализироватьСоединение(); + Ресурс = ПутьВХранилище + ИмяРесурса; + Запрос = Новый HTTPЗапрос(Ресурс); + + Попытка + + Возврат Соединение.Получить(Запрос); + + Исключение + + Возврат Неопределено; + + КонецПопытки; + +КонецФункции diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" index 31a2500..6216c70 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\237\320\260\320\272\320\265\321\202\320\276\320\262\320\245\320\260\320\261\320\260.os" @@ -8,15 +8,10 @@ Процедура Обновить() Экспорт УстановкаПакета = Новый Установкапакета(); - Сервер = Константы.СерверУдаленногоХранилища; - Соединение = УстановкаПакета.ИнициализироватьСоединение(Сервер); - Ресурс = Константы.ПутьВХранилище + "list.txt"; - Запрос = Новый HTTPЗапрос(Ресурс); - Ответ = Соединение.Получить(Запрос); - - Если НЕ Ответ.КодСостояния = 200 Тогда - ТекстИсключения = СтрШаблон("Ошибка подключения к хабу <%1>", Ответ.КодСостояния); - Ответ.Закрыть(); + Ответ = Зеркала.ПолучитьРесурс("list.txt"); + + Если Ответ = Неопределено Тогда + ТекстИсключения = СтрШаблон("Ошибка подключения"); ВызватьИсключение ТекстИсключения; КонецЕсли; diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" index 420ff97..15049f5 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -212,15 +212,10 @@ ФайлПакета = ИмяПакета + ".ospx"; КонецЕсли; - Сервер = Константы.СерверУдаленногоХранилища; - Ресурс = Константы.ПутьВХранилище + ИмяПакета + "/" + ФайлПакета; - Соединение = ИнициализироватьСоединение(Сервер); - - Запрос = Новый HTTPЗапрос(Ресурс); Лог.Информация("Скачиваю файл: " + ФайлПакета); - Ответ = Соединение.Получить(Запрос); - Если Ответ.КодСостояния = 200 Тогда + Ответ = Зеркала.ПолучитьРесурс(ИмяПакета + "/" + ФайлПакета); + Если Не Ответ = Неопределено Тогда Лог.Отладка("Файл получен"); ВремФайл = ОбъединитьПути(КаталогВременныхФайлов(), ФайлПакета); Ответ.ПолучитьТелоКакДвоичныеДанные().Записать(ВремФайл); @@ -234,8 +229,7 @@ ВызватьИсключение; КонецПопытки; Иначе - ТекстИсключения = СтрШаблон("Ошибка установки пакета %1 <%2>", ИмяПакета, Ответ.КодСостояния); - Ответ.Закрыть(); + ТекстИсключения = СтрШаблон("Ошибка установки пакета %1: Нет соединения", ИмяПакета); ВызватьИсключение ТекстИсключения; КонецЕсли; diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" new file mode 100644 index 0000000..9fd12f5 --- /dev/null +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" @@ -0,0 +1,83 @@ +#Использовать logos + +Перем ПодключенноеЗеркало; +Перем Зеркала; +Перем Лог; + +// ИмяРесурса - имя файла относительно "Сервер/ПутьВХранилище" +// Возвращает HttpОтвет +Функция ПолучитьРесурс(Знач ИмяРесурса) Экспорт + + РесурсУспешноПолучен = Ложь; + + Если ПодключенноеЗеркало = Неопределено Тогда + + Для Каждого мЗеркало Из Зеркала Цикл + + Ответ = мЗеркало.ПолучитьРесурс(ИмяРесурса); + Если Ответ = Неопределено Тогда + Продолжить; + КонецЕсли; + + Если Ответ.КодСостояния = 200 Тогда + + РесурсУспешноПолучен = Истина; + ПодключенноеЗеркало = мЗеркало; + Прервать; + + КонецЕсли; + + ТекстОшибки = СтрШаблон("Ошибка подключения к хабу %1 <%2>", + мЗеркало.СерверУдаленногоХранилища, + Ответ.КодСостояния); + + Ответ.Закрыть(); + + Лог.Информация(ТекстОшибки); + + КонецЦикла; + + Иначе + + Ответ = ПодключенноеЗеркало.ПолучитьРесурс(ИмяРесурса); + Если Ответ.КодСостояния = 200 Тогда + РесурсУспешноПолучен = Истина; + Иначе + + ТекстОшибки = СтрШаблон("Ошибка подключения к хабу %1 <%2>", + ПодключенноеЗеркало.СерверУдаленногоХранилища, + Ответ.КодСостояния); + + Ответ.Закрыть(); + Лог.Информация(ТекстОшибки); + + КонецЕсли; + + КонецЕсли; + + Если РесурсУспешноПолучен Тогда + + ТекстСообщения = СтрШаблон("Ресурс %1 успешно получен с %2", ИмяРесурса, ПодключенноеЗеркало.СерверУдаленногоХранилища); + Лог.Информация(ТекстСообщения); + + Возврат Ответ; + + КонецЕсли; + + Возврат Неопределено; + +КонецФункции + +Процедура Добавить(Знач Зеркало) Экспорт + Зеркала.Добавить(Зеркало); +КонецПроцедуры + +Процедура Инициализация() + + Лог = Логирование.ПолучитьЛог("oscript.app.opm"); + + Зеркала = Новый Массив; + +КонецПроцедуры + +Инициализация(); diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" index 6eebc1f..6697790 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213.os" @@ -5,6 +5,8 @@ Перем ИмяФайлаМетаданныхПакета Экспорт; Перем СерверУдаленногоХранилища Экспорт; Перем ПутьВХранилище Экспорт; +Перем СерверЗапасногоХранилища Экспорт; +Перем ПутьВЗапасномХранилище Экспорт; Перем ЛокальныйКаталогУстановкиПакетов Экспорт; Перем ИмяЛога Экспорт; Перем ВерсияПродукта Экспорт; @@ -17,6 +19,8 @@ ИмяФайлаМетаданныхПакета = "opm-metadata.xml"; СерверУдаленногоХранилища = "http://hub.oscript.io"; ПутьВХранилище = "/download/"; +СерверЗапасногоХранилища = "http://hub.oscript.ru"; +ПутьВЗапасномХранилище = "/download/"; ЛокальныйКаталогУстановкиПакетов = "oscript_modules"; ИмяЛога = "oscript.app.opm"; ВерсияПродукта = "0.9.3"; From f10878781361ccdc2d9dcd4d6cb8c8524de250b9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Sun, 5 Mar 2017 15:38:28 +0300 Subject: [PATCH 03/11] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2?= =?UTF-8?q?=D0=BB=D0=B5=D0=BD=D0=B8=D1=8F=20=D0=B7=D0=B0=D0=BC=D0=B5=D1=87?= =?UTF-8?q?=D0=B0=D0=BD=D0=B8=D0=B9=20=D0=BF=D0=BE=20=D0=BD=D0=B0=D1=81?= =?UTF-8?q?=D1=82=D1=80=D0=BE=D0=B9=D0=BA=D0=B0=D0=BC.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...\227\320\265\321\200\320\272\320\260\320\273\320\276.os" | 6 +++--- ...\227\320\265\321\200\320\272\320\260\320\273\320\260.os" | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" index 64fa1ca..8a4add8 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\265\321\200\320\272\320\260\320\273\320\276.os" @@ -10,9 +10,9 @@ КонецЕсли; НастройкиПрокси = НастройкиПриложения.Получить().Прокси; - Если НастройкиПрокси.ИспользоватьПрокси = Истина Тогда + Если НастройкиПрокси.ИспользоватьПрокси Тогда Прокси = Новый ИнтернетПрокси(НастройкиПрокси.ПроксиПоУмолчанию); - Если НастройкиПрокси.ПроксиПоУмолчанию = Ложь Тогда + Если НастройкиПрокси.ПроксиПоУмолчанию Тогда Прокси.Установить("http",НастройкиПрокси.Сервер,НастройкиПрокси.Порт,НастройкиПрокси.Пользователь,НастройкиПрокси.Пароль,НастройкиПрокси.ИспользоватьАутентификациюОС); КонецЕсли; Соединение = Новый HTTPСоединение(СерверУдаленногоХранилища,,,,Прокси); @@ -25,7 +25,7 @@ КонецФункции // ИмяРесурса - имя файла относительно "Сервер/ПутьВХранилище" -// Возвращает HttpОтвет +// Возвращает HttpОтвет или Неопределено, если запрос вернул исключение. Функция ПолучитьРесурс(Знач ИмяРесурса) Экспорт Соединение = ИнициализироватьСоединение(); diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" index 9fd12f5..3419c15 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" @@ -5,7 +5,7 @@ Перем Лог; // ИмяРесурса - имя файла относительно "Сервер/ПутьВХранилище" -// Возвращает HttpОтвет +// Возвращает HttpОтвет или Неопределено, если ни один сервер не вернул ответ. Функция ПолучитьРесурс(Знач ИмяРесурса) Экспорт РесурсУспешноПолучен = Ложь; From 4f1918a4cbb75a1750cbcabe67c6f6be6dbd489f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Sun, 5 Mar 2017 15:38:53 +0300 Subject: [PATCH 04/11] =?UTF-8?q?=D0=97=D0=B5=D1=80=D0=BA=D0=B0=D0=BB?= =?UTF-8?q?=D0=B0=20=D0=BF=D1=80=D0=BE=D0=BF=D0=B8=D1=81=D0=B0=D0=BD=D1=8B?= =?UTF-8?q?=20=D0=B2=20`README.md`.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index 8d6dd6a..650c92b 100644 --- a/README.md +++ b/README.md @@ -19,3 +19,7 @@ OneScript Package Manager Справка из википедии: [Система управления пакетами](https://ru.wikipedia.org/wiki/%D0%A1%D0%B8%D1%81%D1%82%D0%B5%D0%BC%D0%B0_%D1%83%D0%BF%D1%80%D0%B0%D0%B2%D0%BB%D0%B5%D0%BD%D0%B8%D1%8F_%D0%BF%D0%B0%D0%BA%D0%B5%D1%82%D0%B0%D0%BC%D0%B8) +# Сервера +В настоящее время пакеты хранятся на двух серверах: +- [hub.oscript.io](http://hub.oscript.io/download) - основной хаб пакетов +- [hub.oscript.ru](http://hub.oscript.ru/download) - вторичный хаб пакетов. Используется, когда не удаётся получить данные с основного хаба From 27a952edba521b341f1045aaa8a05e751ae60cae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Sun, 5 Mar 2017 18:24:21 +0300 Subject: [PATCH 05/11] =?UTF-8?q?=D0=9F=D0=B5=D1=80=D0=B5=D0=BD=D0=B5?= =?UTF-8?q?=D1=81=D0=B5=D0=BD=D0=B0=20=D0=B8=D0=BD=D0=B8=D1=86=D0=B8=D0=B0?= =?UTF-8?q?=D0=BB=D0=B8=D0=B7=D0=B0=D1=86=D0=B8=D1=8F=20=D0=B7=D0=B5=D1=80?= =?UTF-8?q?=D0=BA=D0=B0=D0=BB.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Зеркала инициализируются при первом обращении из-за неполадок при загрузке классов из модулей. --- src/opm.os | 15 --------------- ...\321\200\320\272\320\260\320\273\320\260.os" | 17 +++++++++++++++-- 2 files changed, 15 insertions(+), 17 deletions(-) diff --git a/src/opm.os b/src/opm.os index e7b3769..1e28f54 100644 --- a/src/opm.os +++ b/src/opm.os @@ -51,26 +51,11 @@ Возврат Новый ДиспетчерКомандПриложения(); КонецФункции -Процедура Инициализация() - - ОсновноеЗеркало = Новый Зеркало; - ОсновноеЗеркало.СерверУдаленногоХранилища = Константы.СерверУдаленногоХранилища; - ОсновноеЗеркало.ПутьВХранилище = Константы.ПутьВХранилище; - - ЗапасноеЗеркало = Новый Зеркало; - ЗапасноеЗеркало.СерверУдаленногоХранилища = Константы.СерверЗапасногоХранилища; - ЗапасноеЗеркало.ПутьВХранилище = Константы.ПутьВЗапасномХранилище; - - Зеркала.Добавить(ОсновноеЗеркало); - Зеркала.Добавить(ЗапасноеЗеркало); - -КонецПроцедуры ///////////////////////////////////////////////////////////////////////// // Точка входа Лог = Логирование.ПолучитьЛог(Константы.ИмяЛога); НастройкиПриложения.УстановитьФайлНастроек(ОбъединитьПути(СтартовыйСценарий().Каталог, "opm.cfg")); -Инициализация(); ВыполнитьКоманду(АргументыКоманднойСтроки); diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" index 3419c15..99a1e14 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" @@ -12,6 +12,10 @@ Если ПодключенноеЗеркало = Неопределено Тогда + Если Зеркала = Неопределено Тогда + Инициализация(); + КонецЕсли; + Для Каждого мЗеркало Из Зеркала Цикл Ответ = мЗеркало.ПолучитьРесурс(ИмяРесурса); @@ -78,6 +82,15 @@ Зеркала = Новый Массив; -КонецПроцедуры + ОсновноеЗеркало = Новый("Зеркало"); + ОсновноеЗеркало.СерверУдаленногоХранилища = Константы.СерверУдаленногоХранилища; + ОсновноеЗеркало.ПутьВХранилище = Константы.ПутьВХранилище; -Инициализация(); + ЗапасноеЗеркало = Новый("Зеркало"); + ЗапасноеЗеркало.СерверУдаленногоХранилища = Константы.СерверЗапасногоХранилища; + ЗапасноеЗеркало.ПутьВХранилище = Константы.ПутьВЗапасномХранилище; + + Зеркала.Добавить(ОсновноеЗеркало); + Зеркала.Добавить(ЗапасноеЗеркало); + +КонецПроцедуры From 0e6517bf9fb705bde9094cff1c526f37a85221b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Tue, 21 Mar 2017 23:29:24 +0300 Subject: [PATCH 06/11] =?UTF-8?q?Fixes=20#50:=20=D0=A0=D0=B5=D0=B3=D0=B8?= =?UTF-8?q?=D1=81=D1=82=D1=80=D0=BE=D0=BD=D0=B5=D0=B7=D0=B0=D0=B2=D0=B8?= =?UTF-8?q?=D1=81=D0=B8=D0=BC=D0=B0=D1=8F=20=D1=83=D1=81=D1=82=D0=B0=D0=BD?= =?UTF-8?q?=D0=BE=D0=B2=D0=BA=D0=B0=20=D0=BF=D0=B0=D0=BA=D0=B5=D1=82=D0=B0?= =?UTF-8?q?.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Имя пакета автоматически приводится в соответствие с регистром файлов, хранящихся в хабе. --- ...20\260\320\272\320\265\321\202\320\260.os" | 35 +++++++++++++++++-- 1 file changed, 32 insertions(+), 3 deletions(-) diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" index 8888bcb..0bb82ec 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -205,17 +205,46 @@ СкачатьИУстановитьПакет(ОписаниеПакета.ИмяПакета, ОписаниеПакета.МинимальнаяВерсия); КонецПроцедуры +// Функция по имени пакета определяет имя архива в хабе +// https://github.com/oscript-library/opm/issues/50 +// Имена файлов в хабе регистрозависимы, однако имена пакетов по обыкновению регистронезависимы +Функция ОпределитьИмяАрхива(Знач ИмяПакета) + + КэшПакетовВХабе = Новый КэшПакетовХаба(); + ПакетыХаба = КэшПакетовВХабе.ПолучитьПакетыХаба(); + + Если ПакетыХаба.Получить(ИмяПакета) = Неопределено Тогда + + Для Каждого мПакет Из ПакетыХаба Цикл + + // Проводим регистронезависимое сравнение имён + Если нрег(мПакет.Ключ) = нрег(ИмяПакета) Тогда + + // и возвращаем ровно то имя, которое хранится в хабе (с учётом регистра) + Возврат мПакет.Ключ; + + КонецЕсли; + + КонецЦикла; + + КонецЕсли; + + Возврат ИмяПакета; + +КонецФункции + Процедура СкачатьИУстановитьПакет(Знач ИмяПакета, Знач ВерсияПакета) + ИмяАрхива = ОпределитьИмяАрхива(ИмяПакета); Если ВерсияПакета <> Неопределено Тогда - ФайлПакета = ИмяПакета + "-" + ВерсияПакета + ".ospx"; + ФайлПакета = ИмяАрхива + "-" + ВерсияПакета + ".ospx"; Иначе - ФайлПакета = ИмяПакета + ".ospx"; + ФайлПакета = ИмяАрхива + ".ospx"; КонецЕсли; Лог.Информация("Скачиваю файл: " + ФайлПакета); - Ответ = Зеркала.ПолучитьРесурс(ИмяПакета + "/" + ФайлПакета); + Ответ = Зеркала.ПолучитьРесурс(ИмяАрхива + "/" + ФайлПакета); Если Не Ответ = Неопределено Тогда Лог.Отладка("Файл получен"); ВремФайл = ОбъединитьПути(КаталогВременныхФайлов(), ФайлПакета); From 75a6ec2d97aba80f2469724ef6e5ea72ea495210 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Mon, 27 Mar 2017 23:35:28 +0300 Subject: [PATCH 07/11] =?UTF-8?q?Fix=20#66:=20=D0=BB=D0=BE=D0=BA=D0=B0?= =?UTF-8?q?=D0=BB=D1=8C=D0=BD=D0=B0=D1=8F=20=D1=83=D1=81=D1=82=D0=B0=D0=BD?= =?UTF-8?q?=D0=BE=D0=B2=D0=BA=D0=B0=20=D0=B2=20=D0=BB=D0=BE=D0=BA=D0=B0?= =?UTF-8?q?=D0=BB=D1=8C=D0=BD=D1=8B=D0=B9=20=D0=BA=D0=B0=D1=82=D0=B0=D0=BB?= =?UTF-8?q?=D0=BE=D0=B3.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit `opm install -l` после просмотра системного каталога теперь так же просматривает каталог oscript_modules в текущем каталоге. --- ...20\272\320\265\321\202\320\276\320\262.os" | 55 +++++++++++++++---- ...20\260\320\272\320\265\321\202\320\260.os" | 24 +++++++- 2 files changed, 65 insertions(+), 14 deletions(-) diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" index 35e3fa3..396b870 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" @@ -3,10 +3,16 @@ Перем Лог; +// Массив каталогов в порядке возрастания приоритета +Перем МассивКаталоговПоискаБиблиотек; + Перем УстановленныеПакеты; Функция ПакетУстановлен(Знач ОписаниеЗависимости) Экспорт + Перем УстановленныеПакеты; + УстановленныеПакеты = ПолучитьУстановленныеПакеты(); + ПакетУстановлен = УстановленныеПакеты.Получить(ОписаниеЗависимости.ИмяПакета) <> Неопределено; КаталогБиблиотек = ОбъединитьПути(КаталогПрограммы(), ПолучитьЗначениеСистемнойНастройки("lib.system")); @@ -34,32 +40,57 @@ Процедура Обновить() Экспорт - КаталогБиблиотек = ОбъединитьПути(КаталогПрограммы(), ПолучитьЗначениеСистемнойНастройки("lib.system")); - Лог.Отладка("КаталогБиблиотек " + КаталогБиблиотек); - УстановленныеПакеты = Новый Соответствие; - - НайденныеФайлы = НайтиФайлы(КаталогБиблиотек, ПолучитьМаскуВсеФайлы()); - Для Каждого ФайлКаталога Из НайденныеФайлы Цикл - Если ФайлКаталога.ЭтоКаталог() Тогда - ДобавитьУстановленныйПакет(ФайлКаталога); - КонецЕсли; + Для Каждого КаталогБиблиотек Из МассивКаталоговПоискаБиблиотек Цикл + + Лог.Отладка("КаталогБиблиотек " + КаталогБиблиотек); + УстановленныеПакеты = Новый Соответствие; + + НайденныеФайлы = НайтиФайлы(КаталогБиблиотек, ПолучитьМаскуВсеФайлы()); + Для Каждого ФайлКаталога Из НайденныеФайлы Цикл + Если ФайлКаталога.ЭтоКаталог() Тогда + + // ДобавитьУстановленныйПакет заменит уже добавленный пакет при совпадении имён + // Соответственно, более поздние каталоги будут иметь приоритет + ДобавитьУстановленныйПакет(ФайлКаталога); + + КонецЕсли; + КонецЦикла; + КонецЦикла; КонецПроцедуры Функция ПолучитьУстановленныеПакеты() Экспорт + + Если УстановленныеПакеты = Неопределено Тогда + Обновить(); + КонецЕсли; + Возврат УстановленныеПакеты; + КонецФункции Процедура Инициализация() Лог = Логирование.ПолучитьЛог("oscript.app.opm"); - //Лог.УстановитьУровень(УровниЛога.Отладка); - - Обновить(); + МассивКаталоговПоискаБиблиотек = Новый Массив; + + КаталогСистемныхБиблиотек = ОбъединитьПути( + КаталогПрограммы(), + ПолучитьЗначениеСистемнойНастройки("lib.system") + ); + + МассивКаталоговПоискаБиблиотек.Добавить(КаталогСистемныхБиблиотек); КонецПроцедуры +// Добавляет каталог в список, по которому выполняется поиск библиотек +Процедура ДобавитьКаталогБиблиотек(Знач Каталог) Экспорт + + МассивКаталоговПоискаБиблиотек.Добавить(Каталог); + +КонецПроцедуры + Процедура ДобавитьУстановленныйПакет(Знач ФайлКаталога) ПутьКФайлуМетаданных = ОбъединитьПути(ФайлКаталога.ПолноеИмя, КонстантыOpm.ИмяФайлаМетаданныхПакета); diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" index 0bb82ec..6c5ad34 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -7,6 +7,7 @@ Перем мЗависимостиВРаботе; Перем ЭтоWindows; Перем мРежимУстановкиПакетов; +Перем КэшУстановленныхПакетов; Процедура УстановитьПакетИзАрхива(Знач ФайлАрхива) Экспорт @@ -137,7 +138,7 @@ КонецПроцедуры Процедура ОбновитьУстановленныеПакеты() Экспорт - КэшУстановленныхПакетов = Новый КэшУстановленныхПакетов; + КэшУстановленныхПакетов = ПолучитьУстановленныеПакеты(); УстановленныеПакеты = КэшУстановленныхПакетов.ПолучитьУстановленныеПакеты(); Для Каждого КлючИЗначение Из УстановленныеПакеты Цикл ОбновитьПакетИзОблака(КлючИЗначение.Ключ); @@ -197,7 +198,26 @@ КонецПроцедуры Функция ПолучитьУстановленныеПакеты() - Возврат Новый КэшУстановленныхПакетов(); + + Если КэшУстановленныхПакетов = Неопределено Тогда + + КэшУстановленныхПакетов = Новый КэшУстановленныхПакетов(); + + Если мРежимУстановкиПакетов = РежимУстановкиПакетов.Локально Тогда + + ПутьККаталогуЛокальнойУстановки = ОбъединитьПути( + ТекущийКаталог(), + КонстантыOpm.ЛокальныйКаталогУстановкиПакетов + ); + + КэшУстановленныхПакетов.ДобавитьКаталогБиблиотек(ПутьККаталогуЛокальнойУстановки); + + КонецЕсли; + + КонецЕсли; + + Возврат КэшУстановленныхПакетов; + КонецФункции Процедура СкачатьИУстановитьПакетПоОписанию(Знач ОписаниеПакета) From c2025324dc1db47508bf652a82a386609d0abda5 Mon Sep 17 00:00:00 2001 From: EvilBeaver Date: Tue, 28 Mar 2017 20:32:31 +0300 Subject: [PATCH 08/11] =?UTF-8?q?=D0=9F=D1=80=D0=B8=20=D0=BD=D0=B0=D0=BB?= =?UTF-8?q?=D0=B8=D1=87=D0=B8=D0=B8=20=D1=83=D0=B6=D0=B5=20=D1=83=D1=81?= =?UTF-8?q?=D1=82=D0=B0=D0=BD=D0=BE=D0=B2=D0=BB=D0=B5=D0=BD=D0=BD=D0=BE?= =?UTF-8?q?=D0=B9=20=D0=B7=D0=B0=D0=B2=D0=B8=D1=81=D0=B8=D0=BC=D0=BE=D1=81?= =?UTF-8?q?=D1=82=D0=B8=20=D0=B2=D1=81=D0=B5=20=D1=80=D0=B0=D0=B2=D0=BD?= =?UTF-8?q?=D0=BE=20=D0=BF=D1=8B=D1=82=D0=B0=D0=B5=D1=82=D1=81=D1=8F=20?= =?UTF-8?q?=D1=81=D0=BA=D0=B0=D1=87=D0=B8=D0=B2=D0=B0=D1=82=D1=8C=20=D1=8D?= =?UTF-8?q?=D1=82=D1=83=20=D0=B2=D0=B5=D1=80=D1=81=D0=B8=D1=8E.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...20\237\320\260\320\272\320\265\321\202\320\276\320\262.os" | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" index 35e3fa3..3c3665b 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\232\321\215\321\210\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\273\320\265\320\275\320\275\321\213\321\205\320\237\320\260\320\272\320\265\321\202\320\276\320\262.os" @@ -26,8 +26,8 @@ Лог.Отладка("ПакетУстановлен: Перед вызовом СравнитьВерсии(ЭтаВерсия = <%1>, БольшеЧемВерсия = <%2>)", УстановленнаяВерсия, ОписаниеЗависимости.МинимальнаяВерсия); УстановленаКорректнаяВерсия = ОписаниеЗависимости.МинимальнаяВерсия = Неопределено - ИЛИ РаботаСВерсиями.СравнитьВерсии(УстановленнаяВерсия, ОписаниеЗависимости.МинимальнаяВерсия) = 1; - + ИЛИ РаботаСВерсиями.СравнитьВерсии(УстановленнаяВерсия, ОписаниеЗависимости.МинимальнаяВерсия) >= 0; + Лог.Отладка("Установлена корректная версия: " + УстановленаКорректнаяВерсия); Возврат ПакетУстановлен И УстановленаКорректнаяВерсия; КонецФункции From 62050025ea7d78577fbac6c66c7e7d1cf42f9c32 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Sat, 15 Apr 2017 22:34:54 +0300 Subject: [PATCH 09/11] =?UTF-8?q?Fixes=20#63:=20=D0=A0=D1=83=D0=B3=D0=B0?= =?UTF-8?q?=D0=B5=D1=82=D1=81=D1=8F=20=D0=BD=D0=B0=20=D0=BD=D0=B5=D0=B2?= =?UTF-8?q?=D0=B5=D0=B4=D0=BE=D0=BC=D1=8B=D0=B9=20=D0=BF=D0=B0=D0=BA=D0=B5?= =?UTF-8?q?=D1=82.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Перед попыткой скачивания проверяет имя пакета в списке. Если пакета с таким именем нет, говорит об этом прямым текстом. --- ...260\320\237\320\260\320\272\320\265\321\202\320\260.os" | 7 +++++++ 1 file changed, 7 insertions(+) diff --git "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" index 6c5ad34..4e6b208 100644 --- "a/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" +++ "b/src/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\321\201\321\202\320\260\320\275\320\276\320\262\320\272\320\260\320\237\320\260\320\272\320\265\321\202\320\260.os" @@ -247,6 +247,8 @@ КонецЦикла; + Возврат Неопределено; + КонецЕсли; Возврат ИмяПакета; @@ -256,6 +258,11 @@ Процедура СкачатьИУстановитьПакет(Знач ИмяПакета, Знач ВерсияПакета) ИмяАрхива = ОпределитьИмяАрхива(ИмяПакета); + Если ИмяАрхива = Неопределено Тогда + ТекстИсключения = СтрШаблон("Ошибка установки пакета %1: Пакет не найден", ИмяПакета); + ВызватьИсключение ТекстИсключения; + КонецЕсли; + Если ВерсияПакета <> Неопределено Тогда ФайлПакета = ИмяАрхива + "-" + ВерсияПакета + ".ospx"; Иначе From 59c735a1ea89e5e0d3712abf86886ae0da9569e5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=A1=D0=B5=D1=80=D0=B3=D1=A3=D0=B9=20=D0=91=D0=B0=D1=82?= =?UTF-8?q?=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Sat, 15 Apr 2017 22:36:26 +0300 Subject: [PATCH 10/11] =?UTF-8?q?=D0=A3=D1=80=D0=BE=D0=B2=D0=B5=D0=BD?= =?UTF-8?q?=D1=8C=20=D0=BB=D0=BE=D0=B3=D0=BE=D0=B2.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Сообщение об успешном скачивании ресурса переведено на уровень Отладки. --- ...\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" index 07b6fa4..4de6277 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\227\320\265\321\200\320\272\320\260\320\273\320\260.os" @@ -62,7 +62,7 @@ Если РесурсУспешноПолучен Тогда ТекстСообщения = СтрШаблон("Ресурс %1 успешно получен с %2", ИмяРесурса, ПодключенноеЗеркало.СерверУдаленногоХранилища); - Лог.Информация(ТекстСообщения); + Лог.Отладка(ТекстСообщения); Возврат Ответ; From 8bd0ec51fa0ea2ee2bb64802de1876a7e2f4cd7c Mon Sep 17 00:00:00 2001 From: Nikita Gryzlov Date: Mon, 1 May 2017 18:00:58 +0300 Subject: [PATCH 11/11] =?UTF-8?q?=D0=91=D0=B0=D0=BC=D0=BF=20=D0=B2=D0=B5?= =?UTF-8?q?=D1=80=D1=81=D0=B8=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...0\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" index 6e613f3..bdcfd4d 100644 --- "a/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" +++ "b/src/\320\234\320\276\320\264\321\203\320\273\320\270/\320\232\320\276\320\275\321\201\321\202\320\260\320\275\321\202\321\213Opm.os" @@ -23,4 +23,4 @@ ПутьВЗапасномХранилище = "/download/"; ЛокальныйКаталогУстановкиПакетов = "oscript_modules"; ИмяЛога = "oscript.app.opm"; -ВерсияПродукта = "0.9.4"; +ВерсияПродукта = "0.9.5";