diff --git a/.gitignore b/.gitignore
index 25e5d678..ef87b79e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -7,10 +7,10 @@ bdd-*.xml
.enabled-plugins
coverage/*
-bin/*
*.ospx
oscript_modules/
+tests/fixtures/gitsync-plugins/*
embedded_plugins/*.ospx
src/cmd/oscript.cfg
@@ -18,6 +18,6 @@ src/cmd/oscript.cfg
*.cfl
*.1CL
1cv8dtmp.1CD
-tests/fixtures/extension_storage/data/
-tests/fixtures/extension_storage/cache/
-tests/fixtures/extension_storage/ver
+# tests/fixtures/extension_storage/data/
+# tests/fixtures/extension_storage/cache/
+# tests/fixtures/extension_storage/ver
diff --git a/TODO b/TODO
deleted file mode 100644
index d5a7ec82..00000000
--- a/TODO
+++ /dev/null
@@ -1,6 +0,0 @@
-[] Добавить чистку кеша Хранилища 1С по отдельному флагу (или подключаемому плагину)
-[] Команда all
- [] Чтение файла формата json
- [] Чтение файла формата yaml
- [] Чтение файла формата xml для совместимости???
-[] Описать интерфейс подписчиков отдельно
diff --git a/bin/tempExtension.cfe b/bin/tempExtension.cfe
new file mode 100644
index 00000000..3f28e7aa
Binary files /dev/null and b/bin/tempExtension.cfe differ
diff --git a/build_packagedef b/build_packagedef
index 1e92459a..25b322bf 100644
--- a/build_packagedef
+++ b/build_packagedef
@@ -1,12 +1,8 @@
-#Использовать logos
#Использовать fs
-Перем Лог;
Процедура ПередСборкой(Знач РабочийКаталог) Экспорт
- ФС.ОбеспечитьПустойКаталог(ОбъединитьПути(РабочийКаталог, "oscript_modules"));
-
- Лог.Информация("Установка локальных зависимостей библиотек");
+ Сообщить("Установка локальных зависимостей библиотек");
КомандаOpm = Новый Команда;
КомандаOpm.УстановитьКоманду("opm");
@@ -19,27 +15,12 @@
ВызватьИсключение КомандаOpm.ПолучитьВывод();
КонецЕсли;
- Лог.Информация("Настройка локальных библиотек");
-
- ПутьКФайлуЗагрузчику = ОбъединитьПути(РабочийКаталог, "oscript_modules", "package-loader.os");
- ШаблонныйФайлЗагрузчик = ОбъединитьПути(РабочийКаталог, "templates", "package-loader.os");
- ФайлЗагрузчик = Новый Файл(ПутьКФайлуЗагрузчику);
- Если Не ФайлЗагрузчик.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлЗагрузчик, ПутьКФайлуЗагрузчику);
- Лог.Информация("Добавлен файл загрузки локальных библиотек");
- КонецЕсли;
+ Сообщить("Получение последней версии плагинов");
- ПутьКФайлуНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "src", "cmd", "oscript.cfg");
- ШаблонныйФайлНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "templates", "oscript.cfg");
- ФайлНастройкиСкрипта= Новый Файл(ПутьКФайлуНастройкиСкрипта);
- Если Не ФайлНастройкиСкрипта.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлНастройкиСкрипта, ПутьКФайлуНастройкиСкрипта);
- Лог.Информация("Добавлен файл настройки запуска");
- КонецЕсли;
-
КомандаOpm = Новый Команда;
КомандаOpm.УстановитьКоманду("opm");
КомандаOpm.ДобавитьПараметр("run get-plugins");
+ КомандаOpm.ДобавитьПараметр("develop");
КомандаOpm.ДобавитьЛогВыводаКоманды("task.build");
@@ -51,10 +32,6 @@
КонецПроцедуры
-Процедура ПриСборке(Знач РабочийКаталог, Знач АрхивПакета) Экспорт
-
-КонецПроцедуры
-
Процедура ПослеСборки(Знач РабочийКаталог, Знач ПутьКФайлуПакета) Экспорт
ПутьКФайлуНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "src", "cmd", "oscript.cfg");
@@ -67,23 +44,15 @@
КонецПроцедуры
-Лог = Логирование.ПолучитьЛог("task.build");
-
-//Лог = Логирование.ПолучитьЛог(ПараметрыСистемыOpm.ИмяЛогаСистемы());
-
-ПутьКСценариюПараметров = ОбъединитьПути(ТекущийСценарий().Каталог, "src/cmd", "Модули", "ПараметрыПриложения.os");
-ПараметрыСистемы_ЛокальнаяВерсия = ЗагрузитьСценарий(ПутьКСценариюПараметров);
-ИмяПродукта = НРег(ПараметрыСистемы_ЛокальнаяВерсия.ИмяПриложения());
-ВерсияПродукта = ПараметрыСистемы_ЛокальнаяВерсия.Версия();
-
-Описание.Имя(ИмяПродукта)
- .Версия(ВерсияПродукта)
- .ВерсияСреды("1.0.20")
+Описание.Имя("gitsync")
+ .Версия("3.0.0-rc.2")
+ .ВерсияСреды("1.0.21")
.ВключитьФайл("src")
.ВключитьФайл("embedded_plugins")
.ВключитьФайл("oscript_modules")
.ВключитьФайл("docs")
.ВключитьФайл("readme.md")
+ .ОпределяетКласс("МенеджерПлагинов", "src/core/Классы/МенеджерПлагинов.os")
.ОпределяетКласс("МенеджерСинхронизации", "src/core/Классы/МенеджерСинхронизации.os")
- .ОпределяетКласс("УправлениеПлагинами", "src/core/Классы/УправлениеПлагинами.os")
- .ИсполняемыйФайл("src/cmd/gitsync.os", ИмяПродукта);
\ No newline at end of file
+ .ОпределяетКласс("ПакетнаяСинхронизация", "src/core/Классы/ПакетнаяСинхронизация.os")
+ .ИсполняемыйФайл("src/cmd/gitsync.os");
\ No newline at end of file
diff --git a/config-example.json b/config-example.json
deleted file mode 100644
index 87c36e4a..00000000
--- a/config-example.json
+++ /dev/null
@@ -1,63 +0,0 @@
-{
- "gitsync-options":
- {
- "global":
- {
- "-email": "server.com",
- "-v8version": "1cv8.exe",
- "-plugins":
- [
- "pull",
- "push",
- "vendorUpload",
- "smart-tags",
- "increment"
- ],
- "flags":
- {
- "-limit": 5,
- "--storage-user": "Администратор"
- }
- },
- "repositories" : [
- {
- "name" : "test",
- "git-local-path": "путь1",
- "git-remote": "адрес1",
- "v8-storage-dir": "каталог1",
- "-plugins":
- [
- "pull",
- "push",
- "vendorUpload",
- "smart-tags",
- "increment"
- ]
- ,
- "flags": {
- "-limit": 5,
- "--storage-user": "Администратор"
- }
- },
- {
- "name" : "test2",
- "git-local-path": "путь2",
- "git-remote": "адрес2",
- "v8-storage-dir": "каталог2",
- "-plugins":
- [
- "pull",
- "push",
- "vendorUpload",
- "smart-tags",
- "increment"
- ]
- ,
- "flags": {
- "-limit": 5,
- "--storage-user": "Администратор"
- }
- }
- ]
- }
-}
diff --git a/config-example.xml b/config-example.xml
deleted file mode 100644
index fc64d1f1..00000000
--- a/config-example.xml
+++ /dev/null
@@ -1,25 +0,0 @@
-
-
- server.com
- 8.3.6
- git
-
-
-
- путь1
- адрес1
- каталог1
-
-
-
-
-
- путь2
- адрес2
- каталог2
- gmail.com
-
-
-
-
-
\ No newline at end of file
diff --git a/config-example.yaml b/config-example.yaml
deleted file mode 100644
index 18098b84..00000000
--- a/config-example.yaml
+++ /dev/null
@@ -1,47 +0,0 @@
-globals:
- storage-user: Администратор
- storage-pwd: ''
- git-path: git
- temp-dir: ""
- v8version: 8.3
- domain-email: localhost
- lic-try-count: 5
- plugins:
- enable:
- - test
- - test2
- disable:
- - test3
- plugins-config:
- git-url: git-url
- push: true
- pull: true
-repositories:
- - name: <ТестовыйРепозиторий>
- disable: true
- storage-path: <КаталогХранилища1С_1>
- git-local-path: <ПутьКаталогаИсходников_1>
- - name: <ТестовыйРепозиторий2>
- disable: true
- storage-path: <КаталогХранилища1С_2>
- git-local-path: <ПутьКаталогаИсходников_2>
- storage-user: Администратор
- storage-pwd: ''
- git-path: git
- temp-dir: ""
- v8version: 8.3
- domain-email: localhost
- lic-try-count: 5
- plugins:
- enable:
- - test
- - test2
- disable:
- - test3
- plugins-config:
- git-url: git-url
- push: true
- pull: true
-
-
-
\ No newline at end of file
diff --git a/docs/usage.md b/docs/usage.md
new file mode 100644
index 00000000..e69de29b
diff --git a/features/cmd/all.feature b/features/cmd/all.feature
new file mode 100644
index 00000000..f459136a
--- /dev/null
+++ b/features/cmd/all.feature
@@ -0,0 +1,55 @@
+# language: ru
+
+Функционал: Проверка работы команды all
+ Как Пользователь
+ Я хочу выполнить клонирование существующего репозитория гит
+ Чтобы выполнять автоматическую выгрузку конфигураций из хранилища
+
+Структура сценария: <Сценарий>
+ Дано Я очищаю параметры команды "gitsync" в контексте
+ И Я создаю новый объект ГитРепозиторий
+ И Я устанавливаю путь выполнения команды "gitsync" к текущей библиотеке
+
+ # Подготовка хранилища 1
+ И Я создаю временный каталог и сохраняю его в переменной "КаталогХранилища1С_1"
+ И я скопировал каталог тестового хранилища конфигурации в каталог из переменной "КаталогХранилища1С_1"
+ И Я создаю временный каталог и сохраняю его в переменной "ПутьКаталогаИсходников_1"
+ И Я инициализирую репозиторий в каталоге из переменной "ПутьКаталогаИсходников_1"
+ И Я создаю тестовой файл AUTHORS в каталоге из переменной "ПутьКаталогаИсходников_1"
+ И Я записываю "0" в файл VERSION в каталоге из переменной "ПутьКаталогаИсходников_1"
+
+ # Подготовка хранилища 2
+ И Я создаю временный каталог и сохраняю его в переменной "КаталогХранилища1С_2"
+ И я скопировал каталог тестового хранилища конфигурации в каталог из переменной "КаталогХранилища1С_2"
+ И Я создаю временный каталог и сохраняю его в переменной "ПутьКаталогаИсходников_2"
+ И Я инициализирую репозиторий в каталоге из переменной "ПутьКаталогаИсходников_2"
+ И Я создаю тестовой файл AUTHORS в каталоге из переменной "ПутьКаталогаИсходников_2"
+ И Я записываю "0" в файл VERSION в каталоге из переменной "ПутьКаталогаИсходников_2"
+
+ # Подготовка хранилища 2
+ И Я создаю временный каталог и сохраняю его в переменной "КаталогХранилищаРасширения"
+ И я скопировал каталог тестового хранилища конфигурации расширения в каталог из переменной "КаталогХранилищаРасширения"
+ И Я создаю временный каталог и сохраняю его в переменной "ПутьКаталогаИсходниковРасширения"
+ И Я инициализирую репозиторий в каталоге из переменной "ПутьКаталогаИсходниковРасширения"
+ И Я создаю тестовой файл AUTHORS в каталоге из переменной "ПутьКаталогаИсходниковРасширения"
+ И Я записываю "0" в файл VERSION в каталоге из переменной "ПутьКаталогаИсходниковРасширения"
+
+ И Я создаю файл настройки из файла <ПутьКФайлуШаблона> и сохраняю в переменную "FILE"
+
+ Допустим Я создаю временный каталог и сохраняю его в переменной "ВременнаяДиректория"
+ И Я добавляю параметр "--tempdir" для команды "gitsync" из переменной "ВременнаяДиректория"
+ # И Я добавляю параметр "-v" для команды "gitsync"
+ И Я добавляю параметр "all" для команды "gitsync"
+ И Я добавляю параметр <ДопПараметрыЗапуска> для команды "gitsync"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "FILE"
+ Когда Я выполняю команду "gitsync"
+ Тогда Вывод команды "gitsync" содержит <Результат>
+ И Вывод команды "gitsync" не содержит "Внешнее исключение"
+ И Код возврата команды "gitsync" равен 0
+
+Примеры:
+ | Сценарий | ПутьКФайлуШаблона | ДопПараметрыЗапуска | Результат |
+ | Выполнение синхронизации по имени | tests/fixtures/default.yaml | --name ТестовыйРепозиторий | ИНФОРМАЦИЯ - Наименование: <ТестовыйРепозиторий> |
+ | Выполнение синхронизации с несколькими хранилищами | tests/fixtures/default.yaml | | ИНФОРМАЦИЯ - Завершено выполнение команды |
+ | Выполнение синхронизации расширениями | tests/fixtures/ext.yaml | | ИНФОРМАЦИЯ - Завершено выполнение команды |
+
\ No newline at end of file
diff --git a/features/cmd/extention.feature b/features/cmd/extention.feature
new file mode 100644
index 00000000..a4258692
--- /dev/null
+++ b/features/cmd/extention.feature
@@ -0,0 +1,30 @@
+# language: ru
+
+Функционал: Проверка работы с хранилищем расширения
+ Как Пользователь
+ Я хочу выполнить клонирование существующего репозитория гит
+ Чтобы выполнять автоматическую выгрузку конфигураций из хранилища
+
+Контекст: Тестовый контекст
+ Когда Я очищаю параметры команды "gitsync" в контексте
+ И Я создаю новый объект ГитРепозиторий
+ И Я устанавливаю путь выполнения команды "gitsync" к текущей библиотеке
+ И Я создаю временный каталог и сохраняю его в переменной "КаталогХранилища1С"
+ И я скопировал каталог тестового хранилища конфигурации расширения в каталог из переменной "КаталогХранилища1С"
+ И Я создаю временный каталог и сохраняю его в переменной "ПутьКаталогаИсходников"
+ И Я инициализирую репозиторий в каталоге из переменной "ПутьКаталогаИсходников"
+ И Я создаю тестовой файл AUTHORS
+ И Я записываю "0" в файл VERSION
+
+ Сценарий: Простая синхронизация хранилища с git-репозиторием
+ Допустим Я создаю временный каталог и сохраняю его в переменной "ВременнаяДиректория"
+ И Я добавляю параметр "--tempdir" для команды "gitsync" из переменной "ВременнаяДиректория"
+ И Я добавляю параметр "-v" для команды "gitsync"
+ И Я добавляю параметр "sync" для команды "gitsync"
+ И Я добавляю параметр "-e test" для команды "gitsync"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "КаталогХранилища1С"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "ПутьКаталогаИсходников"
+ Когда Я выполняю команду "gitsync"
+ Тогда Вывод команды "gitsync" содержит "ИНФОРМАЦИЯ - Завершена синхронизации с git"
+ И Вывод команды "gitsync" не содержит "Внешнее исключение"
+ И Код возврата команды "gitsync" равен 0
\ No newline at end of file
diff --git a/features/cmd/fixtures/default.yaml b/features/cmd/fixtures/default.yaml
new file mode 100644
index 00000000..3bfca11f
--- /dev/null
+++ b/features/cmd/fixtures/default.yaml
@@ -0,0 +1,34 @@
+globals:
+ storage-user: Администратор
+ storage-pwd: ''
+ git-path: git
+ v8version: 8.3
+ domain-email: localhost
+ lic-try-count: 5
+ plugins:
+ enable:
+ - test
+ - test2
+ disable:
+ - test3
+repositories:
+ - name: ТестовыйРепозиторий
+ # disable: false
+ path: <КаталогХранилища1С_1>
+ dir: <ПутьКаталогаИсходников_1>
+ plugins:
+ more:
+ - test3
+ plugins-config:
+
+ - name: ТестовыйРепозиторий2
+ # disable: true
+ path: <КаталогХранилища1С_2>
+ dir: <ПутьКаталогаИсходников_2>
+ storage-user: Администратор
+ storage-pwd: ''
+ git-path: git
+ temp-dir: ""
+ v8version: 8.3
+ domain-email: localhost
+ lic-try-count: 5
\ No newline at end of file
diff --git a/features/cmd/ibconnection.feature b/features/cmd/ibconnection.feature
new file mode 100644
index 00000000..ff9c1d7a
--- /dev/null
+++ b/features/cmd/ibconnection.feature
@@ -0,0 +1,64 @@
+# language: ru
+
+Функционал: Синхронизация в конкретной информационной базе
+ Как Пользователь
+ Я хочу иметь возможность указать не стандартный путь к платформе 1С
+ Чтобы иметь возможность запускать синхронизацию с указание конкретной информационной базы
+
+Контекст: Тестовый контекст
+ Когда Я очищаю параметры команды "gitsync" в контексте
+ И Я создаю новый объект ГитРепозиторий
+ И Я устанавливаю путь выполнения команды "gitsync" к текущей библиотеке
+ И Я создаю временный каталог и сохраняю его в переменной "КаталогХранилища1С"
+ И я скопировал каталог тестового хранилища конфигурации в каталог из переменной "КаталогХранилища1С"
+ И Я создаю временный каталог и сохраняю его в переменной "ПутьКаталогаИсходников"
+ И Я инициализирую репозиторий в каталоге из переменной "ПутьКаталогаИсходников"
+ И Я создаю временную базу и сохраняю в переменную "ВременнаяБаза"
+ И Я создаю тестовой файл AUTHORS
+ И Я записываю "0" в файл VERSION
+
+Сценарий: Простая синхронизация хранилища с git-репозиторием
+ Допустим Я создаю временный каталог и сохраняю его в переменной "ВременнаяДиректория"
+ И Я добавляю параметр "-v" для команды "gitsync"
+ И Я добавляю параметр "--tempdir" для команды "gitsync" из переменной "ВременнаяДиректория"
+ И Я добавляю параметр "--ib-connection" для команды "gitsync" из переменной "ВременнаяБаза"
+ И Я добавляю параметр "sync" для команды "gitsync"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "КаталогХранилища1С"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "ПутьКаталогаИсходников"
+ Когда Я выполняю команду "gitsync"
+ Тогда Вывод команды "gitsync" содержит "Для синхронизации используется база"
+ И Вывод команды "gitsync" содержит "Завершена синхронизации с git"
+ И Вывод команды "gitsync" не содержит "Внешнее исключение"
+ И Код возврата команды "gitsync" равен 0
+
+Сценарий: Клонирование репозитория гит и наполнение его служебными данными
+ Допустим Я создаю временный каталог и сохраняю его в переменной "URLРепозитория"
+ И Я инициализирую bare репозиторий в каталоге из переменной "URLРепозитория"
+ И Я наполняю bare репозиторий из переменной "URLРепозитория" тестовыми данными
+ И Я добавляю параметр "-v" для команды "gitsync"
+ И Я добавляю параметр "--ib-connection" для команды "gitsync" из переменной "ВременнаяБаза"
+ И Я добавляю параметр "clone" для команды "gitsync"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "КаталогХранилища1С"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "URLРепозитория"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "ПутьКаталогаИсходников"
+ Когда Я выполняю команду "gitsync"
+ Тогда Вывод команды "gitsync" содержит "Клонирование завершено"
+ И Вывод команды "gitsync" не содержит "Внешнее исключение"
+ И Код возврата команды "gitsync" равен 0
+ И В каталоге из переменной "ПутьКаталогаИсходников" создается файл или каталог "AUTHORS"
+ И В каталоге из переменной "ПутьКаталогаИсходников" создается файл или каталог "VERSION"
+
+Сценарий: Инициализация каталога исходников в пустом каталоге внутри git-репозитория
+ Допустим Я инициализирую пустой репозиторий в каталог из переменной "ПутьКаталогаИсходников"
+ И Я создаю каталог src временный в каталоге из переменной "ПутьКаталогаИсходников" и сохраняю его в контекст в переменной "КаталогSRC"
+ И Я добавляю параметр "--ib-connection" для команды "gitsync" из переменной "ВременнаяБаза"
+ И Я добавляю параметр "init" для команды "gitsync"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "КаталогХранилища1С"
+ И Я добавляю позиционный параметр для команды "gitsync" из переменной "КаталогSRC"
+ Когда Я выполняю команду "gitsync"
+ Тогда Вывод команды "gitsync" содержит "Инициализация завершена"
+ И Вывод команды "gitsync" не содержит "Внешнее исключение"
+ И Код возврата команды "gitsync" равен 0
+ И В каталоге из переменной "КаталогSRC" создается файл или каталог "AUTHORS"
+ И В каталоге из переменной "КаталогSRC" создается файл или каталог "VERSION"
+ И В каталоге из переменной "КаталогSRC" не создается файл или каталог ".git"
\ No newline at end of file
diff --git a/features/cmd/step_definitions/all.os b/features/cmd/step_definitions/all.os
new file mode 100644
index 00000000..5daace23
--- /dev/null
+++ b/features/cmd/step_definitions/all.os
@@ -0,0 +1,148 @@
+#Использовать tempfiles
+#Использовать yaml
+
+// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
+
+Перем БДД; //контекст фреймворка 1bdd
+
+// Метод выдает список шагов, реализованных в данном файле-шагов
+Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
+ БДД = КонтекстФреймворкаBDD;
+
+ ВсеШаги = Новый Массив;
+
+ ВсеШаги.Добавить("ЯСоздаюТестовойФайлAuthorsВКаталогеИзПеременной");
+ ВсеШаги.Добавить("ЯЗаписываюВФайлVersionВКаталогеИзПеременной");
+ ВсеШаги.Добавить("ЯСоздаюФайлНастройкиИзФайлаИСохраняюВПеременную");
+ ВсеШаги.Добавить("ЯДобавляюПараметр__Параметрдлятаблицы____Параметрстрока__Gitsync");
+
+ Возврат ВсеШаги;
+КонецФункции
+
+// Реализация шагов
+
+// Процедура выполняется перед запуском каждого сценария
+Процедура ПередЗапускомСценария(Знач Узел) Экспорт
+
+КонецПроцедуры
+
+// Процедура выполняется после завершения каждого сценария
+Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
+
+КонецПроцедуры
+
+
+
+//Я создаю тестовой файл AUTHORS в каталоге из переменной "ПутьКаталогаИсходников_1"
+Процедура ЯСоздаюТестовойФайлAuthorsВКаталогеИзПеременной(Знач ИмяПеременной) Экспорт
+ ПутьКаталогаИсходников = БДД.ПолучитьИзКонтекста(ИмяПеременной);
+ ФайлАвторов = Новый ЗаписьТекста;
+ ФайлАвторов.Открыть(ОбъединитьПути(ПутьКаталогаИсходников, "AUTHORS"), "utf-8");
+ ФайлАвторов.ЗаписатьСтроку("Администратор=Администратор ");
+ ФайлАвторов.ЗаписатьСтроку("Отладка=Отладка ");
+ ФайлАвторов.Закрыть();
+КонецПроцедуры
+
+//Я записываю "0" в файл VERSION в каталоге из переменной "ПутьКаталогаИсходников_1"
+Процедура ЯЗаписываюВФайлVersionВКаталогеИзПеременной(Знач НомерВерсии, Знач ИмяПеременной) Экспорт
+
+ ПутьКаталогаИсходников = БДД.ПолучитьИзКонтекста(ИмяПеременной);
+
+ ПутьКФайлуВерсий = ОбъединитьПути(ПутьКаталогаИсходников,"VERSION");
+ Попытка
+ Запись = Новый ЗаписьТекста(ПутьКФайлуВерсий, "utf-8");
+ Запись.ЗаписатьСтроку("");
+ Запись.ЗаписатьСтроку("" + НомерВерсии + "");
+ Запись.Закрыть();
+ Исключение
+ Если Запись <> Неопределено Тогда
+ ОсвободитьОбъект(Запись);
+ КонецЕсли;
+ ВызватьИсключение;
+ КонецПопытки;
+КонецПроцедуры
+
+//Я создаю файл настройки из файла и сохраняю в переменную "FILE"
+Процедура ЯСоздаюФайлНастройкиИзФайлаИСохраняюВПеременную(Знач ПутьКФайлу, Знач ИмяПеременной) Экспорт
+
+
+ ПутьКаталогаИсходников_1 = БДД.ПолучитьИзКонтекста("ПутьКаталогаИсходников_1");
+ КаталогХранилища1С_1 = БДД.ПолучитьИзКонтекста("КаталогХранилища1С_1");
+
+ ПутьКаталогаИсходников_2 = БДД.ПолучитьИзКонтекста("ПутьКаталогаИсходников_2");
+ КаталогХранилища1С_2 = БДД.ПолучитьИзКонтекста("КаталогХранилища1С_2");
+
+ ПутьКаталогаИсходниковРасширения = БДД.ПолучитьИзКонтекста("ПутьКаталогаИсходниковРасширения");
+ КаталогХранилищаРасширения = БДД.ПолучитьИзКонтекста("КаталогХранилищаРасширения");
+
+
+ ЧтениеТекста = Новый ЧтениеТекста();
+ ЧтениеТекста.Открыть(ПутьКФайлу, КодировкаТекста.UTF8);
+ ТекстYaml = ЧтениеТекста.Прочитать();
+ ЧтениеТекста.Закрыть();
+
+ ТекстYaml = СтрЗаменить(ТекстYaml, "<ПутьКаталогаИсходников_1>", ПутьКаталогаИсходников_1);
+ ТекстYaml = СтрЗаменить(ТекстYaml, "<КаталогХранилища1С_1>", КаталогХранилища1С_1);
+
+ ТекстYaml = СтрЗаменить(ТекстYaml, "<ПутьКаталогаИсходников_2>", ПутьКаталогаИсходников_2);
+ ТекстYaml = СтрЗаменить(ТекстYaml, "<КаталогХранилища1С_2>", КаталогХранилища1С_2);
+
+ ТекстYaml = СтрЗаменить(ТекстYaml, "<ПутьКаталогаИсходниковРасширения>", ПутьКаталогаИсходниковРасширения);
+ ТекстYaml = СтрЗаменить(ТекстYaml, "<КаталогХранилищаРасширения>", КаталогХранилищаРасширения);
+
+ ВременныйФайл = ВременныеФайлы.СоздатьФайл(".yaml");
+
+ ЗаписьТекста = Новый ЗаписьТекста(ВременныйФайл);
+ ЗаписьТекста.Записать(ТекстYaml);
+ ЗаписьТекста.Закрыть();
+
+
+ ЧтениеТекста = Новый ЧтениеТекста();
+ ЧтениеТекста.Открыть(ВременныйФайл, КодировкаТекста.UTF8);
+ ТекстYaml = ЧтениеТекста.Прочитать();
+ ЧтениеТекста.Закрыть();
+
+ ПарсерYAml = Новый ПарсерYaml();
+ Результа = ПарсерYAml.ПрочитатьYaml(ТекстYaml);
+
+ ТекстJson = ОБъектВJson(Результа);
+
+ ВременныйФайл = ВременныеФайлы.СоздатьФайл(".json");
+ ЗаписьТекста = Новый ЗаписьТекста(ВременныйФайл);
+ ЗаписьТекста.Записать(ТекстJson);
+ ЗаписьТекста.Закрыть();
+
+ БДД.СохранитьВКонтекст(ИмяПеременной, ВременныйФайл);
+
+КонецПроцедуры
+
+
+Функция ОБъектВJson(Знач Объект, ПараметрыЗаписи = Неопределено) Экспорт
+
+ Если ПараметрыЗаписи = Неопределено Тогда
+ ПараметрыЗаписи = Новый ПараметрыЗаписиJSON(ПереносСтрокJSON.Авто, " ", ,,,,,, Истина);
+ КонецЕсли;
+
+ ЗаписьJSON = Новый ЗаписьJSON;
+ ЗаписьJSON.УстановитьСтроку(ПараметрыЗаписи);
+ ЗаписатьJSON(ЗаписьJSON, Объект);
+
+ Возврат ЗаписьJSON.Закрыть();
+
+КонецФункции
+
+Функция ОбъектИзJson(ТекстJSON, ЧитатьВСтруктуру = Ложь, ФорматДаты = Неопределено) Экспорт
+
+ Если ФорматДаты = Неопределено Тогда
+ ФорматДаты = ФорматДатыJSON.ISO;
+ КонецЕсли;
+ ЧтениеJSON = Новый ЧтениеJSON;
+ ЧтениеJSON.УстановитьСтроку(ТекстJSON);
+
+ Объект = ПрочитатьJSON(ЧтениеJSON,
+ НЕ ЧитатьВСтруктуру,,
+ ФорматДаты);
+ ЧтениеJSON.Закрыть();
+ Возврат Объект;
+
+КонецФункции
diff --git a/features/cmd/step_definitions/clone.os b/features/cmd/step_definitions/clone.os
index ed02201e..dde5cd7e 100644
--- a/features/cmd/step_definitions/clone.os
+++ b/features/cmd/step_definitions/clone.os
@@ -2,7 +2,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
@@ -19,14 +19,13 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
-
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
@@ -36,7 +35,7 @@
ГитРепозиторий = БДД.ПолучитьИзКонтекста("ГитРепозиторий");
URLРепозитория = БДД.ПолучитьИзКонтекста(ПеременнаяURLРепозитория);
- ВременныйКаталог = ЛокальныеВременныеФайлы.СоздатьКаталог();
+ ВременныйКаталог = ВременныеФайлы.СоздатьКаталог();
ГитРепозиторий.УстановитьРабочийКаталог(ВременныйКаталог);
ГитРепозиторий.Инициализировать();
@@ -62,7 +61,7 @@
ГитРепозиторий.Отправить();
- ЛокальныеВременныеФайлы.БезопасноУдалитьФайл(ВременныйКаталог);
+ ВременныеФайлы.БезопасноУдалитьФайл(ВременныйКаталог);
КонецПроцедуры
diff --git a/features/cmd/step_definitions/extention.os b/features/cmd/step_definitions/extention.os
new file mode 100644
index 00000000..6a1811fc
--- /dev/null
+++ b/features/cmd/step_definitions/extention.os
@@ -0,0 +1,54 @@
+#Использовать fs
+
+// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
+
+Перем БДД; //контекст фреймворка 1bdd
+
+
+// Метод выдает список шагов, реализованных в данном файле-шагов
+Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
+ БДД = КонтекстФреймворкаBDD;
+
+ ВсеШаги = Новый Массив;
+
+ ВсеШаги.Добавить("ЯСкопировалКаталогТестовогоХранилищаКонфигурацииРасширенияВКаталогИзПеременной");
+
+ Возврат ВсеШаги;
+КонецФункции
+
+// Реализация шагов
+
+// Процедура выполняется перед запуском каждого сценария
+Процедура ПередЗапускомСценария(Знач Узел) Экспорт
+
+
+
+КонецПроцедуры
+
+// Процедура выполняется после завершения каждого сценария
+Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
+
+
+КонецПроцедуры
+
+
+//я скопировал каталог тестового хранилища конфигурации расширения в каталог из переменной "КаталогХранилища1С"
+Процедура ЯСкопировалКаталогТестовогоХранилищаКонфигурацииРасширенияВКаталогИзПеременной(Знач ИмяПеременной) Экспорт
+ КаталогХранилища1С = БДД.ПолучитьИзКонтекста(ИмяПеременной);
+ ФС.КопироватьСодержимоеКаталога(ПутьКВременномуФайлуХранилища1С(), КаталогХранилища1С);
+ // КопироватьФайл(ПутьКВременномуФайлуХранилища1С(), ОбъединитьПути(КаталогХранилища1С, "1cv8ddb.1CD"));
+КонецПроцедуры
+
+Функция ПутьКВременномуФайлуХранилища1С()
+
+ Возврат ОбъединитьПути(КаталогFixtures(), "extension_storage");
+
+КонецФункции
+
+Функция КаталогFixtures()
+ Возврат ОбъединитьПути(КаталогГитсинк(), "tests", "fixtures");
+КонецФункции
+
+Функция КаталогГитсинк()
+ Возврат ОбъединитьПути(ТекущийСценарий().Каталог, "..", "..", "..");
+КонецФункции
diff --git a/features/cmd/step_definitions/ibconnection.os b/features/cmd/step_definitions/ibconnection.os
new file mode 100644
index 00000000..d1bd8d0e
--- /dev/null
+++ b/features/cmd/step_definitions/ibconnection.os
@@ -0,0 +1,47 @@
+#Использовать v8runner
+#Использовать tempfiles
+
+// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
+
+
+Перем БДД; //контекст фреймворка 1bdd
+
+
+// Метод выдает список шагов, реализованных в данном файле-шагов
+Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
+ БДД = КонтекстФреймворкаBDD;
+
+ ВсеШаги = Новый Массив;
+
+ ВсеШаги.Добавить("ЯСоздаюВременнуюБазуИСохраняюВПеременную");
+
+ Возврат ВсеШаги;
+КонецФункции
+
+// Реализация шагов
+
+
+// Процедура выполняется перед запуском каждого сценария
+Процедура ПередЗапускомСценария(Знач Узел) Экспорт
+
+
+
+КонецПроцедуры
+
+// Процедура выполняется после завершения каждого сценария
+Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
+
+КонецПроцедуры
+
+
+//Я создаю временную базу и сохраняю в переменную "ВременнаяБаза"
+Процедура ЯСоздаюВременнуюБазуИСохраняюВПеременную(Знач ИмяПеременной) Экспорт
+
+ ПутьКВременнойБазе = ВременныеФайлы.СоздатьКаталог();
+
+ УправлениеКонфигуратором = Новый УправлениеКонфигуратором;
+ УправлениеКонфигуратором.СоздатьФайловуюБазу(ПутьКВременнойБазе);
+
+ БДД.СохранитьВКонтекст(ИмяПеременной, СтрШаблон("/F%1",ПутьКВременнойБазе));
+
+КонецПроцедуры
diff --git a/features/cmd/step_definitions/init.os b/features/cmd/step_definitions/init.os
index 4ae473fb..153fea24 100644
--- a/features/cmd/step_definitions/init.os
+++ b/features/cmd/step_definitions/init.os
@@ -2,7 +2,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
БДД = КонтекстФреймворкаBDD;
@@ -20,13 +20,13 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
//Я инициализирую пустой репозиторий в каталог из переменной "ПутьКаталогаИсходников"
diff --git a/features/cmd/step_definitions/shared.os b/features/cmd/step_definitions/shared.os
index 42af4ccd..30784c14 100644
--- a/features/cmd/step_definitions/shared.os
+++ b/features/cmd/step_definitions/shared.os
@@ -6,7 +6,7 @@
#Использовать "../../../src/core"
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
Перем Лог;
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
@@ -53,13 +53,13 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
//я устанавливаю в контексте признак статистики скриптов OneScript
@@ -104,7 +104,7 @@
//Я устанавливаю рабочей каталог во временный каталог
Процедура ЯУстанавливаюРабочейКаталогВоВременныйКаталог() Экспорт
- УстановитьТекущийКаталог(ЛокальныеВременныеФайлы.СоздатьКаталог());
+ УстановитьТекущийКаталог(ВременныеФайлы.СоздатьКаталог());
КонецПроцедуры
//Я создаю новый объект ГитРепозиторий
@@ -193,7 +193,13 @@
Процедура ЯДобавляюПараметрДляКомандыИзПеременной(Знач Параметр, Знач ИмяКоманды, Знач ИмяПеременной) Экспорт
Команда = БДД.ПолучитьИзКонтекста(КлючКоманды(ИмяКоманды));
ЗначениеПеременной = БДД.ПолучитьИзКонтекста(ИмяПеременной);
+
+ Если СтрНайти(ЗначениеПеременной, " ") Тогда
+ ЗначениеПеременной = ОбернутьВКавычки(ЗначениеПеременной);
+ КонецЕсли;
+
Команда.ДобавитьПараметр(СтрШаблон("%1 %2", Параметр, ЗначениеПеременной));
+
КонецПроцедуры
//Я устанавливаю путь выполнения команды "gitsync" к текущей библиотеке
@@ -214,8 +220,7 @@
Команда = БДД.ПолучитьИзКонтекста(КлючКоманды(ИмяКоманды));
Если НЕ ЭтоExe Тогда
- ПодготовитьПриложениеКТестированию(КаталогГитсинк());
-
+
Команда.УстановитьКоманду("oscript");
Команда.ДобавитьПараметр("-encoding=utf-8");
@@ -365,40 +370,7 @@
Возврат "Команда-" + ИмяКоманды;
КонецФункции
-Процедура ПодготовитьПриложениеКТестированию(Знач РабочийКаталог) Экспорт
-
- Лог.Отладка("Установка локальных зависимостей библиотек");
- КомандаOpm = Новый Команда;
- КомандаOpm.УстановитьРабочийКаталог(РабочийКаталог);
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("install -l");
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение КомандаOpm.ПолучитьВывод();
- КонецЕсли;
-
- Лог.Отладка("Настройка локальных библиотек");
-
- ПутьКФайлуЗагрузчику = ОбъединитьПути(РабочийКаталог, "oscript_modules", "package-loader.os");
- ШаблонныйФайлЗагрузчик = ОбъединитьПути(РабочийКаталог, "templates", "package-loader.os");
- ФайлЗагрузчик = Новый Файл(ПутьКФайлуЗагрузчику);
- Если Не ФайлЗагрузчик.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлЗагрузчик, ПутьКФайлуЗагрузчику);
- Лог.Информация("Добавлен файл загрузки локальных библиотек");
- КонецЕсли;
-
- ПутьКФайлуНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "src", "cmd", "oscript.cfg");
- ШаблонныйФайлНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "templates", "oscript.cfg");
- ФайлНастройкиСкрипта= Новый Файл(ПутьКФайлуНастройкиСкрипта);
- Если Не ФайлНастройкиСкрипта.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлНастройкиСкрипта, ПутьКФайлуНастройкиСкрипта);
- Лог.Информация("Добавлен файл настройки запуска");
- КонецЕсли;
-
-КонецПроцедуры
-ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
Лог = Логирование.ПолучитьЛог(ИмяЛога());
\ No newline at end of file
diff --git a/features/cmd/step_definitions/sync.core.os b/features/cmd/step_definitions/sync.core.os
index e0327d2a..2951866e 100644
--- a/features/cmd/step_definitions/sync.core.os
+++ b/features/cmd/step_definitions/sync.core.os
@@ -4,7 +4,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
БДД = КонтекстФреймворкаBDD;
@@ -12,7 +12,7 @@
ВсеШаги = Новый Массив;
ВсеШаги.Добавить("ЯСоздаюВременныйКаталогИСохраняюЕгоВПеременной");
- ВсеШаги.Добавить("ЯСоздаюНовыйУправлениеплагинами");
+ ВсеШаги.Добавить("ЯСоздаюНовыйМенеджерПлагинов");
ВсеШаги.Добавить("ЯСобираюТестовыйПлагинИСохраняюВКонтекст");
ВсеШаги.Добавить("ЯУстанавливаюФайлПлагинаИзПеременной");
ВсеШаги.Добавить("ЯЗагружаюПлагиныИзКаталогаВПеременной");
@@ -26,19 +26,19 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
//Я создаю временный каталог и сохраняю его в переменной "КаталогПлагинов"
Процедура ЯСоздаюВременныйКаталогИСохраняюЕгоВПеременной(Знач ИмяПеременной) Экспорт
- ВременныйКаталог = ЛокальныеВременныеФайлы.СоздатьКаталог();
+ ВременныйКаталог = ВременныеФайлы.СоздатьКаталог();
БДД.СохранитьВКонтекст(ИмяПеременной, ВременныйКаталог);
@@ -47,7 +47,7 @@
//Я собираю тестовый плагин и сохраняю в контекст "ПутьКФайлуПлагина"
Процедура ЯСобираюТестовыйПлагинИСохраняюВКонтекст(Знач ИмяПеременной) Экспорт
- ВременныйКаталог = ЛокальныеВременныеФайлы.СоздатьКаталог();
+ ВременныйКаталог = ВременныеФайлы.СоздатьКаталог();
ФС.КопироватьСодержимоеКаталога(КаталогТестовогоПлагина(), ВременныйКаталог);
@@ -77,32 +77,32 @@
КонецПроцедуры
-//Я создаю новый УправлениеПлагинами
-Процедура ЯСоздаюНовыйУправлениеплагинами() Экспорт
- УправлениеПлагинами = Новый УправлениеПлагинами;
+//Я создаю новый МенеджерПлагинов
+Процедура ЯСоздаюНовыйМенеджерПлагинов() Экспорт
+ МенеджерПлагинов = Новый МенеджерПлагинов;
- БДД.СохранитьВКонтекст("УправлениеПлагинами", УправлениеПлагинами);
+ БДД.СохранитьВКонтекст("МенеджерПлагинов", МенеджерПлагинов);
КонецПроцедуры
//Я загружаю плагины из каталога в переменной "КаталогПлагинов"
Процедура ЯЗагружаюПлагиныИзКаталогаВПеременной(Знач ИмяПеременнойКаталога) Экспорт
- УправлениеПлагинами = БДД.ПолучитьИзКонтекста("УправлениеПлагинами");
+ МенеджерПлагинов = БДД.ПолучитьИзКонтекста("МенеджерПлагинов");
КаталогПлагинов = БДД.ПолучитьИзКонтекста(ИмяПеременнойКаталога);
- УправлениеПлагинами.УстановитьКаталогПлагинов(КаталогПлагинов);
- УправлениеПлагинами.ЗагрузитьПлагины();
+ МенеджерПлагинов.УстановитьКаталогПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.ЗагрузитьПлагины();
- УправлениеПлагинами.ВключитьПлагин("test_plugin");
+ МенеджерПлагинов.ВключитьПлагин("test_plugin");
КонецПроцедуры
//Я подключаю плагины в МенеджерСинхронизации
Процедура ЯПодключаюПлагиныВМенеджерсинхронизации() Экспорт
- УправлениеПлагинами = БДД.ПолучитьИзКонтекста("УправлениеПлагинами");
+ МенеджерПлагинов = БДД.ПолучитьИзКонтекста("МенеджерПлагинов");
- ИндексПлагинов = УправлениеПлагинами.ПолучитьИндексПлагинов();
+ ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
МенеджерСинхронизации = БДД.ПолучитьИзКонтекста("МенеджерСинхронизации");
МенеджерСинхронизации.ПодпискиНаСобытия(ИндексПлагинов);
@@ -115,9 +115,9 @@
КаталогПлагинов = БДД.ПолучитьИзКонтекста("КаталогПлагинов");
ФайлПлагина = БДД.ПолучитьИзКонтекста(ПутьКФайлуПлагина);
- УправлениеПлагинами = БДД.ПолучитьИзКонтекста("УправлениеПлагинами");
- УправлениеПлагинами.УстановитьКаталогПлагинов(КаталогПлагинов);
- УправлениеПлагинами.УстановитьФайлПлагин(ФайлПлагина);
+ МенеджерПлагинов = БДД.ПолучитьИзКонтекста("МенеджерПлагинов");
+ МенеджерПлагинов.УстановитьКаталогПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.УстановитьФайлПлагин(ФайлПлагина);
КонецПроцедуры
@@ -126,4 +126,4 @@
Возврат ОбъединитьПути(ТекущийСценарий().Каталог, "testsata", "test_plugin");
КонецФункции
-ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
diff --git a/features/cmd/step_definitions/sync.os b/features/cmd/step_definitions/sync.os
index 3a99892e..1aa3b993 100644
--- a/features/cmd/step_definitions/sync.os
+++ b/features/cmd/step_definitions/sync.os
@@ -1,7 +1,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
@@ -17,12 +17,12 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
diff --git "a/features/cmd/step_definitions/testsata/test_plugin/src/\320\232\320\273\320\260\321\201\321\201\321\213/testPlugin.os" "b/features/cmd/step_definitions/testsata/test_plugin/src/\320\232\320\273\320\260\321\201\321\201\321\213/testPlugin.os"
index 32280b51..9f99d014 100644
--- "a/features/cmd/step_definitions/testsata/test_plugin/src/\320\232\320\273\320\260\321\201\321\201\321\213/testPlugin.os"
+++ "b/features/cmd/step_definitions/testsata/test_plugin/src/\320\232\320\273\320\260\321\201\321\201\321\213/testPlugin.os"
@@ -116,7 +116,7 @@
// ПутьКХранилищу - Строка - полный путь к хранилищу конфигурации
// СтандартнаяОбработка - Булево - признак отказ от обработки по умолчанию
//
-Процедура ПриПолученииТаблицыВерсий(ТаблицаВерсий, ПутьКХранилищу, СтандартнаяОбработка) Экспорт
+Процедура ПриПолученииТаблицыВерсий(ТаблицаВерсий, ПутьКХранилищу, ТекущаяВерсия, СтандартнаяОбработка) Экспорт
Лог.Информация("Вызвано событие <ПриПолученииТаблицыВерсий> для плагина <%1>", Имя());
diff --git a/features/cmd/step_definitions/v8path.os b/features/cmd/step_definitions/v8path.os
new file mode 100644
index 00000000..3d675627
--- /dev/null
+++ b/features/cmd/step_definitions/v8path.os
@@ -0,0 +1,45 @@
+#Использовать v8find
+// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
+
+Перем БДД; //контекст фреймворка 1bdd
+
+// Метод выдает список шагов, реализованных в данном файле-шагов
+Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
+ БДД = КонтекстФреймворкаBDD;
+
+ ВсеШаги = Новый Массив;
+
+ ВсеШаги.Добавить("ЯИщюПлатформуИСохранюНайденныйПуть");
+
+ Возврат ВсеШаги;
+КонецФункции
+
+// Реализация шагов
+
+// Процедура выполняется перед запуском каждого сценария
+Процедура ПередЗапускомСценария(Знач Узел) Экспорт
+
+КонецПроцедуры
+
+// Процедура выполняется после завершения каждого сценария
+Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
+
+КонецПроцедуры
+
+
+//Я ищю платформу и сохраню найденный путь "ПутьКПлатформе1С"
+Процедура ЯИщюПлатформуИСохранюНайденныйПуть(Знач ИмяПеременной) Экспорт
+
+ ПутьКПлатформе1С = Платформа1С.ПутьКПредприятию("8.3");
+
+ Если Не ЗначениеЗаполнено(ПутьКПлатформе1С) Тогда
+ ВызватьИсключение "Не найден путь к платформе 1С";
+ КонецЕсли;
+
+ БДД.СохранитьВКонтекст(ИмяПеременной, ПутьКПлатформе1С);
+
+КонецПроцедуры
+
+Функция ОбернутьВКавычки(Знач Строка);
+ Возврат """" + Строка + """";
+КонецФункции
\ No newline at end of file
diff --git a/features/cmd/v8path.feature b/features/cmd/v8path.feature
index 14870025..67eb83c3 100644
--- a/features/cmd/v8path.feature
+++ b/features/cmd/v8path.feature
@@ -13,19 +13,20 @@
И я скопировал каталог тестового хранилища конфигурации в каталог из переменной "КаталогХранилища1С"
И Я создаю временный каталог и сохраняю его в переменной "ПутьКаталогаИсходников"
И Я инициализирую репозиторий в каталоге из переменной "ПутьКаталогаИсходников"
+ И Я ищю платформу и сохраню найденный путь "ПутьКПлатформе1С"
И Я создаю тестовой файл AUTHORS
И Я записываю "0" в файл VERSION
Сценарий: Простая синхронизация хранилища с git-репозиторием
Допустим Я создаю временный каталог и сохраняю его в переменной "ВременнаяДиректория"
И Я добавляю параметр "--tempdir" для команды "gitsync" из переменной "ВременнаяДиректория"
- И Я добавляю параметр "--v8-path /opt/1C/v8.3/i386/1cv8" для команды "gitsync"
+ И Я добавляю параметр "--v8-path" для команды "gitsync" из переменной "ПутьКПлатформе1С"
И Я добавляю параметр "-v" для команды "gitsync"
И Я добавляю параметр "sync" для команды "gitsync"
И Я добавляю позиционный параметр для команды "gitsync" из переменной "КаталогХранилища1С"
И Я добавляю позиционный параметр для команды "gitsync" из переменной "ПутьКаталогаИсходников"
Когда Я выполняю команду "gitsync"
- Тогда Вывод команды "gitsync" содержит "ОТЛАДКА - Используется путь к платформе 1С "
+ Тогда Вывод команды "gitsync" содержит "ИНФОРМАЦИЯ - Используется путь к платформе 1С"
И Вывод команды "gitsync" содержит "ИНФОРМАЦИЯ - Завершена синхронизации с git"
И Вывод команды "gitsync" не содержит "Внешнее исключение"
И Код возврата команды "gitsync" равен 0
\ No newline at end of file
diff --git a/features/core/step_definitions/clone.os b/features/core/step_definitions/clone.os
index ed02201e..1503098b 100644
--- a/features/core/step_definitions/clone.os
+++ b/features/core/step_definitions/clone.os
@@ -2,7 +2,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
@@ -20,13 +20,13 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
@@ -36,7 +36,7 @@
ГитРепозиторий = БДД.ПолучитьИзКонтекста("ГитРепозиторий");
URLРепозитория = БДД.ПолучитьИзКонтекста(ПеременнаяURLРепозитория);
- ВременныйКаталог = ЛокальныеВременныеФайлы.СоздатьКаталог();
+ ВременныйКаталог = ВременныеФайлы.СоздатьКаталог();
ГитРепозиторий.УстановитьРабочийКаталог(ВременныйКаталог);
ГитРепозиторий.Инициализировать();
@@ -62,7 +62,7 @@
ГитРепозиторий.Отправить();
- ЛокальныеВременныеФайлы.БезопасноУдалитьФайл(ВременныйКаталог);
+ ВременныеФайлы.БезопасноУдалитьФайл(ВременныйКаталог);
КонецПроцедуры
diff --git a/features/core/step_definitions/init.os b/features/core/step_definitions/init.os
index 4ae473fb..153fea24 100644
--- a/features/core/step_definitions/init.os
+++ b/features/core/step_definitions/init.os
@@ -2,7 +2,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
БДД = КонтекстФреймворкаBDD;
@@ -20,13 +20,13 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
//Я инициализирую пустой репозиторий в каталог из переменной "ПутьКаталогаИсходников"
diff --git a/features/core/step_definitions/shared.os b/features/core/step_definitions/shared.os
index d5ada6ff..21cbc2e4 100644
--- a/features/core/step_definitions/shared.os
+++ b/features/core/step_definitions/shared.os
@@ -6,7 +6,7 @@
#Использовать "../../../src/core"
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
Перем Лог;
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
@@ -53,13 +53,13 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
//я устанавливаю в контексте признак статистики скриптов OneScript
@@ -104,7 +104,7 @@
//Я устанавливаю рабочей каталог во временный каталог
Процедура ЯУстанавливаюРабочейКаталогВоВременныйКаталог() Экспорт
- УстановитьТекущийКаталог(ЛокальныеВременныеФайлы.СоздатьКаталог());
+ УстановитьТекущийКаталог(ВременныеФайлы.СоздатьКаталог());
КонецПроцедуры
//Я создаю новый объект ГитРепозиторий
@@ -199,7 +199,6 @@
//Я устанавливаю путь выполнения команды "gitsync" к текущей библиотеке
Процедура ЯУстанавливаюПутьВыполненияКомандыКТекущейБиблиотеке(Знач ИмяКоманды) Экспорт
- ПодготовитьПриложениеКТестированию(КаталогГитсинк());
ПутьГитсинк = ОбъединитьПути(КаталогГитсинк(), "src", "cmd", "gitsync.os");
Команда = БДД.ПолучитьИзКонтекста(КлючКоманды(ИмяКоманды));
@@ -344,41 +343,7 @@
Возврат "Команда-" + ИмяКоманды;
КонецФункции
-Процедура ПодготовитьПриложениеКТестированию(Знач РабочийКаталог) Экспорт
-
- Лог.Отладка("Установка локальных зависимостей библиотек");
- КомандаOpm = Новый Команда;
- КомандаOpm.УстановитьРабочийКаталог(РабочийКаталог);
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("install -l");
-
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение КомандаOpm.ПолучитьВывод();
- КонецЕсли;
-
- Лог.Отладка("Настройка локальных библиотек");
-
- ПутьКФайлуЗагрузчику = ОбъединитьПути(РабочийКаталог, "oscript_modules", "package-loader.os");
- ШаблонныйФайлЗагрузчик = ОбъединитьПути(РабочийКаталог, "templates", "package-loader.os");
- ФайлЗагрузчик = Новый Файл(ПутьКФайлуЗагрузчику);
- Если Не ФайлЗагрузчик.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлЗагрузчик, ПутьКФайлуЗагрузчику);
- Лог.Информация("Добавлен файл загрузки локальных библиотек");
- КонецЕсли;
-
- ПутьКФайлуНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "src", "cmd", "oscript.cfg");
- ШаблонныйФайлНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "templates", "oscript.cfg");
- ФайлНастройкиСкрипта= Новый Файл(ПутьКФайлуНастройкиСкрипта);
- Если Не ФайлНастройкиСкрипта.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлНастройкиСкрипта, ПутьКФайлуНастройкиСкрипта);
- Лог.Информация("Добавлен файл настройки запуска");
- КонецЕсли;
-
-КонецПроцедуры
-ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
Лог = Логирование.ПолучитьЛог(ИмяЛога());
//Лог.УстановитьУровень(Логирование.ПолучитьЛог("bdd").Уровень());
diff --git a/features/core/step_definitions/sync.batch.os b/features/core/step_definitions/sync.batch.os
index e19cfa00..089d86c5 100644
--- a/features/core/step_definitions/sync.batch.os
+++ b/features/core/step_definitions/sync.batch.os
@@ -31,7 +31,7 @@
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ВременныеФайлы.Удалить();
+
КонецПроцедуры
diff --git a/features/core/step_definitions/sync.core.os b/features/core/step_definitions/sync.core.os
index fd9f3663..40b7e976 100644
--- a/features/core/step_definitions/sync.core.os
+++ b/features/core/step_definitions/sync.core.os
@@ -4,7 +4,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
БДД = КонтекстФреймворкаBDD;
@@ -12,7 +12,7 @@
ВсеШаги = Новый Массив;
ВсеШаги.Добавить("ЯСоздаюВременныйКаталогИСохраняюЕгоВПеременной");
- ВсеШаги.Добавить("ЯСоздаюНовыйУправлениеплагинами");
+ ВсеШаги.Добавить("ЯСоздаюНовыйМенеджерПлагинов");
ВсеШаги.Добавить("ЯСобираюТестовыйПлагинИСохраняюВКонтекст");
ВсеШаги.Добавить("ЯУстанавливаюФайлПлагинаИзПеременной");
ВсеШаги.Добавить("ЯЗагружаюПлагиныИзКаталогаВПеременной");
@@ -26,19 +26,19 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
//Я создаю временный каталог и сохраняю его в переменной "КаталогПлагинов"
Процедура ЯСоздаюВременныйКаталогИСохраняюЕгоВПеременной(Знач ИмяПеременной) Экспорт
- ВременныйКаталог = ЛокальныеВременныеФайлы.СоздатьКаталог();
+ ВременныйКаталог = ВременныеФайлы.СоздатьКаталог();
БДД.СохранитьВКонтекст(ИмяПеременной, ВременныйКаталог);
@@ -47,7 +47,7 @@
//Я собираю тестовый плагин и сохраняю в контекст "ПутьКФайлуПлагина"
Процедура ЯСобираюТестовыйПлагинИСохраняюВКонтекст(Знач ИмяПеременной) Экспорт
- ВременныйКаталог = ЛокальныеВременныеФайлы.СоздатьКаталог();
+ ВременныйКаталог = ВременныеФайлы.СоздатьКаталог();
ФС.КопироватьСодержимоеКаталога(КаталогТестовогоПлагина(), ВременныйКаталог);
@@ -78,32 +78,32 @@
КонецПроцедуры
-//Я создаю новый УправлениеПлагинами
-Процедура ЯСоздаюНовыйУправлениеплагинами() Экспорт
- УправлениеПлагинами = Новый УправлениеПлагинами;
+//Я создаю новый МенеджерПлагинов
+Процедура ЯСоздаюНовыйМенеджерПлагинов() Экспорт
+ МенеджерПлагинов = Новый МенеджерПлагинов;
- БДД.СохранитьВКонтекст("УправлениеПлагинами", УправлениеПлагинами);
+ БДД.СохранитьВКонтекст("МенеджерПлагинов", МенеджерПлагинов);
КонецПроцедуры
//Я загружаю плагины из каталога в переменной "КаталогПлагинов"
Процедура ЯЗагружаюПлагиныИзКаталогаВПеременной(Знач ИмяПеременнойКаталога) Экспорт
- УправлениеПлагинами = БДД.ПолучитьИзКонтекста("УправлениеПлагинами");
+ МенеджерПлагинов = БДД.ПолучитьИзКонтекста("МенеджерПлагинов");
КаталогПлагинов = БДД.ПолучитьИзКонтекста(ИмяПеременнойКаталога);
- УправлениеПлагинами.УстановитьКаталогПлагинов(КаталогПлагинов);
- УправлениеПлагинами.ЗагрузитьПлагины();
+ МенеджерПлагинов.УстановитьКаталогПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.ЗагрузитьПлагины();
- УправлениеПлагинами.ВключитьПлагин("test_plugin");
+ МенеджерПлагинов.ВключитьПлагин("test_plugin");
КонецПроцедуры
//Я подключаю плагины в МенеджерСинхронизации
Процедура ЯПодключаюПлагиныВМенеджерсинхронизации() Экспорт
- УправлениеПлагинами = БДД.ПолучитьИзКонтекста("УправлениеПлагинами");
+ МенеджерПлагинов = БДД.ПолучитьИзКонтекста("МенеджерПлагинов");
- ИндексПлагинов = УправлениеПлагинами.ПолучитьИндексПлагинов();
+ ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
МенеджерСинхронизации = БДД.ПолучитьИзКонтекста("МенеджерСинхронизации");
МенеджерСинхронизации.ПодпискиНаСобытия(ИндексПлагинов);
@@ -116,9 +116,9 @@
КаталогПлагинов = БДД.ПолучитьИзКонтекста("КаталогПлагинов");
ФайлПлагина = БДД.ПолучитьИзКонтекста(ПутьКФайлуПлагина);
- УправлениеПлагинами = БДД.ПолучитьИзКонтекста("УправлениеПлагинами");
- УправлениеПлагинами.УстановитьКаталогПлагинов(КаталогПлагинов);
- УправлениеПлагинами.УстановитьФайлПлагин(ФайлПлагина);
+ МенеджерПлагинов = БДД.ПолучитьИзКонтекста("МенеджерПлагинов");
+ МенеджерПлагинов.УстановитьКаталогПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.УстановитьФайлПлагин(ФайлПлагина);
КонецПроцедуры
@@ -127,4 +127,4 @@
Возврат ОбъединитьПути(ТекущийСценарий().Каталог, "testsata", "test_plugin");
КонецФункции
-ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
diff --git a/features/core/step_definitions/sync.os b/features/core/step_definitions/sync.os
index 3a99892e..1aa3b993 100644
--- a/features/core/step_definitions/sync.os
+++ b/features/core/step_definitions/sync.os
@@ -1,7 +1,7 @@
// Реализация шагов BDD-фич/сценариев c помощью фреймворка https://github.com/artbear/1bdd
Перем БДД; //контекст фреймворка 1bdd
-Перем ЛокальныеВременныеФайлы;
+
// Метод выдает список шагов, реализованных в данном файле-шагов
Функция ПолучитьСписокШагов(КонтекстФреймворкаBDD) Экспорт
@@ -17,12 +17,12 @@
// Процедура выполняется перед запуском каждого сценария
Процедура ПередЗапускомСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы = Новый МенеджерВременныхФайлов;
+
КонецПроцедуры
// Процедура выполняется после завершения каждого сценария
Процедура ПослеЗапускаСценария(Знач Узел) Экспорт
- ЛокальныеВременныеФайлы.Удалить();
+
КонецПроцедуры
diff --git a/features/core/sync.batch.feature b/features/core/sync.batch.feature
index 7e4bd981..ee5f703b 100644
--- a/features/core/sync.batch.feature
+++ b/features/core/sync.batch.feature
@@ -91,7 +91,7 @@ repositories:
# Допустим Я устанавливаю авторизацию в хранилище пользователя "Администратор" с паролем ""
# И Я устанавливаю версию платформы "8.3"
# И Я создаю временный каталог и сохраняю его в переменной "КаталогПлагинов"
-# И Я создаю новый УправлениеПлагинами
+# И Я создаю новый МенеджерПлагинов
# И Я собираю тестовый плагин и сохраняю в контекст "ПутьКФайлуПлагина"
# И Я устанавливаю файл плагина из переменной "ПутьКФайлуПлагина"
# И Я загружаю плагины из каталога в переменной "КаталогПлагинов"
diff --git a/features/core/sync.core.feature b/features/core/sync.core.feature
index d2b1deb9..c2546b2f 100644
--- a/features/core/sync.core.feature
+++ b/features/core/sync.core.feature
@@ -27,7 +27,7 @@
Допустим Я устанавливаю авторизацию в хранилище пользователя "Администратор" с паролем ""
И Я устанавливаю версию платформы "8.3"
И Я создаю временный каталог и сохраняю его в переменной "КаталогПлагинов"
- И Я создаю новый УправлениеПлагинами
+ И Я создаю новый МенеджерПлагинов
И Я собираю тестовый плагин и сохраняю в контекст "ПутьКФайлуПлагина"
И Я устанавливаю файл плагина из переменной "ПутьКФайлуПлагина"
И Я загружаю плагины из каталога в переменной "КаталогПлагинов"
diff --git a/package-loader.os b/package-loader.os
deleted file mode 100644
index d9e4f5b4..00000000
--- a/package-loader.os
+++ /dev/null
@@ -1,8 +0,0 @@
-
-#Использовать "src/core"
-
-Процедура ПриЗагрузкеБиблиотеки(Путь, СтандартнаяОбработка, Отказ)
-
- СтандартнаяОбработка = Ложь;
-
-КонецПроцедуры
diff --git a/packagedef b/packagedef
index 2ac7b97f..ba2eac7b 100644
--- a/packagedef
+++ b/packagedef
@@ -1,101 +1,28 @@
-#Использовать logos
-#Использовать fs
-Перем Лог;
-
-Процедура ПередСборкой(Знач РабочийКаталог) Экспорт
-
- ФС.ОбеспечитьПустойКаталог(ОбъединитьПути(РабочийКаталог, "oscript_modules"));
-
- Лог.Информация("Установка локальных зависимостей библиотек");
- КомандаOpm = Новый Команда;
-
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("install -l");
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.build");
-
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение КомандаOpm.ПолучитьВывод();
- КонецЕсли;
-
- Лог.Информация("Настройка локальных библиотек");
-
- ПутьКФайлуЗагрузчику = ОбъединитьПути(РабочийКаталог, "oscript_modules", "package-loader.os");
- ШаблонныйФайлЗагрузчик = ОбъединитьПути(РабочийКаталог, "templates", "package-loader.os");
- ФайлЗагрузчик = Новый Файл(ПутьКФайлуЗагрузчику);
- Если Не ФайлЗагрузчик.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлЗагрузчик, ПутьКФайлуЗагрузчику);
- Лог.Информация("Добавлен файл загрузки локальных библиотек");
- КонецЕсли;
-
- ПутьКФайлуНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "src", "cmd", "oscript.cfg");
- ШаблонныйФайлНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "templates", "oscript.cfg");
- ФайлНастройкиСкрипта= Новый Файл(ПутьКФайлуНастройкиСкрипта);
- Если Не ФайлНастройкиСкрипта.Существует() Тогда
- КопироватьФайл(ШаблонныйФайлНастройкиСкрипта, ПутьКФайлуНастройкиСкрипта);
- Лог.Информация("Добавлен файл настройки запуска");
- КонецЕсли;
-
- ФС.ОбеспечитьПустойКаталог(ОбъединитьПути(РабочийКаталог, "embedded_plugins"));
-
- КомандаOpm = Новый Команда;
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("run get-plugins");
-
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение КомандаOpm.ПолучитьВывод();
- КонецЕсли;
-
- Лог.Информация("Настройка локальных библиотек - завершена");
-
-КонецПроцедуры
-
-Процедура ПослеСборки(Знач РабочийКаталог, Знач ПутьКФайлуПакета) Экспорт
-
- ПутьКФайлуНастройкиСкрипта = ОбъединитьПути(РабочийКаталог, "src", "cmd", "oscript.cfg");
- ФайлНастройкиСкрипта= Новый Файл(ПутьКФайлуНастройкиСкрипта);
- Если ФайлНастройкиСкрипта.Существует() Тогда
- УдалитьФайлы(ПутьКФайлуНастройкиСкрипта);
- КонецЕсли;
-
- ФС.ОбеспечитьПустойКаталог(ОбъединитьПути(РабочийКаталог, "oscript_modules"));
-
-КонецПроцедуры
-
-Лог = Логирование.ПолучитьЛог("task.build");
-
-ПутьКСценариюПараметров = ОбъединитьПути(ТекущийСценарий().Каталог, "src/cmd", "Модули", "ПараметрыПриложения.os");
-ПараметрыСистемы_ЛокальнаяВерсия = ЗагрузитьСценарий(ПутьКСценариюПараметров);
-ИмяПродукта = НРег(ПараметрыСистемы_ЛокальнаяВерсия.ИмяПриложения());
-ВерсияПродукта = ПараметрыСистемы_ЛокальнаяВерсия.Версия();
-
-Описание.Имя(ИмяПродукта)
- .Версия(ВерсияПродукта)
- .ВерсияСреды("1.0.20")
+Описание.Имя("gitsync")
+ .Версия("3.0.0-rc.2")
+ .ВерсияСреды("1.0.21")
.ЗависитОт("logos", "1.2.0")
.ЗависитОт("tempfiles", "0.2.2")
- .ЗависитОт("v8runner", "1.1.3")
+ .ЗависитОт("v8runner", "1.3.0")
.ЗависитОт("gitrunner", "1.2.0")
.ЗависитОт("strings", "0.4.1")
.ЗависитОт("1commands", "1.3.4")
.ЗависитОт("json", "1.0.1")
.ЗависитОт("fs", "0.4.1")
.ЗависитОт("delegate", "0.2.0")
- .ЗависитОт("v8storage", "0.7.0")
+ .ЗависитОт("v8storage", "0.8.0")
.ЗависитОт("reflector", "0.4.0")
.ЗависитОт("opm", "0.15.3")
.ЗависитОт("cli", "0.9.10")
- .ЗависитОт("configor", "0.5.3")
+ .ЗависитОт("configor", "0.6.3")
.ВключитьФайл("src")
.ВключитьФайл("docs")
.ВключитьФайл("embedded_plugins")
.ВключитьФайл("oscript_modules")
.ВключитьФайл("readme.md")
.ВключитьФайл("templates/temp.cfe")
+ .ОпределяетКласс("МенеджерПлагинов", "src/core/Классы/МенеджерПлагинов.os")
.ОпределяетКласс("МенеджерСинхронизации", "src/core/Классы/МенеджерСинхронизации.os")
- .ОпределяетКласс("УправлениеПлагинами", "src/core/Классы/УправлениеПлагинами.os")
- .ИсполняемыйФайл("src/cmd/gitsync.os", ИмяПродукта);
+ .ОпределяетКласс("ПакетнаяСинхронизация", "src/core/Классы/ПакетнаяСинхронизация.os")
+ .ИсполняемыйФайл("src/cmd/gitsync.os");
diff --git a/readme.md b/readme.md
index 646d0e12..e7b688d5 100644
--- a/readme.md
+++ b/readme.md
@@ -14,6 +14,7 @@
- [Установка](#установка)
- [Вручную](#вручную)
- [Через пакетный менеджер opm](#через-пакетный-менеджер-opm)
+- [Требования](#требования)
- [Особенности](#особенности)
- [Отличия от `gitsync` версий 2.x](#отличия-от-gitsync-версий-2x)
- [Описание функциональности](#описание-функциональности)
@@ -70,9 +71,15 @@ $ opm install -f <ПутьКФайлу>
1. командой `opm install gitsync`
2. Запустить командой `gitsync`
+
+## Требования
+
+* утилита `ring` и `` - для работы с 1С старше версии > 8.3.11
+
## Особенности
+
### Отличия от `gitsync` версий 2.x
diff --git a/src/cmd/gitsync.os b/src/cmd/gitsync.os
index 98a961a5..bc4e859d 100644
--- a/src/cmd/gitsync.os
+++ b/src/cmd/gitsync.os
@@ -27,19 +27,31 @@
Приложение.Опция("v verbose", Ложь, "вывод отладочной информация в процессе выполнении")
.Флаговый()
.ВОкружении("GITSYNC_VERBOSE");
-
+
+ Приложение.Опция("U ib-user ib-usr", "", "пользователь информационной базы")
+ .ТСтрока()
+ .ВОкружении("GITSYNC_IB_USR GITSYNC_IB_USER");
+
+ Приложение.Опция("P ib-pwd", "", "пароль пользователя информационной базы")
+ .ТСтрока()
+ .ВОкружении("GITSYNC_IB_PASSWORD GITSYNC_IB_PWD");
+
+ Приложение.Опция("C ib-connection ibconnection", "", "путь подключения к информационной базе")
+ .ТСтрока()
+ .ВОкружении("GITSYNC_IB_CONNECTION GITSYNC_IBCONNECTION");
+
// Приложение.Опция("p plugins", "", "плагины к загрузке и исполнению (дополнительное ограничение)")
// .ТМассивСтрок()
// .ВОкружении("GITSYNC_RUN_PLUGINS");
Приложение.Опция("t tempdir", "", "путь к каталогу временных файлов")
- .ВОкружении("GITSYNC_TEMP");
+ .ВОкружении("GITSYNC_TEMP GITSYNC_TEMPDIR");
Приложение.Опция("git-path", "", "путь к исполняемому файлу git")
.ВОкружении("GITSYNC_GIT_PATH GIT_PATH");
Приложение.Опция("domain-email", "localhost", "домен почты для пользователей git")
- .ВОкружении("GITSYNC_EMAIL");
+ .ВОкружении("GITSYNC_EMAIL GITSYNC_DOMAIN_EMAIL");
Приложение.ДобавитьКоманду("usage u", "Выводит примеры использования",
Новый КомандаUsage);
diff --git "a/src/cmd/\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\260All.os" "b/src/cmd/\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\260All.os"
index 05959f55..ae70b108 100644
--- "a/src/cmd/\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\260All.os"
+++ "b/src/cmd/\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\260All.os"
@@ -1,4 +1,5 @@
-
+#Использовать configor
+
Перем Лог;
Процедура ОписаниеКоманды(Команда) Экспорт
@@ -7,10 +8,16 @@
.ТЧисло()
.ВОкружении("GITSYNC_ALL_TIMER");
+ Команда.Опция("thread", 1, "количество потоков выполнения")
+ .ТЧисло()
+ .ВОкружении("GITSYNC_ALL_THREAD");
+
+ Команда.Опция("n name", "", "имя настройки пакетной синхронизации")
+ .ТСтрока();
+
Команда.Опция("u storage-user", "", "пользователь хранилища конфигурации")
.ТСтрока()
- .ВОкружении("GITSYNC_STORAGE_USER")
- .ПоУмолчанию("Администратор");
+ .ВОкружении("GITSYNC_STORAGE_USER");
Команда.Опция("p storage-pwd", "", "пароль пользователя хранилища конфигурации")
.ТСтрока()
@@ -34,32 +41,77 @@
ПользовательХранилища = Команда.ЗначениеОпции("storage-user");
ПарольПользователяХранилища = Команда.ЗначениеОпции("storage-pwd");
-
+
+ ИмяНастройкиСинхронизации = Команда.ЗначениеОпции("name");
+ КоличествоПотоковСинхронизации = Команда.ЗначениеОпции("thread");
+
ИнтервалПовторенияСинхронизации = Команда.ЗначениеОпции("timer");
ФайлНастроек = Новый Файл(ПутьКФайлуНастроек);
Если Не ФайлНастроек.Существует() Тогда
- ВызватьИсключение Новый ИнформацияОбОшибке(СтрШаблон("Файл настроек <%1> не найден", ФайлНастроек.ПолноеИмя), "Работа приложения остановлена");
+ ВызватьИсключение СтрШаблон("Файл настроек <%1> не найден", ФайлНастроек.ПолноеИмя);
КонецЕсли;
ОбщиеПараметры = ПараметрыПриложения.Параметры();
+ ПараметрыФайлаНастроек = ПрочитатьФайлНастроек(ПутьКФайлуНастроек);
+
+ Если ПараметрыФайлаНастроек.Количество() = 0 Тогда
+ ВызватьИсключение "Файл настроек не содержит данных";
+ КонецЕсли;
+
ПакетнаяСинхронизация = Новый ПакетнаяСинхронизация();
- ПакетнаяСинхронизация.УстановитьНастройки(ФайлНастроек);
- ПакетнаяСинхронизация.ТаймерПовторения(ИнтервалПовторенияСинхронизации)
+ ПакетнаяСинхронизация
+ .ТаймерПовторения(ИнтервалПовторенияСинхронизации)
.КаталогПлагинов(ПараметрыПриложения.КаталогПлагинов())
- .ФайлВключенныхПлагинов(ПараметрыПриложения.ФайлВключенныхПлагинов())
.ВерсияПлатформы(ОбщиеПараметры.ВерсияПлатформы)
.ДоменПочтыПоУмолчанию(ОбщиеПараметры.ДоменПочты)
.ИсполняемыйФайлГит(ОбщиеПараметры.ПутьКГит)
- .УровеньЛога(ПараметрыПриложения.УровеньЛога())
- .РежимУдаленияВременныхФайлов(Истина)
- .АвторизацияВХранилищеКонфигурации(ПользовательХранилища, ПарольПользователяХранилища);
-
- ПакетнаяСинхронизация.ВыполнитьСинхронизацию();
+ .ПутьКПлатформе(ОбщиеПараметры.ПутьКПлатформе)
+ .РежимУдаленияВременныхФайлов(Истина)
+ .АвторизацияВХранилищеКонфигурации(ПользовательХранилища, ПарольПользователяХранилища)
+ ;
+
+ ПакетнаяСинхронизация.ПрочитатьНастройки(ПараметрыФайлаНастроек);
+
+ Если ЗначениеЗаполнено(ИмяНастройкиСинхронизации) Тогда
+ ПакетнаяСинхронизация.ВыполнитьСинхронизациюПоНастройке(ИмяНастройкиСинхронизации);
+ Иначе
+ ПакетнаяСинхронизация.ВыполнитьСинхронизацию(КоличествоПотоковСинхронизации);
+ КонецЕсли;
Лог.Информация("Завершено выполнение команды ");
КонецПроцедуры
+Функция ПрочитатьФайлНастроек(Знач ПутьКФайлуНастроек)
+
+ Лог.Отладка("Чтение файла настроек начато");
+
+ ТекстФайла = РаботаСФайлами.ПрочитатьФайл(ПутьКФайлуНастроек);
+
+ Лог.Отладка("Чтение файла настроек завершено");
+
+ ПрочитанныйПараметры = РаботаСФайлами.ОбъектИзJson(ТекстФайла);
+
+ ЭтоОдинРепозиторий = ПрочитанныйПараметры.Получить("repositories") = Неопределено
+ И ПрочитанныйПараметры.Получить("Репозитории") = Неопределено;
+
+ Параметры = ПрочитанныйПараметры;
+
+ Если ЭтоОдинРепозиторий Тогда
+
+ Параметры = Новый Соответствие();
+ МассивРепозиториев = Новый Массив;
+ МассивРепозиториев.Добавить(ПрочитанныйПараметры);
+
+ Параметры.Вставить("repositories", МассивРепозиториев);
+
+ КонецЕсли;
+
+ Возврат Параметры;
+
+КонецФункции
+
+
Лог = ПараметрыПриложения.Лог();
\ No newline at end of file
diff --git "a/src/cmd/\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\260Clone.os" "b/src/cmd/\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\260Clone.os"
index 3ebe9b56..312ceadb 100644
--- "a/src/cmd/\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\260Clone.os"
+++ "b/src/cmd/\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\260Clone.os"
@@ -9,6 +9,10 @@
Команда.Опция("p storage-pwd", "", "пароль пользователя хранилища конфигурации")
.ТСтрока()
.ВОкружении("GITSYNC_STORAGE_PASSWORD GITSYNC_STORAGE_PWD");
+
+ Команда.Опция("e ext extension", "", "имя расширения для работы с хранилищем расширения")
+ .ТСтрока()
+ .ВОкружении("GITSYNC_EXTENSION");
Команда.Аргумент("PATH", "", "Путь к хранилищу конфигурации 1С.")
.ТСтрока()
@@ -32,8 +36,13 @@
КаталогРабочейКопии = Команда.ЗначениеАргумента("WORKDIR");
URLРепозитория = Команда.ЗначениеАргумента("URL");
- ПользовательХранилища = Команда.ЗначениеОпции("--storage-user");
- ПарольПользователяХранилища = Команда.ЗначениеОпции("--storage-pwd");
+ ПользовательХранилища = Команда.ЗначениеОпции("storage-user");
+ ПарольПользователяХранилища = Команда.ЗначениеОпции("storage-pwd");
+ ИмяРасширения = Команда.ЗначениеОпции("extension");
+
+ ПользовательИБ = Команда.ЗначениеОпции("ib-user");
+ ПарольПользователяИБ = Команда.ЗначениеОпции("ib-pwd");
+ СтрокаСоединенияИБ = Команда.ЗначениеОпции("ib-connection");
Лог.Отладка("КаталогРабочейКопии: %1", КаталогРабочейКопии);
@@ -52,7 +61,7 @@
КонецЕсли;
ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
@@ -61,6 +70,8 @@
.ПутьКПлатформе(ОбщиеПараметры.ПутьКПлатформе)
.ДоменПочтыПоУмолчанию(ОбщиеПараметры.ДоменПочты)
.ИсполняемыйФайлГит(ОбщиеПараметры.ПутьКГит)
+ .УстановитьКонтекст(СтрокаСоединенияИБ, ПользовательИБ, ПарольПользователяИБ)
+ .ИмяРасширения(ИмяРасширения)
.ПодпискиНаСобытия(ИндексПлагинов)
.ПараметрыПодписокНаСобытия(Команда.ПараметрыКоманды())
.УровеньЛога(ПараметрыПриложения.УровеньЛога())
diff --git "a/src/cmd/\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\260Init.os" "b/src/cmd/\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\260Init.os"
index 9dd884e7..bde6d66b 100644
--- "a/src/cmd/\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\260Init.os"
+++ "b/src/cmd/\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\260Init.os"
@@ -35,10 +35,14 @@
ПутьКХранилищу = Команда.ЗначениеАргумента("PATH");
КаталогРабочейКопии = Команда.ЗначениеАргумента("WORKDIR");
- ПользовательХранилища = Команда.ЗначениеОпции("--storage-user");
- ПарольПользователяХранилища = Команда.ЗначениеОпции("--storage-pwd");
+ ПользовательХранилища = Команда.ЗначениеОпции("storage-user");
+ ПарольПользователяХранилища = Команда.ЗначениеОпции("storage-pwd");
ИмяРасширения = Команда.ЗначениеОпции("extension");
+ ПользовательИБ = Команда.ЗначениеОпции("ib-user");
+ ПарольПользователяИБ = Команда.ЗначениеОпции("ib-pwd");
+ СтрокаСоединенияИБ = Команда.ЗначениеОпции("ib-connection");
+
// инициализировать с нуля
ФайлКаталогРабочейКопии = Новый Файл(КаталогРабочейКопии);
Если Не ФайлКаталогРабочейКопии.Существует() Тогда
@@ -59,7 +63,7 @@
КонецЕсли;
ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
@@ -68,6 +72,7 @@
.ПутьКПлатформе(ОбщиеПараметры.ПутьКПлатформе)
.ДоменПочтыПоУмолчанию(ОбщиеПараметры.ДоменПочты)
.ИсполняемыйФайлГит(ОбщиеПараметры.ПутьКГит)
+ .УстановитьКонтекст(СтрокаСоединенияИБ, ПользовательИБ, ПарольПользователяИБ)
.ПодпискиНаСобытия(ИндексПлагинов)
.ПараметрыПодписокНаСобытия(Команда.ПараметрыКоманды())
.ИмяРасширения(ИмяРасширения)
diff --git "a/src/cmd/\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\260PluginDisable.os" "b/src/cmd/\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\260PluginDisable.os"
index 1f10d9c1..a0c9872e 100644
--- "a/src/cmd/\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\260PluginDisable.os"
+++ "b/src/cmd/\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\260PluginDisable.os"
@@ -17,27 +17,17 @@
ИменаПлагинов = Команда.ЗначениеАргумента("PLUGIN");
ВсеВключенные = Команда.ЗначениеОпции("all");
- ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
-
- ВсеПлагины = МенеджерПлагинов.ПолучитьИндексПлагинов();
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
Лог = ПараметрыПриложения.Лог();
Лог.Отладка("Отключение всех плагинов <%1>", ВсеВключенные);
- ПлагиныДляОтключения = Новый Массив;
-
Если ВсеВключенные Тогда
- Для каждого Плагин Из ВсеПлагины Цикл
- Лог.Отладка(" --> отключаю плагин <%1>", Плагин.Ключ);
- ПлагиныДляОтключения.Добавить(Плагин.Ключ);
- КонецЦикла;
+ МенеджерПлагинов.ОтключитьВсеПлагины();
Иначе
- ПлагиныДляОтключения = ИменаПлагинов;
+ МенеджерПлагинов.ОтключитьПлагины(ИменаПлагинов);
КонецЕсли;
- МенеджерПлагинов.ОтключитьПлагины(ПлагиныДляОтключения);
-
- МенеджерПлагинов.ЗаписатьВключенныеПлагины();
+ ПараметрыПриложения.ЗаписатьВключенныеПлагины();
КонецПроцедуры
diff --git "a/src/cmd/\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\260PluginEnable.os" "b/src/cmd/\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\260PluginEnable.os"
index b89d503b..5be60ffa 100644
--- "a/src/cmd/\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\260PluginEnable.os"
+++ "b/src/cmd/\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\260PluginEnable.os"
@@ -19,19 +19,14 @@
ИменаПлагинов = Команда.ЗначениеАргумента("PLUGIN");
ВсеУстановленные = Команда.ЗначениеОпции("all");
- ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
- ВсеПлагины = МенеджерПлагинов.ПолучитьИндексПлагинов();
-
Если ВсеУстановленные Тогда
+ МенеджерПлагинов.ВключитьВсеПлагины();
+ Иначе
- Для каждого Плагин Из ВсеПлагины Цикл
- МенеджерПлагинов.ВключитьПлагин(Плагин.Ключ);
- КонецЦикла;
+ ВсеПлагины = МенеджерПлагинов.ПолучитьИндексПлагинов();
- Иначе
-
Для каждого Плагин Из ИменаПлагинов Цикл
ИмяПлагина = СокрЛ(Плагин);
@@ -42,7 +37,7 @@
Продолжить;
КонецЕсли;
- МенеджерПлагинов.ВключитьПлагин(ИмяПлагина);
+ НашлиПлагин.Включить();
Сообщить("Включен плагин: "+ ИмяПлагина);
@@ -50,7 +45,7 @@
КонецЕсли;
- МенеджерПлагинов.ЗаписатьВключенныеПлагины();
+ ПараметрыПриложения.ЗаписатьВключенныеПлагины();
КонецПроцедуры
diff --git "a/src/cmd/\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\260PluginInstall.os" "b/src/cmd/\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\260PluginInstall.os"
index ff4b90c2..b607b9be 100644
--- "a/src/cmd/\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\260PluginInstall.os"
+++ "b/src/cmd/\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\260PluginInstall.os"
@@ -29,8 +29,7 @@
ПакетыКУстановке = Команда.ЗначениеАргумента("NAME");
МассивФайловПлагинов = Команда.ЗначениеОпции("file");
- ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
Для каждого ПутьКПлагину Из МассивФайловПлагинов Цикл
diff --git "a/src/cmd/\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\260PluginList.os" "b/src/cmd/\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\260PluginList.os"
index edfdae9d..e94ea93d 100644
--- "a/src/cmd/\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\260PluginList.os"
+++ "b/src/cmd/\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\260PluginList.os"
@@ -13,38 +13,34 @@
Процедура ВыполнитьКоманду(Знач Команда) Экспорт
- ВывестиВсеПлагины = Команда.ЗначениеОпции("-a");
- ВыводТолькоНазваний = Команда.ЗначениеОпции("-q");
+ ВывестиВсеПлагины = Команда.ЗначениеОпции("all");
+ ВыводТолькоНазваний = Команда.ЗначениеОпции("quiet");
- ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
-
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
ВсеПлагины = МенеджерПлагинов.ПолучитьИндексПлагинов();
- ВключенныеПлагины = МенеджерПлагинов.ПрочитатьВключенныеПлагины();
-
+
Если НЕ ВыводТолькоНазваний Тогда
Сообщить(СтрШаблон("Каталог плагинов: <%1>", ПараметрыПриложения.КаталогПлагинов()));
Сообщить("Список плагинов: ");
КонецЕсли;
- Для каждого Плагин Из ВсеПлагины Цикл
+ Для каждого КлючЗначение Из ВсеПлагины Цикл
- ВключенныйПлагин = ВключенныеПлагины[Плагин.Ключ];
+ Плагин = КлючЗначение.Значение;
- Если ВключенныйПлагин = Неопределено
- И НЕ ВывестиВсеПлагины Тогда
- Продолжить;
+ Если НЕ ВывестиВсеПлагины Тогда
+ Если НЕ Плагин.Включен() Тогда
+ Продолжить;
+ КонецЕсли;
КонецЕсли;
- КлассПлагина = Плагин.Значение;
-
Если ВыводТолькоНазваний Тогда
-
- Сообщить(КлассПлагина.Имя());
+
+ Сообщить(Плагин.Имя());
Иначе
- ВывестиОписаниеПлагина(КлассПлагина);
+ ВывестиОписаниеПлагина(Плагин);
КонецЕсли;
@@ -54,9 +50,10 @@
Процедура ВывестиОписаниеПлагина(КлассПлагина);
- ШаблонНаименования = " %1 (версия: %3) "+ Символы.Таб + "%2";
+ ШаблонНаименования = " %4 %1 [%3] " + Символы.Таб + "%2";
+ ТекстВключен = ?(КлассПлагина.Включен(), "[on] ", "[off]");
- Сообщить(СтрШаблон(ШаблонНаименования, КлассПлагина.Имя(), КлассПлагина.Описание(), КлассПлагина.Версия()));
+ Сообщить(СтрШаблон(ШаблонНаименования, КлассПлагина.Имя(), КлассПлагина.Описание(), КлассПлагина.Версия(), ТекстВключен));
КонецПроцедуры
diff --git "a/src/cmd/\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\260PluginsInit.os" "b/src/cmd/\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\260PluginsInit.os"
index 33f2830d..724e1d39 100644
--- "a/src/cmd/\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\260PluginsInit.os"
+++ "b/src/cmd/\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\260PluginsInit.os"
@@ -16,9 +16,9 @@
МассивФайловПлагинов = НайтиФайлы(КаталогВстроенныхПлагинов, "*.ospx");
ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
- Лог.Информация("Начала инициализация предустановленных плагинов");
+ Лог.Информация("Начата инициализация предустановленных плагинов");
Лог.Отладка("Каталог поиска предустановленных плагинов: <%1>", КаталогВстроенныхПлагинов);
Лог.Отладка("Количество пакетов плагинов к установке: <%1>", МассивФайловПлагинов.Количество());
diff --git "a/src/cmd/\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\260SetVersion.os" "b/src/cmd/\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\260SetVersion.os"
index 10867197..e8456901 100644
--- "a/src/cmd/\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\260SetVersion.os"
+++ "b/src/cmd/\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\260SetVersion.os"
@@ -24,7 +24,7 @@
ВызватьКоммит = Команда.ЗначениеОпции("commit");
ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
diff --git "a/src/cmd/\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\260Sync.os" "b/src/cmd/\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\260Sync.os"
index e53d6dfe..2f624e43 100644
--- "a/src/cmd/\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\260Sync.os"
+++ "b/src/cmd/\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\260Sync.os"
@@ -36,10 +36,14 @@
ПутьКХранилищу = Команда.ЗначениеАргумента("PATH");
КаталогРабочейКопии = Команда.ЗначениеАргумента("WORKDIR");
- ПользовательХранилища = Команда.ЗначениеОпции("--storage-user");
- ПарольПользователяХранилища = Команда.ЗначениеОпции("--storage-pwd");
+ ПользовательХранилища = Команда.ЗначениеОпции("storage-user");
+ ПарольПользователяХранилища = Команда.ЗначениеОпции("storage-pwd");
ИмяРасширения = Команда.ЗначениеОпции("extension");
+ ПользовательИБ = Команда.ЗначениеОпции("ib-user");
+ ПарольПользователяИБ = Команда.ЗначениеОпции("ib-pwd");
+ СтрокаСоединенияИБ = Команда.ЗначениеОпции("ib-connection");
+
ФайлКаталогРабочейКопии = Новый Файл(КаталогРабочейКопии);
КаталогРабочейКопии = ФайлКаталогРабочейКопии.ПолноеИмя;
@@ -53,7 +57,7 @@
КонецЕсли;
ОбщиеПараметры = ПараметрыПриложения.Параметры();
- МенеджерПлагинов = ОбщиеПараметры.УправлениеПлагинами;
+ МенеджерПлагинов = ПараметрыПриложения.МенеджерПлагинов();
ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
@@ -62,13 +66,13 @@
.ПутьКПлатформе(ОбщиеПараметры.ПутьКПлатформе)
.ДоменПочтыПоУмолчанию(ОбщиеПараметры.ДоменПочты)
.ИсполняемыйФайлГит(ОбщиеПараметры.ПутьКГит)
+ .УстановитьКонтекст(СтрокаСоединенияИБ, ПользовательИБ, ПарольПользователяИБ)
.ПодпискиНаСобытия(ИндексПлагинов)
.ПараметрыПодписокНаСобытия(Команда.ПараметрыКоманды())
.УровеньЛога(ПараметрыПриложения.УровеньЛога())
.ИмяРасширения(ИмяРасширения)
.АвторизацияВХранилищеКонфигурации(ПользовательХранилища, ПарольПользователяХранилища)
.РежимУдаленияВременныхФайлов(Истина)
- .РежимРаботыСХранилищемРасширения(ОбщиеПараметры.ЭтоРасширение)
.Синхронизировать(КаталогИсходников, ПутьКХранилищу);
Лог.Информация("Завершено выполнение команды ");
diff --git "a/src/cmd/\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\260Usage.os" "b/src/cmd/\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\260Usage.os"
index 054bb432..3e18eefd 100644
--- "a/src/cmd/\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\260Usage.os"
+++ "b/src/cmd/\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\260Usage.os"
@@ -1,3 +1,5 @@
+#Использовать "../../core/Классы/internal/bindata"
+
Перем ЭтоWindows;
Перем ИмяКомандыGitsync;
@@ -8,22 +10,11 @@
Команда.Аргумент("COMMAND", "", "Команда для вывода подробностей использования").ТСтрока().Обязательный(Ложь);
- //Команда.УстановитьДействиеПередВыполнением(ПараметрыПриложения);
- //Команда.УстановитьДействиеПослеВыполнения(ПараметрыПриложения);
-
КонецПроцедуры
Процедура ВыполнитьКоманду(Знач Команда) Экспорт
- Если ПараметрыПриложения.ЭтоСборкаEXE() Тогда
-
- Лог.Информация("Команда для собранного приложения в exe не доступна");
-
- Возврат;
-
- КонецЕсли;
-
- ИмяКоманды = Команда.ЗначениеАргумента("COMMAND");
+ ИмяКоманды = Команда.ЗначениеАргумента("COMMAND");
Если ПустаяСтрока(ИмяКоманды) Тогда
ВывестиОбщееИспользование();
@@ -101,26 +92,29 @@
Процедура ВывестиИспользованиеКоманды(Знач ИмяКоманды)
+ ИмяКомандыСправки = "";
+
Если ИмяКоманды = "init"
или ИмяКоманды = "i" Тогда
- ВывестиИспользованиеInit();
+ ИмяКомандыСправки = "init";
ИначеЕсли ИмяКоманды = "clone"
или ИмяКоманды = "c" Тогда
- ВывестиИспользованиеClone();
+ ИмяКомандыСправки = "clone";
ИначеЕсли ИмяКоманды = "sync"
или ИмяКоманды = "s" Тогда
- ВывестиИспользованиеSync();
+ ИмяКомандыСправки = "sync";
ИначеЕсли ИмяКоманды = "setversion"
- или ИмяКоманды = "v" Тогда
- ВывестиИспользованиеSetVersion();
+ или ИмяКоманды = "sv" Тогда
+ ИмяКомандыСправки = "set-version";
ИначеЕсли ИмяКоманды = "plugins"
или ИмяКоманды = "p" Тогда
- ВывестиИспользованиеPlugins();
+ ИмяКомандыСправки = "plugins";
Иначе
- Сообщить("Команда для подробного использования не корректная или не найдена");
- ВывестиОбщееИспользование();
+ ИмяКомандыСправки = "usage";
КонецЕсли;
+ ВывестиОписаниеДляКоманды(ИмяКомандыСправки);
+
КонецПроцедуры
Процедура ВывестиОписание(Знач ТекстОписания)
@@ -163,110 +157,31 @@
КонецПроцедуры
-Процедура ВывестиИспользованиеInit()
-
- ОписаниеКомандыInit = ПрочитатьФайл(ОбъединитьПути(КаталогДокументации, "init.md"));
-
- ВывестиОписание(ОписаниеКомандыInit);
-
-КонецПроцедуры
-
-Процедура ВывестиИспользованиеClone()
-
- ПодробноеОписаниеКоманды = "
- | Подробное описание использования команды
- |
- | clone (синоним c) - клонирует репозиторий git и при необходимости наполняет его данными из хранилища 1С
- | Подробную справку по параметрам см. %1 clone --help
- |
- | В РАЗРАБОТКЕ
- |";
-
- ВывестиОписание(ПодробноеОписаниеКоманды);
-
-КонецПроцедуры
-
-Процедура ВывестиИспользованиеSync()
-
- ПодробноеОписаниеКоманды = "
- | Подробное описание использования команды
- |
- | sync (синоним s) - инициализация нового хранилища git и наполнение его данными из хранилища 1С
- | Подробную справку по параметрам см. %1 sync --help
- |
- | Переменные окружения:
- | * GITSYNC_WORKDIR - рабочий каталог для команды
- | * GITSYNC_STORAGE_PATH - путь к хранилищу конфигурации 1С.
- |
- | Примеры, использования:
- |
- | 1. Простое использование
- |
- | > %1 sync C:/Хранилище_1С/ C:/work_dir/
- |
- | Данная команда выполнит синхронизация
- | версий хранилища 1С ""C:/Хранилище_1С/""
- | в рабочем каталоге ""C:/work_dir/""
- |
- | 2. Инциализация в текущем рабочем каталоге,
- | переменная окружения не должна быть задана
- |
- | > cd C:/work_dir/
- | > %1 sync C:/Хранилище_1С/
- |
- | Данная команда выполнит синхронизация
- | версий хранилища 1С ""C:/Хранилище_1С/""
- | в рабочем каталоге ""C:/work_dir/""
- |
-
- |";
+Процедура ВывестиОписаниеДляКоманды(Знач ИмяКоманды)
- ВывестиОписание(ПодробноеОписаниеКоманды);
-
-КонецПроцедуры
-
-Процедура ВывестиИспользованиеSetVersion()
-
- ПодробноеОписаниеКоманды = "Подробное описание использования команды
- |
- | setversion (синоним v) - устанавливает необходимую версию в файл VERSION
- | Подробную справку по параметрам см. %1 setversion --help
- |
- | В РАЗРАБОТКЕ
- |";
+ ИмяФайла = СтрШаблон("%1.md", ИмяКоманды);
- ВывестиОписание(ПодробноеОписаниеКоманды);
+ Если ПараметрыПриложения.ЭтоСборкаEXE() Тогда
+
+ ЗагрузчикЗапакованныхФайловGitsync = Новый ЗагрузчикЗапакованныхФайловGitsync;
+ ТекстОписанияКоманды = ПрочитатьФайл(ЗагрузчикЗапакованныхФайловGitsync.ПолучитьПутьКФайлу(ИмяФайла));
-КонецПроцедуры
+ Иначе
-Процедура ВывестиИспользованиеPlugins()
-
- ПодробноеОписаниеКоманды = "Подробное описание использования команды
- |
- | plugins (синоним p) - инициализация нового хранилища git и наполнение его данными из хранилища 1С
- | Подробную справку по параметрам см. %1 plugins --help
- |
- | В РАЗРАБОТКЕ
- |";
+ КаталогДокументации = ОбъединитьПути(ОбъединитьПути(ТекущийСценарий().Каталог, "..","..", ".."),"docs");
+ ТекстОписанияКоманды = ПрочитатьФайл(ОбъединитьПути(КаталогДокументации, ИмяФайла));
- ВывестиОписание(ПодробноеОписаниеКоманды);
+ КонецЕсли;
+
+ ВывестиОписание(ТекстОписанияКоманды);
КонецПроцедуры
-
Функция Инициализация()
СистемнаяИнформация = Новый СистемнаяИнформация;
ЭтоWindows = Найти(НРег(СистемнаяИнформация.ВерсияОС), "windows") > 0;
- Если ЭтоWindows Тогда
- ИмяКомандыGitsync = "gitsync";
- Иначе
- ИмяКомандыGitsync = "gitsync";
- КонецЕсли;
-
- КаталогДокументации = ОбъединитьПути(ОбъединитьПути(ТекущийСценарий().Каталог, "..","..", ".."),"docs");
-
Лог = ПараметрыПриложения.Лог();
КонецФункции
diff --git "a/src/cmd/\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\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os" "b/src/cmd/\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\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os"
index 98e8db96..507e5848 100644
--- "a/src/cmd/\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\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os"
+++ "b/src/cmd/\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\237\321\200\320\270\320\273\320\276\320\266\320\265\320\275\320\270\321\217.os"
@@ -1,6 +1,8 @@
#Использовать logos
#Использовать tempfiles
#Использовать fs
+#Использовать "../../core"
+#Использовать "../../core/Классы/internal/files"
Перем ЛогПриложения;
Перем ОбщиеПараметры;
@@ -11,25 +13,116 @@
Перем ИмяКаталогаПлагинов;
Перем ИмяКаталогаПриложения;
Перем ИмяФайлаНастройкиПриложения;
+Перем МенеджерПлагинов;
+Перем ИмяФайлаПлагинов;
Процедура Инициализация()
ОбщиеПараметры = Новый Структура();
- ОбщиеПараметры.Вставить("Плагины", Новый Массив);
ОбщиеПараметры.Вставить("ВерсияПлатформы", "8.3");
ОбщиеПараметры.Вставить("ПутьКПлатформе", "");
ОбщиеПараметры.Вставить("ДоменПочты", "localhost");
ОбщиеПараметры.Вставить("ПутьКГит", "");
- ОбщиеПараметры.Вставить("ЭтоРасширение", "");
ИмяКаталогаПлагинов = "plugins";
ИмяКаталогаПриложения = ".gitsync";
ИмяФайлаНастройкиПриложения = "config.json";
+ ИмяФайлаПлагинов = "plugins.json gitsync-plugins.json";
+ МенеджерПлагинов = Новый МенеджерПлагинов;
ОпределитьКаталогПлагинов();
КонецПроцедуры
+// Выполняет чтение включенных плагинов из файла
+//
+// Возвращаемое значение:
+// Соответствие - набор данных о плагина
+// * ключ - строка - имя плагина
+// * значение - булево - признак включенности плагина
+//
+Функция ПрочитатьВключенныеПлагины()
+
+ ВключенныеПлагины = Новый Соответствие;
+
+ ПутьКФайлу = ПолучитьПутьКФайлуПлагинов();
+ ФайлПлагинов = Новый Файл(ПутьКФайлу);
+
+ Если Не ФайлПлагинов.Существует() Тогда
+ Возврат ВключенныеПлагины;
+ КонецЕсли;
+
+ JsonСтрока = РаботаСФайлами.ПрочитатьФайл(ПутьКФайлу);
+
+ Если ПустаяСтрока(JsonСтрока) Тогда
+ Возврат ВключенныеПлагины;
+ КонецЕсли;
+
+ ДанныеФайла = РаботаСФайлами.ОбъектИзJson(JsonСтрока);
+
+ Для каждого ДанныеПлагинаИзФайла Из ДанныеФайла Цикл
+
+ Если Булево(ДанныеПлагинаИзФайла.Значение) Тогда
+ ВключенныеПлагины.Вставить(ДанныеПлагинаИзФайла.Ключ, ДанныеПлагинаИзФайла.Значение);
+ КонецЕсли;
+
+ КонецЦикла;
+
+ Возврат ВключенныеПлагины;
+
+КонецФункции
+
+Функция МенеджерПлагинов() Экспорт
+ Возврат МенеджерПлагинов;
+КонецФункции
+
+// Процедура записывает активированные плагины в файл
+//
+Процедура ЗаписатьВключенныеПлагины() Экспорт
+
+ ИмяФайла = ПолучитьПутьКФайлуПлагинов();
+
+ КаталогФайла = Новый Файл(ИмяФайла).Путь;
+ ФС.ОбеспечитьКаталог(КаталогФайла);
+
+ ДанныеДляЗаписи = Новый Соответствие;
+ ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
+
+ Для каждого КлючЗначение Из ИндексПлагинов Цикл
+
+ Плагин = КлючЗначение.Значение;
+ ДанныеДляЗаписи.Вставить(Плагин.Имя(), Плагин.Включен());
+
+ КонецЦикла;
+
+ ТекстФайла = РаботаСФайлами.ОБъектВJson(ДанныеДляЗаписи);
+
+ РаботаСФайлами.ЗаписатьФайл(ИмяФайла, ТекстФайла);
+
+КонецПроцедуры
+
+#КонецОбласти
+
+Функция ПолучитьПутьКФайлуПлагинов()
+
+ МассивИменФайла = СтрРазделить(ИмяФайлаПлагинов, " ", Ложь);
+
+ Для каждого ИмяФайла Из МассивИменФайла Цикл
+
+ ПутьКФайлуПлагинов = ОбъединитьПути(КаталогПлагинов(), ИмяФайла);
+
+ ФайлПлагинов = Новый Файл(ПутьКФайлуПлагинов);
+
+ Если Не ФайлПлагинов.Существует() Тогда
+ Возврат ФайлПлагинов.ПолноеИмя;
+ КонецЕсли;
+
+ КонецЦикла;
+
+ Возврат ОбъединитьПути(КаталогПлагинов(), МассивИменФайла[0]);
+
+КонецФункции
+
Функция ЭтоСборкаEXE() Экспорт
Если ЭтоПриложениеEXE = Неопределено Тогда
@@ -58,7 +151,7 @@
Если ЗначениеЗаполнено(ПутьККаталогуПлагинов) Тогда
- ОбщиеПараметры.УправлениеПлагинами.УстановитьКаталогПлагинов(ПутьККаталогуПлагинов);
+ МенеджерПлагинов.УстановитьКаталогПлагинов(ПутьККаталогуПлагинов);
КонецЕсли;
@@ -109,7 +202,7 @@
ИначеЕсли ПроверитьТекущийКаталог() Тогда
- Возврат ;
+ Возврат;
Иначе
@@ -177,29 +270,26 @@
// TODO Сделать чтение настройки из файла
КонецПроцедуры
-Функция ФайлВключенныхПлагинов() Экспорт
- Возврат ОбъединитьПути(КаталогПлагинов(), "gitsync-plugins.json");
-КонецФункции
-
Функция ИмяФайлаНастройкиПакетнойСинхронизации() Экспорт
- Возврат "config.yaml";
+ Возврат "config.json";
КонецФункции
Процедура ВыполнитьПодпискуПриРегистрацииКомандыПриложения(Команда) Экспорт
- ОбработчикПодписок = ОбщиеПараметры.УправлениеПлагинами.НовыйМенеджерПодписок();
+ ОбработчикПодписок = МенеджерПлагинов.НовыйМенеджерПодписок();
ОбработчикПодписок.ПриРегистрацииКомандыПриложения(Команда.ПолучитьИмяКоманды(), Команда);
КонецПроцедуры
Процедура ПодготовитьПлагины() Экспорт
- МенеджерПлагинов = Новый УправлениеПлагинами;
+ МенеджерПлагинов = Новый МенеджерПлагинов;
МенеджерПлагинов.УстановитьКаталогПлагинов(КаталогПлагинов());
- МенеджерПлагинов.УстановитьФайлВключенныхПлагинов(ФайлВключенныхПлагинов());
МенеджерПлагинов.ЗагрузитьПлагины();
+ ВключенныеПлагины = ПрочитатьВключенныеПлагины();
+ МенеджерПлагинов.ВключитьПлагины(ВключенныеПлагины);
- ОбщиеПараметры.Вставить("УправлениеПлагинами", МенеджерПлагинов);
+ ОбщиеПараметры.Вставить("МенеджерПлагинов", МенеджерПлагинов);
КонецПроцедуры
@@ -248,7 +338,7 @@
Если РежимОтладки Тогда
Лог().УстановитьУровень(УровниЛога.Отладка);
- ОбщиеПараметры.УправлениеПлагинами.УстановитьРежимОтладки();
+ МенеджерПлагинов().УстановитьРежимОтладки();
КонецЕсли;
@@ -281,7 +371,7 @@
Функция Версия() Экспорт
- Возврат "3.0.0-beta4";
+ Возврат "3.0.0-rc.2";
КонецФункции
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/README_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/README_Gitsync.os"
new file mode 100644
index 00000000..2fa0476d
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/README_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "README.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "D716283B8EAD871D80805B7FAB76784C";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "0J7Qv9C40YHQsNC90LjQtSDQv9GD0LHQu9C40YfQvdC+0LPQviDQuNC90YLQtdGA0YTQtdC50YHQsCDQsdC40LHQu9C40L7RgtC10LrQuCBgZ2l0c3luY2AKPT09PT09PT09Cgo8IS0tIFRPQyBpbnNlcnRBbmNob3I6dHJ1ZSAtLT4KCgo8IS0tIC9UT0MgLS0+Cgo+INCU0L7QutGD0LzQtdC90YLQsNGG0LjRjyDQsiDRgNCw0LfRgNCw0LHQvtGC0LrQtQoKPCEtLSBUT0RPOiDQn9C+0LTQs9C+0YLQvtCy0LjRgtGMINC00L7QutGD0LzQtdC90YLQsNGG0LjRjiAtLT4=";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/clone_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/clone_Gitsync.os"
new file mode 100644
index 00000000..6217bcc1
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/clone_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "clone.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "D41D8CD98F00B204E9800998ECF8427E";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/init_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/init_Gitsync.os"
new file mode 100644
index 00000000..22a0dc34
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/init_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "init.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "C13A148F21716C93E20BA5B2F99F57E4";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "# Подробное описание использования команды <init>

init (синоним i) - инициализация нового хранилища git и наполнение его данными из хранилища 1С

> Подробную справку по опциям и аргументам см. `gitsync init --help`

--------------
### Справка по использованию команды:
```
Команда: init, i
 Инициализация структуры нового хранилища git. Подготовка к синхронизации

Строка запуска: gitsync init [ОПЦИИ] PATH [WORKDIR]

Аргументы:
  PATH          Путь к хранилищу конфигурации 1С. (env $GITSYNC_STORAGE_PATH)
  WORKDIR       Адрес локального репозитория GIT или каталог исходников внутри локальной копии git-репозитария. По умолчанию текущий каталог (env $GITSYNC_WORKDIR)

Опции:
  -u, --storage-user    пользователь хранилища конфигурации (env $GITSYNC_STORAGE_USER) (по умолчанию Администратор)
  -p, --storage-pwd     пароль пользователя хранилища конфигурации (env $GITSYNC_STORAGE_PASSWORD, $GITSYNC_STORAGE_PWD)
```
--------------
### Глобальные переменные окружения
| Имя                 | Описание                                               |
|---------------------|--------------------------------------------------------|
| `GITSYNC_V8VERSION` | маска версии платформы (8.3, 8.3.5, 8.3.6.2299 и т.п.) |
| `GITSYNC_VERSOBE`   | вывод отладочной информация в процессе выполнении      |
| `GITSYNC_TEMP`      | путь к каталогу временных файлов                       |
| `GITSYNC_EMAIL`     | домен почты для пользователей git                      |

--------------
### Переменные окружения команды

| Имя                        | Описание                                   |
|----------------------------|--------------------------------------------|
| `GITSYNC_WORKDIR`          | рабочий каталог для команды                |
| `GITSYNC_STORAGE_PATH`     | путь к хранилищу конфигурации 1С.          |
| `GITSYNC_STORAGE_USER`     | пользователь хранилища конфигурации        |
| `GITSYNC_STORAGE_PASSWORD` | пароль пользователя хранилища конфигурации |
--------------
### Значения по умолчанию:
|                    |                              |
|--------------------|------------------------------|
| WORKDIR            | текущая рабочая директория   |
| -u, --storage-user | пользователь `Администратор` |

--------------
## Примеры, использования
***
* Простое использование

    `gitsync init C:/Хранилище_1С/ C:/GIT/src`

    Данная команда создаст новый репозиторий git в каталоге `C:/GIT/src` из хранилища 1С по пути `C:/Хранилище_1С/`
***
* Указание конкретной версии платформы

    `gitsync --v8version=8.3.9 init C:/Хранилище_1С/ C:/GIT/src`

    Данная команда создаст новый репозиторий git в каталоге `C:/GIT/src` из хранилища 1С по пути `C:/Хранилище_1С/`
    Для работы будет использоватьcя платформа 8.3.9.xxxx
***
* Указание вывода отладочных логов

    `gitsync --verbose init C:/Хранилище_1С/ C:/GIT/src`
    или
    `gitsync -v init C:/Хранилище_1С/ C:/GIT/src`

    Данная команда создаст новый репозиторий git в каталоге `C:/GIT/src` из хранилища 1С по пути `C:/Хранилище_1С/`
    После указания будет выводиться дополнительные отладочные логи с признаком `Отладка`
***
* Указание каталога временных файлов при работе приложения

    `gitsync --tempdir=./temp_sync/ init C:/Хранилище_1С/ C:/GIT/src`
    или
    `gitsync -t ./temp_sync/ init C:/Хранилище_1С/ C:/GIT/src`

    Данная команда создаст новый репозиторий git в каталоге `C:/GIT/src` из хранилища 1С по пути `C:/Хранилище_1С/`
    Для работы будет использоватьcя каталог временных файлов `./temp_sync/`
***
* Инициализация в текущем рабочем каталоге,

    > переменная окружения **`GITSYNC_WORKDIR`** не должна быть задана

    ```sh
    cd C:/work_dir/
    gitsync init C:/Хранилище_1С/
    ```
    Данная команда создаст новый репозиторий git в каталоге `C:/work_dir/` из хранилища 1С по пути `C:/Хранилище_1С/`
***
* Инициализация в с указанием пользователя и пароля.

    ```sh
    gitsync init --storage-user Admin --storage-pwd=Secret C:/Хранилище_1С/ C:/work_dir/
    ```
    Данная команда создаст новый репозиторий git в каталоге `C:/work_dir/` из хранилища 1С по пути `C:/Хранилище_1С/`
***
* Использование синонимов (короткая версия предыдущего примера)

    ```sh
    gitsync i -uAdmin -p=Secret C:/Хранилище_1С/ C:/work_dir/
    ```
    Данная команда создаст новый репозиторий git в каталоге `C:/work_dir/` из хранилища 1С по пути `C:/Хранилище_1С/`
***
* Использование только переменных окружения

    linux:
    ```sh
    export GITSYNC_WORKDIR=./work_dir/
    export GITSYNC_STORAGE_PATH=./Хранилище_1С/

    export GITSYNC_STORAGE_USER=Админ
    export GITSYNC_STORAGE_PASSWORD=Пароль
    export GITSYNC_V8VERSION=8.3.7
    export GITSYNC_VERSOBE=true #Можно использовать Да/Ложь/Нет/Истина
    export GITSYNC_TEMP=./temp/sync
    gitsync i
    ```
    
    windows:
    ```cmd
    set GITSYNC_WORKDIR=./work_dir/
    set GITSYNC_STORAGE_PATH=./Хранилище_1С/

    set GITSYNC_STORAGE_USER=Админ
    set GITSYNC_STORAGE_PASSWORD=Пароль
    set GITSYNC_V8VERSION=8.3.7
    set GITSYNC_VERSOBE=true #Можно использовать Да/Ложь/Нет/Истина
    set GITSYNC_TEMP=./temp/sync

    gitsync i
    ```
    Данная команда создаст новый репозиторий git в каталоге `C:/work_dir/` из хранилища 1С по пути `C:/Хранилище_1С/`";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/plugins_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/plugins_Gitsync.os"
new file mode 100644
index 00000000..ffcedf55
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/plugins_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "plugins.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "D41D8CD98F00B204E9800998ECF8427E";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/setversion_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/setversion_Gitsync.os"
new file mode 100644
index 00000000..35edd93d
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/setversion_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "setversion.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "D41D8CD98F00B204E9800998ECF8427E";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/sync_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/sync_Gitsync.os"
new file mode 100644
index 00000000..7243f598
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/sync_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "sync.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "74CEF0F61D02F663EE3857B6112384D2";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "# Подробное описание использования команды <sync>

sync (синоним s) - Выполняет синхронизацию хранилища 1С с git-репозиторием

> Подробную справку по опциям и аргументам см. `gitsync sync --help`

### Справка по использованию команды:
```
Команда: sync, s
 Выполняет синхронизацию хранилища 1С с git-репозиторием

Строка запуска: gitsync sync [ОПЦИИ] PATH [WORKDIR]

Аргументы:
  PATH          Путь к хранилищу конфигурации 1С. (env $GITSYNC_STORAGE_PATH)
  WORKDIR       Каталог исходников внутри локальной копии git-репозитария. (env $GITSYNC_WORKDIR)

Опции:
  -u, --storage-user    пользователь хранилища конфигурации (env $GITSYNC_STORAGE_USER) (по умолчанию Администратор)
  -p, --storage-pwd     пароль пользователя хранилища конфигурации (env $GITSYNC_STORAGE_PASSWORD, $GITSYNC_STORAGE_PWD)

```
### Глобальные переменные окружения
| Имя                 | Описание                                               |
|---------------------|--------------------------------------------------------|
| `GITSYNC_V8VERSION` | маска версии платформы (8.3, 8.3.5, 8.3.6.2299 и т.п.) |
| `GITSYNC_VERSOBE`   | вывод отладочной информация в процессе выполнении      |
| `GITSYNC_TEMP`      | путь к каталогу временных файлов                       |
| `GITSYNC_EMAIL`     | домен почты для пользователей git                      |

### Переменные окружения команды

| Имя                        | Описание                                   |
|----------------------------|--------------------------------------------|
| `GITSYNC_WORKDIR`          | рабочий каталог для команды                |
| `GITSYNC_STORAGE_PATH`     | путь к хранилищу конфигурации 1С.          |
| `GITSYNC_STORAGE_USER`     | пользователь хранилища конфигурации        |
| `GITSYNC_STORAGE_PASSWORD` | пароль пользователя хранилища конфигурации |

### Значения по умолчанию

|                    |                              |
|--------------------|------------------------------|
| WORKDIR            | текущая рабочая директория   |
| -u, --storage-user | пользователь `Администратор` |

## Примеры, использования

* Простое использование

    `gitsync sync C:/Хранилище_1С/ C:/GIT/src`

    Данная команда выполнить синхронизацию хранилища 1С по пути `C:/Хранилище_1С/` и репозитория git в каталоге `C:/GIT/src`

* Инициализация в текущем рабочем каталоге,

    > переменная окружения **`GITSYNC_WORKDIR`** не должна быть задана

    ```sh
    cd C:/work_dir/
    gitsync sync C:/Хранилище_1С/
    ```
    Данная команда выполнить синхронизацию хранилища 1С по пути `C:/Хранилище_1С/` и репозитория git в каталоге `C:/work_dir`

* Инициализация в с указанием пользователя и пароля.

    ```sh
    gitsync sync --storage-user Admin --storage-pwd=Secret C:/Хранилище_1С/ C:/work_dir/
    ```
    Данная команда выполнить синхронизацию хранилища 1С по пути `C:/Хранилище_1С/` и репозитория git в каталоге `C:/work_dir`
    Используя для подключения к хранилищу 1С пользователя `Admin` и пароль `Secret`

* Использование синонимов (короткая версия предыдущего примера)

    ```sh
    gitsync s -uAdmin -p=Secret C:/Хранилище_1С/ C:/work_dir/
    ```
    Данная команда выполнить синхронизацию хранилища 1С по пути `C:/Хранилище_1С/` и репозитория git в каталоге `C:/work_dir`
    Используя для подключения к хранилищу 1С пользователя `Admin` и пароль `Secret`

* Использование только переменных окружения

    linux:
    ```sh
    export GITSYNC_WORKDIR=./work_dir/
    export GITSYNC_STORAGE_PATH=./Хранилище_1С/

    export GITSYNC_STORAGE_USER=Admin
    export GITSYNC_STORAGE_PASSWORD=Secret
    export GITSYNC_V8VERSION=8.3.7
    export GITSYNC_VERSOBE=true #Можно использовать Да/Ложь/Нет/Истина
    export GITSYNC_TEMP=./temp/sync
    gitsync s
    ```
    windows:
    ```cmd
    set GITSYNC_WORKDIR=./work_dir/
    set GITSYNC_STORAGE_PATH=./Хранилище_1С/

    set GITSYNC_STORAGE_USER=Admin
    set GITSYNC_STORAGE_PASSWORD=Secret
    set GITSYNC_V8VERSION=8.3.7
    set GITSYNC_VERSOBE=true #Можно использовать Да/Ложь/Нет/Истина
    set GITSYNC_TEMP=./temp/sync

    gitsync s
    ```
    Данная команда выполнить синхронизацию хранилища 1С по пути `C:/Хранилище_1С/` и репозитория git в каталоге `C:/work_dir`
    Используя для подключения к хранилищу 1С пользователя `Admin` и пароль `Secret`
";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/tempExtension_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/tempExtension_Gitsync.os"
new file mode 100644
index 00000000..dd27e4e9
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/tempExtension_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "tempExtension.cfe";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "6B3A3B869213E02BE3C63E74A4117049";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "////fwACAAADAAAAAAAAAA0KMDAwMDAwMjQgMDAwMDAyMDAgN2ZmZmZmZmYgDQovAgAArgIAAP///3+ACQAA/wkAAP///38eDAAAaQwAAP///38AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA0KMDAwMDAwNjAgMDAwMDAwNjAgN2ZmZmZmZmYgDQqgmg3OP0MCAKCaDc4/QwIAAAAAAGIANQBhAGEAMAA3ADYAYwAtAGMAMQA4ADcALQA0ADQAZAAwAC0AYQBmADgANQAtADkAYwAwADIANABkADQAMQBkADMAYwA5AAAAAAANCjAwMDAwNmIzIDAwMDAwNmIzIDdmZmZmZmZmIA0KvVhNbiW5Dd4PMJdwto+AKFEitc1FBiIlHSBAVgMDyS7HyBGyGWCAYJAruE+SK+Sr56rX7cl0TwduxN0o+NmUxCL5/cj//ue/fsy377/70esYSVtQsCmJzERjW6UeKcsUniX6860doT1m5RSThu8g5inUpQilJKnXxXmHHnF8POp99/T4nG7pJhpScjKKXRJJRKPeZ6ZU9trd+kilPd+eXv7+8o8Pf/3wt5efP/zl5aeXX15+fvmJn153evrTn58+F4GlTze+6a3PHcN9Uxs6SGwMMs1Mc9el5qVptFu5cV1FWnby6E5yvFmffdOM1HPeJrWlW77pbtoKCyk37DarkJVSaSiPYlU9c2C38Mmb1yTNsyBsFPKZMkWTMnvt1XViN27sIXF/fTyKZRpJKu1qO9eVRa0gLBr+zRXIaDHCeJMzXmaJ5LV8WwtG2BxNDLWjvDmTsG2ylfHotXlwGq3tW37+/ruzNkcjnj/7TOcX/cbj+rphThpbGA1LnaSZUc+K124tj7qkidav2+nrgo7EX/9fc/T85rtveNQ3C7JUOD1yPF7i/5zAhbqnP6BsmmxPYCA8Fkm2Tl60UNJRh4qv1fnG9xn5dgnkrwsrjyIdGd/zPrNeErXsLrTqBi8N8IxhoCmz+TTmGIvPdU9/fMJ3R/7/43J+3/L8vuXlfcvlfcvr+5a39y3X9y239y3vb5cfO+SPosI/PJ0Avg9Yfp3RrqU56LzHCJJVwMeCE2ZZvWob3sXOcUxhPbRn4hblkMlK3ptj8GvysdLodV6he4l1Q3o1zyO00SihH0NV2yN0b+hSkG1BAhqBBBgfZ406cuap/cIR+7xr+KxjQok6k3sWgtCvtbj0BHE+Q6t2yFyhCGiN8EYCVoJWoHzeR4WInKFZIN4qEO9ejKTCKNiEKiaWLEOzM68ztKRZq0ynKgzG2S1DkBTGgqPN2MuzxxWqO+/RB3nW9vAU9a2nOEO7z7khwSmQoVQId4f00uw9NraGBPoVuqokGTAAayPXANuNyUwdlclzDwiwPUIVbgZSnJr+TgukucTsSnsyFH6BUoePTAV5TW0d2Vy7yrJsEGdKW4TEK0wG45CRvaAA6jOuClQzMYgnlbZgL+DFyAw8CVZeLjAOaV4V0BnzMBM0YlSSnht5lU5sMAVt4NDYZyh8SchA54EDJIBXJmtoseKo3DYDE1eu1qqmkhepChzJYhi84oPqnG3Z2K527Xo6wPVFB8hfZRHu+41dBQOYqOSGPhXZOHopXI7ONnMrFuU8OmCSUu+LuDj23A7vOGsiOL2UcspdH+MXAQOo3UgDRCCNEaqwmQoAuHpUGL8zFGek3rbjd/WACpzU2IADzk+iyhhN/0gSRwV2zFwH6mQ5XxU4UJAsCTrOvPsR1x4SfHpfjF/o9EJ9ZLS5gB865oIOYnH2NfrUrxNgmJ56ZwRGyS2BB4DiL0MnNZ5wwOipHia/pUW9YiTWVIxxQc1NrlBd+IDJMt18sRdo5zfYiwsXyYlpt+SvoZ+DDkfVNRwzVjCvIqiD81wEJ4sfN3UU/OKZzaMed5HtSFM84S4CkoQrPwZSOJcH05Y27LDwqCmwCLzD2UyfsOe+SrBqV31gl7NPrTDxfuhCBR4iKmVP3urue6QrAXh916PFua/8ZUawPBjLcWzO6WBakCxYilhwFPizjkeu3vDrgVHnJr+zKyYUxceGpQLrXw49binMBgCpH0jLYARcq7LVmUH3nvsVGlvQAFBSwY3lGpe0307uayhI1pKiUdAPFCuhu1a5U+lHEzbuKZIfqDiBsUozqANTGvcRywG6B6v1XaR22d19fHIZPFExBvBoindD28FojJsaXhNy3SYbt52ynfp8jEaxpQtsUiBPQCDew0BVZGBKX+E5rccUzbVmdzuK1kAXG5wlkIHIuBNFQW3uEvQJsHHPkp7APZGBf9yJCcQAjasVIuPNa/FfY1q3lm4Z4Ot63L4KFAZCCtkL0AOmaqxPsi/JOSU0E01B9gr8jYW2hlsMG2DCdk3rRvqmw6jJAtHX5VAOOAQvY80BSKSlb7KvjCV1Gq0h4LHUYHsMFGO5V9aaYGfWf1cfbd5eklBJh6AFONjrcW/NxrgxhLv4J/mvhmsvgMNFQda9InDh4gwcewUfowP1yj9mgQCDrOtRTENNukP+VkwHbzaTwW/yX83Y8qF/uehxKwZPNt3UU/AqRdEt/XX14TBaXgJlLfBlUiGJY8B0AHUFQMM0xmv1z79HKAAI1epRDq5QhpOqmIqElIbnMld9k9L9lPvF8/zhfwANCjAwMDAwMDYwIDAwMDAwMDYwIDdmZmZmZmZmIA0KoJoNzj9DAgCgmg3OP0MCAAAAAABjADEAOAA2ADEAOABjADgALQBhADgAMAA5AC0ANAA2ADgAOAAtADkAMgA3AGQALQA3ADYANgAyAGEANQBlADQANgA0ADcANQAAAAAADQowMDAwMDA3ZCAwMDAwMDIwMCA3ZmZmZmZmZiANCi2MwQlCMRBE74JN5JyF3XWzyS9nk68FCJ4+OXxsxDLUf7CFpBJbMIoMDMNjZt7bayG/3y34tX9CXygppZLAEk4gmhJMHGeIqmzhKCoxVO/arV/72tf2bPf2cL/1wM7TkGQ2zuU0PiSAUDYwPMyAIeNkXLQQeR7188VVj/UDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADQowMDAwMDAyYyAwMDAwMDAyYyA3ZmZmZmZmZiANCqCaDc4/QwIAoJoNzj9DAgAAAAAAYwBvAG4AZgBpAGcAaQBuAGYAbwAAAAAADQowMDAwMDBmYyAwMDAwMDIwMCA3ZmZmZmZmZiANCo2OTW6CQABG9yRcgi0zcQZmhpkFixpFG7BYS0DYwQy1RZHKT1s1nqyLHqlXaGt6gCZv8SUvX/K+Pj7PCOja2cIMXAdHNkYAXXTtl6sCBc1z5DAJJeYOJEQhmD9yCoVEFlEEK1sKkGdPiyax3t5LM/LZ3KPWdGSfnE6eaL3P4ociQau9GUzGq24I42OvttkkvntNpqLiu3BY67rWF2F6PKh6qEkT9DfpTPDO3LjuX4bxnw4DHG6ffc8bVeqFBmbjdyqSXlS1y1177wLj58owlxzmHAlIGOdQWI6CDmNWTkvCiEMNMPJwMF4Uy3mIzSgMN22Jt0UwzNZF6l6+AQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/usage_Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/usage_Gitsync.os"
new file mode 100644
index 00000000..2831f01d
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/usage_Gitsync.os"
@@ -0,0 +1,34 @@
+
+///////////////////////////////////////////
+// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+///////////////////////////////////////////
+//
+// ФАЙЛ:
+//
+
+// Возвращает версию запакованного файла
+//
+Функция Версия() Экспорт
+ Возврат "1.0.0";
+КонецФункции
+
+// Возвращает имя запакованного файла
+//
+Функция ИмяФайла() Экспорт
+ Возврат "usage.md";
+КонецФункции
+
+// Возвращает хеш строку запакованного файла
+//
+Функция Хеш() Экспорт
+ Возврат "D41D8CD98F00B204E9800998ECF8427E";
+КонецФункции
+
+// Возвращает запакованные данные файла
+//
+Функция ДвоичныеДанные() Экспорт
+ ЗапакованныеДанные = "";
+ Возврат ЗапакованныеДанные;
+КонецФункции
+
+
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\244\320\260\320\271\320\273\320\276\320\262Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\244\320\260\320\271\320\273\320\276\320\262Gitsync.os"
new file mode 100644
index 00000000..beb0b8e7
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\244\320\260\320\271\320\273\320\276\320\262Gitsync.os"
@@ -0,0 +1,79 @@
+#Использовать tempfiles
+
+#Область ПрограммныйИнтерфейс
+
+Функция ПолучитьПутьКФайлу(Знач ИмяФайла) Экспорт
+
+ Возврат ПолучитьВременныйПутьКФайлу(ИмяФайла);
+
+КонецФункции
+
+Функция ПолучитьВременныйПутьКФайлу(Знач ИмяФайла) Экспорт
+
+ МенеджерЗапакованныхФайлов = Новый МенеджерЗапакованныхФайловGitsync;
+ ИндексФайлов = МенеджерЗапакованныхФайлов.ПолучитьИндексФайлов();
+
+ ИмяКлассаФайла = ИндексФайлов[ИмяФайла];
+
+ Если ИмяКлассаФайла = Неопределено Тогда
+ ВызватьИсключение СтрШаблон("Не удалось найти двоичные данные для файла <%1>", ИмяФайла);
+ КонецЕсли;
+
+ ФайлРаспаковки = Новый Файл(ИмяФайла);
+
+ КлассФайла = Новый (ИмяКлассаФайла);
+
+ ПутьКФайлу = ВременныеФайлы.НовоеИмяФайла(ФайлРаспаковки.Расширение);
+
+ РаспаковатьДанные(ПутьКФайлу, КлассФайла);
+
+ Возврат ПутьКФайлу;
+
+КонецФункции
+
+Функция ПолучитьХешФайла(Знач ИмяФайла) Экспорт
+
+ МенеджерЗапакованныхФайлов = Новый МенеджерЗапакованныхФайловGitsync;
+ ИндексФайлов = МенеджерЗапакованныхФайлов.ПолучитьИндексФайлов();
+
+ ИмяКлассаФайла = ИндексФайлов[ИмяФайла];
+
+ Если ИмяКлассаФайла = Неопределено Тогда
+ ВызватьИсключение СтрШаблон("Не удалось найти двоичные данные для файла <%1>", ИмяФайла);
+ КонецЕсли;
+
+ ФайлРаспаковки = Новый Файл(ИмяФайла);
+
+ КлассФайла = Новый (ИмяКлассаФайла);
+
+ Возврат КлассФайла.Хеш()
+
+КонецФункции
+
+#КонецОбласти
+
+#Область Упакованные_файлы
+
+Процедура РаспаковатьДанные(Знач ПутьКФайлу, КлассФайла)
+
+ ДвоичныеДанные = Base64Значение(КлассФайла.ДвоичныеДанные());
+
+ ОбеспечитьКаталог(ПутьКФайлу);
+
+ ДвоичныеДанные.Записать(ПутьКФайлу);
+
+КонецПроцедуры
+
+Процедура ОбеспечитьКаталог(ПутьККаталогу)
+
+ ВременныйКаталог = Новый Файл(ПутьККаталогу);
+
+ Если ВременныйКаталог.Существует() Тогда
+ Возврат;
+ КонецЕсли;
+
+ СоздатьКаталог(ВременныйКаталог.Путь);
+
+КонецПроцедуры
+
+#КонецОбласти
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\244\320\260\320\271\320\273\320\276\320\262Gitsync.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\244\320\260\320\271\320\273\320\276\320\262Gitsync.os"
new file mode 100644
index 00000000..8b1191eb
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/bindata/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\244\320\260\320\271\320\273\320\276\320\262Gitsync.os"
@@ -0,0 +1,15 @@
+Функция ПолучитьИндексФайлов() Экспорт
+
+ ИндексФайлов = Новый Соответствие;
+ ИндексФайлов.Вставить("tempExtension.cfe", "tempExtension_Gitsync");
+ ИндексФайлов.Вставить("clone.md", "clone_Gitsync");
+ ИндексФайлов.Вставить("init.md", "init_Gitsync");
+ ИндексФайлов.Вставить("plugins.md", "plugins_Gitsync");
+ ИндексФайлов.Вставить("README.md", "README_Gitsync");
+ ИндексФайлов.Вставить("setversion.md", "setversion_Gitsync");
+ ИндексФайлов.Вставить("sync.md", "sync_Gitsync");
+ ИндексФайлов.Вставить("usage.md", "usage_Gitsync");
+
+ Возврат ИндексФайлов;
+
+КонецФункции
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/files/\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\244\320\260\320\271\320\273\320\260\320\274\320\270.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/files/\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\244\320\260\320\271\320\273\320\260\320\274\320\270.os"
new file mode 100644
index 00000000..01a53335
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/files/\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\244\320\260\320\271\320\273\320\260\320\274\320\270.os"
@@ -0,0 +1,49 @@
+#Использовать json
+
+Функция ПрочитатьФайл(Знач ПутьКФайлу) Экспорт
+
+ ЧтениеТекста = Новый ЧтениеТекста(ПутьКФайлу, "UTF-8");
+ ТекстФайла = ЧтениеТекста.Прочитать();
+ ЧтениеТекста.Закрыть();
+
+ Возврат ТекстФайла;
+
+КонецФункции
+
+Процедура ЗаписатьФайл(Знач ПутьКФайлу, Знач ТекстФайла) Экспорт
+
+ ЗаписьТекста = Новый ЗаписьТекста(ПутьКФайлу);
+ ЗаписьТекста.Записать(ТекстФайла);
+ ЗаписьТекста.Закрыть();
+
+КонецПроцедуры
+
+Функция ОБъектВJson(Знач Объект, ПараметрыЗаписи = Неопределено) Экспорт
+
+ Если ПараметрыЗаписи = Неопределено Тогда
+ ПараметрыЗаписи = Новый ПараметрыЗаписиJSON(ПереносСтрокJSON.Авто, " ", ,,,,,, Истина);
+ КонецЕсли;
+
+ ЗаписьJSON = Новый ЗаписьJSON;
+ ЗаписьJSON.УстановитьСтроку(ПараметрыЗаписи);
+ ЗаписатьJSON(ЗаписьJSON, Объект);
+
+ Возврат ЗаписьJSON.Закрыть();
+
+КонецФункции
+
+Функция ОбъектИзJson(ТекстJSON, ЧитатьВСтруктуру = Ложь, ФорматДаты = Неопределено) Экспорт
+
+ Если ФорматДаты = Неопределено Тогда
+ ФорматДаты = ФорматДатыJSON.ISO;
+ КонецЕсли;
+ ЧтениеJSON = Новый ЧтениеJSON;
+ ЧтениеJSON.УстановитьСтроку(ТекстJSON);
+
+ Объект = ПрочитатьJSON(ЧтениеJSON,
+ НЕ ЧитатьВСтруктуру,,
+ ФорматДаты);
+ ЧтениеJSON.Закрыть();
+ Возврат Объект;
+
+КонецФункции
\ No newline at end of file
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
index f6af1162..9104f016 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
@@ -1,6 +1,6 @@
#Использовать logos
-Перем ИндексУстановленныхПлагинов; // Соответствие
+Перем НаборПлагиновСинхронизации; // Соответствие
Перем Лог; // Объект - Логирование
Перем ДоступныйИнтерфейсПлагинов; // Объект.ИнтерфейсОбъекта - интерфейс плагинов
Перем КаталогПлагинов; // Строка - каталог пакетов плагинов
@@ -20,7 +20,29 @@
//
Процедура ЗагрузитьПлагины() Экспорт
- ОбновитьИндексПлагинов();
+ ПодключениеПлагиновКаталога = Новый ПодключениеПлагиновКаталога;
+ МассивПлагинов = ПодключениеПлагиновКаталога.ПодключитьПлагиныКаталога(КаталогПлагинов);
+ Лог.Отладка("Количество плагинов <%1> каталога <%2>", МассивПлагинов.Количество(), КаталогПлагинов);
+
+ СоздательНабораПлагиновСинхронизации = Новый СоздательНабораПлагиновСинхронизации;
+
+ Для каждого ИмяКлассаПлагина Из МассивПлагинов Цикл
+
+ СоздательНабораПлагиновСинхронизации.ДобавитьПлагин(ИмяКлассаПлагина);
+
+ КонецЦикла;
+
+ ПодключениеЗапакованныхПлагинов = Новый ПодключениеЗапакованныхПлагинов;
+ МассивПлагинов = ПодключениеЗапакованныхПлагинов.ИндексПлагинов();
+ Лог.Отладка("Количество встроенных плагинов <%1>", МассивПлагинов.Количество());
+
+ Для каждого ИмяКлассаПлагина Из МассивПлагинов Цикл
+
+ СоздательНабораПлагиновСинхронизации.ДобавитьПлагин(ИмяКлассаПлагина);
+
+ КонецЦикла;
+
+ НаборПлагиновСинхронизации = СоздательНабораПлагиновСинхронизации.Создать();
КонецПроцедуры
@@ -32,113 +54,17 @@
// * значение - Объект - ссылка на произвольный объект
//
Функция ИндексПлагинов() Экспорт
- Возврат ИндексУстановленныхПлагинов;
+ Возврат НаборПлагиновСинхронизации;
КонецФункции
#КонецОбласти
#Область Вспомогательные_процедуры_и_функции
-Процедура ОбновитьИндексПлагинов()
-
- Лог.Отладка("Обновление индекса плагина из каталога <%1>", КаталогПлагинов);
- ИндексУстановленныхПлагинов = Новый Соответствие;
-
- КаталогиПлагинов = НайтиФайлы(КаталогПлагинов, ПолучитьМаскуВсеФайлы(), Ложь);
-
- Для каждого Каталоги Из КаталогиПлагинов Цикл
-
- Если Не Каталоги.ЭтоКаталог() Тогда
- Продолжить;
- КонецЕсли;
-
- ЗагрузитьПлагин(Каталоги.ПолноеИмя);
-
- КонецЦикла;
-
- Лог.Отладка("В индекс плагинов добавлено <%1> плагинов", ИндексУстановленныхПлагинов.Количество());
-
-КонецПроцедуры
-
-Процедура ЗагрузитьПлагин(Знач Путь)
-
- Лог.Отладка("Загружаю плагины из каталога <%1>", Путь);
-
- ФайлМанифеста = Новый Файл(ОбъединитьПути(Путь, "lib.config"));
-
- Если ФайлМанифеста.Существует() Тогда
- Лог.Отладка("Обрабатываем по манифесту");
- ДобавитьКлассыПлагинов(ФайлМанифеста.ПолноеИмя, Путь);
- Иначе
- Лог.Отладка("Плагины из каталога <%1> не могут быть загружены - не найден файл ", Путь);
- КонецЕсли;
-
-КонецПроцедуры
-
-Процедура ДобавитьКлассыПлагинов(Знач Файл, Знач Путь)
-
- Чтение = Новый ЧтениеXML;
- Чтение.ОткрытьФайл(Файл);
- Чтение.ПерейтиКСодержимому();
-
- Если Чтение.ЛокальноеИмя <> "package-def" Тогда
- Чтение.Закрыть();
- Возврат;
- КонецЕсли;
-
- Пока Чтение.Прочитать() Цикл
-
- Если Чтение.ТипУзла = ТипУзлаXML.Комментарий Тогда
-
- Продолжить;
-
- КонецЕсли;
-
- Если Чтение.ТипУзла = ТипУзлаXML.НачалоЭлемента Тогда
-
- Если Чтение.ЛокальноеИмя = "class" Тогда
- ФайлКласса = Новый Файл(ОбъединитьПути(Путь, Чтение.ЗначениеАтрибута("file")));
- Если ФайлКласса.Существует()
- И ФайлКласса.ЭтоФайл() Тогда
- Идентификатор = Чтение.ЗначениеАтрибута("name");
- Если Не ПустаяСтрока(Идентификатор) Тогда
- ДобавитьПлагинВИндекс(Идентификатор, ФайлКласса.ПолноеИмя);
- КонецЕсли;
- Иначе
- ВызватьИсключение "Не найден файл " + ФайлКласса.ПолноеИмя + ", указанный в манифесте";
- КонецЕсли;
-
- Чтение.Прочитать(); // в конец элемента
-
- КонецЕсли;
-
- КонецЕсли;
-
- КонецЦикла;
-
- Чтение.Закрыть();
-
-КонецПроцедуры
-
-Процедура ДобавитьПлагинВИндекс(Знач ИмяКлассаПлагина, Знач ИмяФайлаКласса)
-
- Лог.Отладка("Добавляю плагин <%1> в индекс плагинов", ИмяКлассаПлагина);
-
- Попытка
- НовыйПлагин = Новый ПлагинСинхронизации(ИмяФайлаКласса, ИмяКлассаПлагина, ДоступныйИнтерфейсПлагинов);
- Исключение
- Лог.Отладка("Ошибка добавления плагина в индекс плагинов. По причине: <%1>", ОписаниеОшибки());
- Возврат;
- КонецПопытки;
-
- ИндексУстановленныхПлагинов.Вставить(НовыйПлагин.Имя(), НовыйПлагин);
-
-КонецПроцедуры
-
Процедура ПриСозданииОбъекта(Знач ВходящийКаталогПлагинов = Неопределено)
КаталогПлагинов = ВходящийКаталогПлагинов;
- ДоступныйИнтерфейсПлагинов = Новый ИнтерфейсПлагинов().Интерфейс();
+ НаборПлагиновСинхронизации = Новый Соответствие();
Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync.plugins.loader");
КонецПроцедуры
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262EXE.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262EXE.os"
deleted file mode 100644
index 776223b2..00000000
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\227\320\260\320\263\321\200\321\203\320\267\321\207\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262EXE.os"
+++ /dev/null
@@ -1,84 +0,0 @@
-#Использовать logos
-
-Перем ИндексУстановленныхПлагинов; // Соответствие
-Перем Лог; // Объект - Логирование
-Перем ДоступныйИнтерфейсПлагинов; // Объект.ИнтерфейсОбъекта - интерфейс плагинов
-Перем КаталогПлагинов; // Строка - каталог пакетов плагинов
-
-#Область Экспортные_методы
-
-// Устанавливает каталог плагинов
-//
-// Параметры:
-// ПутьККаталогу - Строка - полный путь к каталогу плагинов
-//
-Процедура УстановитьКаталогПлагинов(Знач ПутьККаталогу) Экспорт
- КаталогПлагинов = ПутьККаталогу;
-КонецПроцедуры
-
-// Выполняет загрузки плагинов в индекс
-//
-Процедура ЗагрузитьПлагины() Экспорт
-
- ОбновитьИндексПлагинов();
-
-КонецПроцедуры
-
-// Возвращает загруженный индекс плагинов
-//
-// Возвращаемое значение:
-// Соответствие - набор плагинов
-// * ключ - Строка - имя плагина
-// * значение - Объект - ссылка на произвольный объект
-//
-Функция ИндексПлагинов() Экспорт
- Возврат ИндексУстановленныхПлагинов;
-КонецФункции
-
-#КонецОбласти
-
-#Область Вспомогательные_процедуры_и_функции
-
-Процедура ОбновитьИндексПлагинов()
-
- Лог.Отладка("Обновление индекса плагина из каталога <%1>", КаталогПлагинов);
- ИндексУстановленныхПлагинов = Новый Соответствие;
-
- ИндексПлагиновEXE = Новый ИндексПлагиновEXE;
- ИндексПлагинов = ИндексПлагиновEXE.ПолучитьИндексПлагиновEXE();
-
- Для каждого Плагин Из ИндексПлагинов Цикл
-
- ДобавитьПлагинВИндекс(Плагин);
-
- КонецЦикла;
-
- Лог.Отладка("В индекс плагинов добавлено <%1> плагинов", ИндексУстановленныхПлагинов.Количество());
-
-КонецПроцедуры
-
-Процедура ДобавитьПлагинВИндекс(Знач ИмяКлассаПлагина)
-
- Лог.Отладка("Добавляю плагин <%1> в индекс плагинов", ИмяКлассаПлагина);
-
- Попытка
- НовыйПлагин = Новый ПлагинСинхронизации(Неопределено, ИмяКлассаПлагина, ДоступныйИнтерфейсПлагинов);
- ИндексУстановленныхПлагинов.Вставить(НовыйПлагин.Имя(), НовыйПлагин);
-
- Исключение
- Лог.Отладка("Ошибка добавления плагина в индекс плагинов. По причине: <%1>", ОписаниеОшибки());
-
- КонецПопытки;
-
-
-КонецПроцедуры
-
-Процедура ПриСозданииОбъекта(Знач ВходящийКаталогПлагинов = Неопределено)
-
- КаталогПлагинов = ВходящийКаталогПлагинов;
- ДоступныйИнтерфейсПлагинов = Новый ИнтерфейсПлагинов().Интерфейс();
- Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync.plugins.loader");
-
-КонецПроцедуры
-
-#КонецОбласти
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\230\320\275\320\264\320\265\320\272\321\201\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262EXE.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\230\320\275\320\264\320\265\320\272\321\201\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262EXE.os"
deleted file mode 100644
index 4300f5d9..00000000
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\230\320\275\320\264\320\265\320\272\321\201\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262EXE.os"
+++ /dev/null
@@ -1,7 +0,0 @@
-Функция ПолучитьИндексПлагиновEXE() Экспорт
-
- ИндексПлагинов = Новый Массив;
-
- Возврат ИндексПлагинов;
-
-КонецФункции
\ No newline at end of file
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\276\320\264\320\277\320\270\321\201\320\276\320\272.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\276\320\264\320\277\320\270\321\201\320\276\320\272.os"
index 4d593898..63bb64d7 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\276\320\264\320\277\320\270\321\201\320\276\320\272.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\276\320\264\320\277\320\270\321\201\320\276\320\272.os"
@@ -153,18 +153,20 @@
// * ГУИД_Автора - Строка - уникальный идентификатор автора версии
// * ПредставлениеАвтора - Строка - представление автора для коммита в git
// ПутьКХранилищу - Строка - полный путь к хранилищу конфигурации
+// НачальнаяВерсия - Число - номер начальной версии хранилища
// СтандартнаяОбработка - Булево - признак отказ от обработки по умолчанию
//
-Процедура ПриПолученииТаблицыВерсий(ТаблицаВерсий, ПутьКХранилищу, СтандартнаяОбработка) Экспорт
+Процедура ПриПолученииТаблицыВерсий(ТаблицаВерсий, ПутьКХранилищу, НачальнаяВерсия, СтандартнаяОбработка) Экспорт
ПараметрыВыполнения = Новый Массив;
ПараметрыВыполнения.Добавить(ТаблицаВерсий);
ПараметрыВыполнения.Добавить(ПутьКХранилищу);
+ ПараметрыВыполнения.Добавить(НачальнаяВерсия);
ПараметрыВыполнения.Добавить(СтандартнаяОбработка);
ВыполнитьПодпискуНаСобытие("ПриПолученииТаблицыВерсий", ПараметрыВыполнения);
- ПрисвоитьЗначенияПараметраПроцедуры(ПараметрыВыполнения, ТаблицаВерсий, ПутьКХранилищу, СтандартнаяОбработка);
+ ПрисвоитьЗначенияПараметраПроцедуры(ПараметрыВыполнения, ТаблицаВерсий, ПутьКХранилищу, НачальнаяВерсия, СтандартнаяОбработка);
КонецПроцедуры
@@ -243,6 +245,48 @@
КонецПроцедуры
+// Вызывается при получении таблицы пользователей из хранилища конфигурации
+//
+// Параметры:
+// ПутьКФайлуАвторов - Строка - полный путь к хранилищу конфигурации
+// ТаблицаАвторов - ТаблицаЗначений - инициализированная таблица с колонками:
+// * Автор - Строка - имя автора версии в хранилище
+// * ПредставлениеАвтора - Строка - представление автора для коммита в git
+// СтандартнаяОбработка - Булево - признак отказ от обработки по умолчанию
+//
+Процедура ПриПолученииТаблицыАвторов(ПутьКФайлуАвторов, ТаблицаАвторов, СтандартнаяОбработка) Экспорт
+
+ ПараметрыВыполнения = Новый Массив;
+ ПараметрыВыполнения.Добавить(ПутьКФайлуАвторов);
+ ПараметрыВыполнения.Добавить(ТаблицаАвторов);
+ ПараметрыВыполнения.Добавить(СтандартнаяОбработка);
+
+ ВыполнитьПодпискуНаСобытие("ПриПолученииТаблицыАвторов", ПараметрыВыполнения);
+
+ ПрисвоитьЗначенияПараметраПроцедуры(ПараметрыВыполнения, ПутьКФайлуАвторов, ТаблицаАвторов, СтандартнаяОбработка);
+
+КонецПроцедуры
+
+// Вызывается при получении таблицы пользователей из хранилища конфигурации
+//
+// Параметры:
+// ПутьКФайлуАвторов - Строка - полный путь к хранилищу конфигурации
+// ТаблицаАвторов - ТаблицаЗначений - инициализированная таблица с колонками:
+// * Автор - Строка - имя автора версии в хранилище
+// * ПредставлениеАвтора - Строка - представление автора для коммита в git
+//
+Процедура ПослеПолученияТаблицыАвторов(ПутьКФайлуАвторов, ТаблицаАвторов) Экспорт
+
+ ПараметрыВыполнения = Новый Массив;
+ ПараметрыВыполнения.Добавить(ПутьКФайлуАвторов);
+ ПараметрыВыполнения.Добавить(ТаблицаАвторов);
+
+ ВыполнитьПодпискуНаСобытие("ПослеПолученияТаблицыАвторов", ПараметрыВыполнения);
+
+ ПрисвоитьЗначенияПараметраПроцедуры(ПараметрыВыполнения, ПутьКФайлуАвторов, ТаблицаАвторов);
+
+КонецПроцедуры
+
#КонецОбласти
#Область Подписки_на_обработки_строки_версии
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\273\320\260\320\263\320\270\320\275\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\273\320\260\320\263\320\270\320\275\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
index 1a9eeb86..ebc39004 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\273\320\260\320\263\320\270\320\275\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\273\320\260\320\263\320\270\320\275\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
@@ -154,16 +154,10 @@
КлассПлагина = ПолучитьКлассПлагина();
КонецПроцедуры
-Процедура ПриСозданииОбъекта(Знач ВходящееИмяФайлаКлассаПлагина, Знач ВходящееИмяКлассаПлагина, ИнтерфейсМетодовПлагинов)
+Процедура ПриСозданииОбъекта(Знач ВходящееИмяКлассаПлагина, ИнтерфейсМетодовПлагинов)
ИмяКлассаПлагина = ВходящееИмяКлассаПлагина;
- Если НЕ ВходящееИмяФайлаКлассаПлагина = Неопределено Тогда
-
- ПодключитьСценарий(ВходящееИмяФайлаКлассаПлагина, ИмяКлассаПлагина);
-
- КонецЕсли;
-
КлассПлагина = ПолучитьКлассПлагина();
ИнтерфейсПлагина = Новый ИнтерфейсОбъекта();
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\276\320\264\320\272\320\273\321\216\321\207\320\265\320\275\320\270\320\265\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\276\320\264\320\272\320\273\321\216\321\207\320\265\320\275\320\270\320\265\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
new file mode 100644
index 00000000..cbb704bd
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\276\320\264\320\272\320\273\321\216\321\207\320\265\320\275\320\270\320\265\320\227\320\260\320\277\320\260\320\272\320\276\320\262\320\260\320\275\320\275\321\213\321\205\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
@@ -0,0 +1,9 @@
+// ИСПОЛЬЗУЕТСЯ ТОЛЬКО ДЛЯ СБОРКИ В EXE
+//
+Функция ИндексПлагинов() Экспорт
+
+ ИндексПлагинов = Новый Массив;
+
+ Возврат ИндексПлагинов;
+
+КонецФункции
\ No newline at end of file
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\276\320\264\320\272\320\273\321\216\321\207\320\265\320\275\320\270\320\265\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262\320\232\320\260\321\202\320\260\320\273\320\276\320\263\320\260.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\276\320\264\320\272\320\273\321\216\321\207\320\265\320\275\320\270\320\265\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262\320\232\320\260\321\202\320\260\320\273\320\276\320\263\320\260.os"
new file mode 100644
index 00000000..d91e271a
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\276\320\264\320\272\320\273\321\216\321\207\320\265\320\275\320\270\320\265\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262\320\232\320\260\321\202\320\260\320\273\320\276\320\263\320\260.os"
@@ -0,0 +1,93 @@
+#Использовать logos
+
+Перем МассивПодключенныхПлагинов;
+Перем Лог;
+
+Функция ПодключитьПлагиныКаталога(Знач КаталогПлагинов) Экспорт
+
+ МассивПодключенныхПлагинов = Новый Массив();
+
+ Если ВРег(Прав(ТекущийСценарий().Источник, 3)) = "EXE" Тогда
+ Возврат МассивПодключенныхПлагинов;
+ КонецЕсли;
+
+ Лог.Отладка("Подключение плагинов из каталога <%1>", КаталогПлагинов);
+ КаталогиПлагинов = НайтиФайлы(КаталогПлагинов, ПолучитьМаскуВсеФайлы(), Ложь);
+
+ Для каждого Каталоги Из КаталогиПлагинов Цикл
+
+ Если Не Каталоги.ЭтоКаталог() Тогда
+ Продолжить;
+ КонецЕсли;
+
+ ЗагрузитьПлагин(Каталоги.ПолноеИмя);
+
+ КонецЦикла;
+
+ Возврат МассивПодключенныхПлагинов;
+
+КонецФункции
+
+Процедура ЗагрузитьПлагин(Знач Путь)
+
+ Лог.Отладка("Загружаю плагины из каталога <%1>", Путь);
+
+ ФайлМанифеста = Новый Файл(ОбъединитьПути(Путь, "lib.config"));
+
+ Если ФайлМанифеста.Существует() Тогда
+ Лог.Отладка("Обрабатываем по манифесту");
+ ДобавитьКлассыПлагинов(ФайлМанифеста.ПолноеИмя, Путь);
+ Иначе
+ Лог.Отладка("Плагины из каталога <%1> не могут быть загружены - не найден файл ", Путь);
+ КонецЕсли;
+
+КонецПроцедуры
+
+Процедура ДобавитьКлассыПлагинов(Знач Файл, Знач Путь)
+
+ Чтение = Новый ЧтениеXML;
+ Чтение.ОткрытьФайл(Файл);
+ Чтение.ПерейтиКСодержимому();
+
+ Если Чтение.ЛокальноеИмя <> "package-def" Тогда
+ Чтение.Закрыть();
+ Возврат;
+ КонецЕсли;
+
+ Пока Чтение.Прочитать() Цикл
+
+ Если Чтение.ТипУзла = ТипУзлаXML.Комментарий Тогда
+
+ Продолжить;
+
+ КонецЕсли;
+
+ Если Чтение.ТипУзла = ТипУзлаXML.НачалоЭлемента Тогда
+
+ Если Чтение.ЛокальноеИмя = "class" Тогда
+ ФайлКласса = Новый Файл(ОбъединитьПути(Путь, Чтение.ЗначениеАтрибута("file")));
+ Если ФайлКласса.Существует()
+ И ФайлКласса.ЭтоФайл() Тогда
+ Идентификатор = Чтение.ЗначениеАтрибута("name");
+ Если Не ПустаяСтрока(Идентификатор) Тогда
+ ПодключитьСценарий(ФайлКласса.ПолноеИмя, Идентификатор);
+ МассивПодключенныхПлагинов.Добавить(Идентификатор);
+ КонецЕсли;
+ Иначе
+ ВызватьИсключение "Не найден файл " + ФайлКласса.ПолноеИмя + ", указанный в манифесте";
+ КонецЕсли;
+
+ Чтение.Прочитать(); // в конец элемента
+
+ КонецЕсли;
+
+ КонецЕсли;
+
+ КонецЦикла;
+
+ Чтение.Закрыть();
+
+КонецПроцедуры
+
+Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync.plugins.loader");
+МассивПодключенныхПлагинов = Новый Массив();
\ No newline at end of file
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\240\320\265\320\277\320\276\320\267\320\270\321\202\320\276\321\200\320\270\320\271\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\240\320\265\320\277\320\276\320\267\320\270\321\202\320\276\321\200\320\270\320\271\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
index 130d1f81..374addbe 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\240\320\265\320\277\320\276\320\267\320\270\321\202\320\276\321\200\320\270\320\271\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\240\320\265\320\277\320\276\320\267\320\270\321\202\320\276\321\200\320\270\320\271\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
@@ -11,14 +11,12 @@
Перем ПарольПользователяХранилища;
Перем УровеньЛогаСинхронизации;
Перем КоличествоЦикловОжиданияЛицензии;
-
+Перем ИмяРасширения;
Перем ИндексПодписчиков;
Перем ПараметрыПодписчиков;
Перем МенеджерСинхронизации;
Перем КаталогПлагинов;
-Перем ПутьКФайлуВключенныхПлагинов;
-Перем ЛокальноеУправлениеПлагинами;
Перем Лог;
@@ -32,7 +30,7 @@
ПроверитьВозможностьСинхронизации();
- НастроитьМенеджерСинхронизации();
+ МенеджерСинхронизации = ПолучитьМенеджерСинхронизации();
Если МенеджерСинхронизации.ТребуетсяСинхронизироватьХранилищеСГит(ПутьКРабочемуКаталогу, ПутьКХранилищу) Тогда
@@ -44,7 +42,7 @@
Лог.Информация("Путь к рабочей копии: <%1>", ПутьКРабочемуКаталогу);
Иначе
- Лог.Предупреждение("--> Синхронизация не требуется <--");
+ Лог.Информация("--> Синхронизация не требуется <--");
КонецЕсли;
Лог.Информация("=================================");
@@ -54,23 +52,25 @@
// TODO: Написать проверку какую? )
КонецПроцедуры
-Процедура НастроитьМенеджерСинхронизации()
+Функция ПолучитьМенеджерСинхронизации()
- Если МенеджерСинхронизации = Неопределено Тогда
- МенеджерСинхронизации = Новый МенеджерСинхронизации();
- КонецЕсли;
-
+ МенеджерСинхронизации = Новый МенеджерСинхронизации();
МенеджерСинхронизации.ВерсияПлатформы(ВерсияПлатформы)
.ДоменПочтыПоУмолчанию(ДоменПочтыПоУмолчанию)
.ИсполняемыйФайлГит(ПутьИсполняемомуФайлуГит)
.ПодпискиНаСобытия(ИндексПодписчиков)
.ПараметрыПодписокНаСобытия(ПараметрыПодписчиков)
- .УровеньЛога(УровеньЛогаСинхронизации)
.ЦикловОжиданияЛицензии(КоличествоЦикловОжиданияЛицензии)
.РежимУдаленияВременныхФайлов(Истина)
.АвторизацияВХранилищеКонфигурации(ПользовательХранилища, ПарольПользователяХранилища);
-КонецПроцедуры
+ Если ЗначениеЗаполнено(ИмяРасширения) Тогда
+ МенеджерСинхронизации.ИмяРасширения(ИмяРасширения);
+ КонецЕсли;
+
+ Возврат МенеджерСинхронизации;
+
+КонецФункции
// Устанавливает путь к каталогу плагинов
//
@@ -85,40 +85,13 @@
Возврат ЭтотОбъект;
КонецФункции
-// Устанавливает уровень вывода логов
-//
-// Параметры:
-// НовыйУровеньЛога - Строка - уровень вывода лога
-//
-// Возвращаемое значение:
-// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
-//
-Функция УровеньЛога(Знач НовыйУровеньЛога) Экспорт
-
- УровеньЛогаСинхронизации = НовыйУровеньЛога;
- Возврат ЭтотОбъект;
-
-КонецФункции
-
-// Устанавливает путь к файлу включенных плагинов
-//
-// Параметры:
-// НовыйПутьКФайлуВключенныхПлагинов - Строка - путь к файлу включенных плагинов
-//
-// Возвращаемое значение:
-// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
-//
-Функция ФайлВключенныхПлагинов(Знач НовыйПутьКФайлуВключенныхПлагинов) Экспорт
- ПутьКФайлуВключенныхПлагинов = НовыйПутьКФайлуВключенныхПлагинов;
- Возврат ЭтотОбъект;
-КонецФункции
-
Процедура ПрочитатьПараметры(Знач ВходящиеПараметры) Экспорт
Наименование = ВходящиеПараметры.Наименование;
ПользовательХранилища = ВходящиеПараметры.ПользовательХранилища;
ПарольПользователяХранилища = ВходящиеПараметры.ПарольПользователяХранилища;
ВерсияПлатформы = ВходящиеПараметры.ВерсияПлатформы;
+ ИмяРасширения = ВходящиеПараметры.ИмяРасширения;
ПутьКХранилищу = ВходящиеПараметры.ПутьКХранилищу;
ПутьКРабочемуКаталогу = ВходящиеПараметры.ПутьКРабочемуКаталогу;
ПутьИсполняемомуФайлуГит = ВходящиеПараметры.ПутьИсполняемомуФайлуГит;
@@ -134,32 +107,20 @@
Процедура ПрочитатьПлагины(Знач НастройкаПлагинов)
- ИнициализироватьУправлениеПлагинами();
-
- ЛокальноеУправлениеПлагинами.ВключитьПлагины(НастройкаПлагинов.ВключенныеПлагины);
- ЛокальноеУправлениеПлагинами.ВключитьПлагины(НастройкаПлагинов.ДополнительныеПлагины);
- ЛокальноеУправлениеПлагинами.ОтключитьПлагины(НастройкаПлагинов.ОтключенныеПлагины);
-
- ИндексПодписчиков = ЛокальноеУправлениеПлагинами.ПолучитьИндексПлагинов();
+ МенеджерПлагинов = Новый МенеджерПлагинов;
+ МенеджерПлагинов.УстановитьКаталогПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.ЗагрузитьПлагины();
-КонецПроцедуры
-
-Процедура ИнициализироватьУправлениеПлагинами()
-
- Если ЛокальноеУправлениеПлагинами = Неопределено Тогда
+ МенеджерПлагинов.ВключитьПлагины(НастройкаПлагинов.ВключенныеПлагины);
+ МенеджерПлагинов.ВключитьПлагины(НастройкаПлагинов.ДополнительныеПлагины);
+ МенеджерПлагинов.ОтключитьПлагины(НастройкаПлагинов.ОтключенныеПлагины);
- ЛокальноеУправлениеПлагинами = Новый УправлениеПлагинами;
- ЛокальноеУправлениеПлагинами.УстановитьКаталогПлагинов(КаталогПлагинов);
- ЛокальноеУправлениеПлагинами.УстановитьФайлВключенныхПлагинов(ПутьКФайлуВключенныхПлагинов);
- ЛокальноеУправлениеПлагинами.ЗагрузитьПлагины();
-
- КонецЕсли;
+ ИндексПодписчиков = МенеджерПлагинов.ПолучитьИндексПлагинов();
КонецПроцедуры
Процедура ПриСозданииОбъекта()
Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync.batch");
- УровеньЛогаСинхронизации = Лог.Уровень();
КонецПроцедуры
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\276\320\267\320\264\320\260\321\202\320\265\320\273\321\214\320\235\320\260\320\261\320\276\321\200\320\260\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\276\320\267\320\264\320\260\321\202\320\265\320\273\321\214\320\235\320\260\320\261\320\276\321\200\320\260\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
new file mode 100644
index 00000000..c240d7cb
--- /dev/null
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\320\232\320\273\320\260\321\201\321\201\321\213/\320\241\320\276\320\267\320\264\320\260\321\202\320\265\320\273\321\214\320\235\320\260\320\261\320\276\321\200\320\260\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
@@ -0,0 +1,38 @@
+#Использовать logos
+
+Перем НаборИменКлассовПлагинов;
+Перем ДоступныйИнтерфейсПлагинов;
+Перем Лог;
+
+Функция Создать() Экспорт
+
+ НаборПлагинов = Новый Соответствие();
+
+ Для каждого ИмяКлассаПлагина Из НаборИменКлассовПлагинов Цикл
+
+ Лог.Отладка("Добавляю плагин <%1> в индекс плагинов", ИмяКлассаПлагина);
+
+ Попытка
+ НовыйПлагин = Новый ПлагинСинхронизации(ИмяКлассаПлагина, ДоступныйИнтерфейсПлагинов);
+ Исключение
+ Лог.Отладка("Ошибка добавления плагина в индекс плагинов. По причине: <%1>", ОписаниеОшибки());
+ Продолжить;
+ КонецПопытки;
+
+ НаборПлагинов.Вставить(НовыйПлагин.Имя(), НовыйПлагин);
+
+ КонецЦикла;
+
+ Возврат НаборПлагинов;
+
+КонецФункции
+
+Процедура ДобавитьПлагин(Знач ИмяКласса) Экспорт
+
+ НаборИменКлассовПлагинов.Добавить(ИмяКласса);
+
+КонецПроцедуры
+
+НаборИменКлассовПлагинов = Новый Массив();
+ДоступныйИнтерфейсПлагинов = Новый ИнтерфейсПлагинов().Интерфейс();
+Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync.plugins.loader");
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\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\321\211\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\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\321\211\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
index d33c975b..aeeb2a1c 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\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\321\211\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/internal/\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\321\211\320\270\320\272\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
@@ -80,6 +80,18 @@
КонецФункции
+Процедура ПриСозданииОбъекта()
+
+ ДополнительныйКаталогБиблиотек = ПолучитьЗначениеСистемнойНастройки("lib.additional");
+
+ Если ЗначениеЗаполнено(ДополнительныйКаталогБиблиотек) Тогда
+ КаталогЗависимостей = ДополнительныйКаталогБиблиотек;
+ Иначе
+ КаталогЗависимостей = ПолучитьЗначениеСистемнойНастройки("lib.system");
+ КонецЕсли;
+
+КонецПроцедуры
+
#КонецОбласти
Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync.plugins.installer");
\ No newline at end of file
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\320\277\321\200\320\260\320\262\320\273\320\265\320\275\320\270\320\265\320\237\320\273\320\260\320\263\320\270\320\275\320\260\320\274\320\270.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
similarity index 52%
rename from "src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\320\277\321\200\320\260\320\262\320\273\320\265\320\275\320\270\320\265\320\237\320\273\320\260\320\263\320\270\320\275\320\260\320\274\320\270.os"
rename to "src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
index fb19f719..f916e104 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\243\320\277\321\200\320\260\320\262\320\273\320\265\320\275\320\270\320\265\320\237\320\273\320\260\320\263\320\270\320\275\320\260\320\274\320\270.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262.os"
@@ -5,8 +5,6 @@
Перем ИндексПлагинов;
Перем КаталогПлагинов;
-Перем ПутьКФайлуВключенныхПлагинов;
-Перем КаталогЗависимостей;
#Область Экспортные_методы
@@ -29,9 +27,6 @@
ТекущийЗагрузчикПлагинов.ЗагрузитьПлагины();
ИндексПлагинов = ТекущийЗагрузчикПлагинов.ИндексПлагинов();
- ВключенныеПлагины = ПрочитатьВключенныеПлагины();
- ВключитьПлагины(ВключенныеПлагины);
-
КонецПроцедуры
// Создает и возвращает новый МенеджерПодписок для текущего индекса плагинов
@@ -102,6 +97,28 @@
КонецПроцедуры
+Процедура ВключитьВсеПлагины() Экспорт
+
+ Для каждого КлючЗначение Из ИндексПлагинов Цикл
+
+ Плагин = КлючЗначение.Значение;
+ Плагин.Включить();
+
+ КонецЦикла;
+
+КонецПроцедуры
+
+Процедура ОтключитьВсеПлагины() Экспорт
+
+ Для каждого КлючЗначение Из ИндексПлагинов Цикл
+
+ Плагин = КлючЗначение.Значение;
+ Плагин.Отключить();
+
+ КонецЦикла;
+
+КонецПроцедуры
+
// Устанавливает каталог установки и чтения плагинов
//
// Параметры:
@@ -111,15 +128,6 @@
КаталогПлагинов = ПутьККаталогу;
КонецПроцедуры
-// Устанавливает каталог для установки зависимостей пакета плагинов
-//
-// Параметры:
-// НовыйКаталогЗависимостей - Строка - полный путь к каталогу установки зависимостей пакета плагина
-//
-Процедура УстановитьКаталогЗависимостей(Знач НовыйКаталогЗависимостей) Экспорт
- КаталогЗависимостей = НовыйКаталогЗависимостей;
-КонецПроцедуры
-
// Производит установку пакета плагинов из файла
//
// Параметры:
@@ -129,8 +137,6 @@
Установщик = Новый УстановщикПлагинов();
Установщик.УстановитьКаталогПлагинов(КаталогПлагинов);
- Установщик.УстановитьКаталогЗависимостей(КаталогЗависимостей);
-
Установщик.УстановитьФайлПлагина(ПутьКФайлуПакета);
КонецПроцедуры
@@ -144,8 +150,6 @@
Установщик = Новый УстановщикПлагинов();
Установщик.УстановитьКаталогПлагинов(КаталогПлагинов);
- Установщик.УстановитьКаталогЗависимостей(КаталогЗависимостей);
-
Установщик.УстановитьПлагинПоИмени(ИмяПлагина);
КонецПроцедуры
@@ -163,123 +167,10 @@
КонецПроцедуры
-// Устанавливает путь к файлу информации о плагинах
-//
-// Параметры:
-// ПутьКФайлу - Строка - полный путь к файлы информации плагинах
-//
-Процедура УстановитьФайлВключенныхПлагинов(Знач ПутьКФайлу) Экспорт
- ПутьКФайлуВключенныхПлагинов = ПутьКФайлу;
-КонецПроцедуры
-
-// Выполняет чтение включенных плагинов из файла
-//
-// Возвращаемое значение:
-// Соответствие - набор данных о плагина
-// * ключ - строка - имя плагина
-// * значение - булево - признак включенности плагина
-//
-Функция ПрочитатьВключенныеПлагины() Экспорт
-
- ВключенныеПлагины = Новый Соответствие;
-
- ПутьКФайлу = ПолучитьПутьКФайлуВключенныхПлагинов();
- ФайлАктивныхПлагинов= Новый Файл(ПутьКФайлу);
-
- Если Не ФайлАктивныхПлагинов.Существует() Тогда
- Возврат ВключенныеПлагины;
- КонецЕсли;
-
- JsonСтрока = ПрочитатьФайл(ПутьКФайлу);
-
- Если ПустаяСтрока(JsonСтрока) Тогда
- Возврат ВключенныеПлагины;
- КонецЕсли;
-
- ПарсерJSON = Новый ПарсерJSON();
- ДанныеФайла = ПарсерJSON.ПрочитатьJSON(JsonСтрока);
-
- Для каждого ДанныеПлагинаИзФайла Из ДанныеФайла Цикл
-
- Если Булево(ДанныеПлагинаИзФайла.Значение) Тогда
- ВключенныеПлагины.Вставить(ДанныеПлагинаИзФайла.Ключ, ДанныеПлагинаИзФайла.Значение);
- КонецЕсли;
-
- КонецЦикла;
-
- Возврат ВключенныеПлагины;
-
-КонецФункции
-
-// Возвращает имя файла информации о плагинах
-//
-// Возвращаемое значение:
-// Строка - имя файла
-//
-Функция ИмяФайлаВключенныхПлагинов() Экспорт
-
- Возврат "gitsync-plugins.json";
-
-КонецФункции
-
-// Процедура записывает активированные плагины в файл
-//
-Процедура ЗаписатьВключенныеПлагины() Экспорт
-
- ИмяФайла = ПолучитьПутьКФайлуВключенныхПлагинов();
-
- КаталогФайла = Новый Файл(ИмяФайла).Путь;
- ФС.ОбеспечитьКаталог(КаталогФайла);
-
- ПарсерJSON = Новый ПарсерJSON();
- ДанныеДляЗаписи = Новый Соответствие;
-
- Для каждого КлючЗначение Из ИндексПлагинов Цикл
-
- Плагин = КлючЗначение.Значение;
- ДанныеДляЗаписи.Вставить(Плагин.Имя(), Плагин.Включен());
-
- КонецЦикла;
-
- ТекстФайла = ПарсерJSON.ЗаписатьJson(ДанныеДляЗаписи);
-
- ЗаписатьФайл(ИмяФайла, ТекстФайла);
-
-КонецПроцедуры
-
#КонецОбласти
#Область Вспомогательные_процедуры_и_функции
-Функция ПолучитьПутьКФайлуВключенныхПлагинов()
-
- ФайлАктивныхПлагинов= Новый Файл(ПутьКФайлуВключенныхПлагинов);
-
- Если Не ФайлАктивныхПлагинов.Существует() Тогда
- Возврат ОбъединитьПути(КаталогПлагинов, ИмяФайлаВключенныхПлагинов());
- КонецЕсли;
-
- Возврат ФайлАктивныхПлагинов.ПолноеИмя;
-
-КонецФункции
-
-Функция ПрочитатьФайл(Знач ИмяФайла)
-
- Чтение = Новый ЧтениеТекста(ИмяФайла, КодировкаТекста.UTF8);
- Рез = Чтение.Прочитать();
- Чтение.Закрыть();
-
- Возврат Рез;
-
-КонецФункции
-
-Процедура ЗаписатьФайл(Знач ИмяФайла, ТекстФайла)
-
- Запись = Новый ЗаписьТекста(ИмяФайла);
- Запись.ЗаписатьСтроку(ТекстФайла);
- Запись.Закрыть();
-
-КонецПроцедуры
Процедура ПриСозданииОбъекта(Знач ЗначениеКаталогПлагинов = Неопределено)
@@ -289,14 +180,6 @@
КаталогПлагинов = ЗначениеКаталогПлагинов;
КонецЕсли;
- ДополнительныйКаталогБиблиотек = ПолучитьЗначениеСистемнойНастройки("lib.additional");
-
- Если ЗначениеЗаполнено(ДополнительныйКаталогБиблиотек) Тогда
- КаталогЗависимостей = ДополнительныйКаталогБиблиотек;
- Иначе
- КаталогЗависимостей = ПолучитьЗначениеСистемнойНастройки("lib.system");
- КонецЕсли;
-
КонецПроцедуры
#КонецОбласти
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
index 81b251a3..8b2ea4b8 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\320\270.os"
@@ -7,6 +7,7 @@
#Использовать gitrunner
#Использовать fs
#Использовать "./internal"
+#Использовать "./internal/bindata"
Перем Лог; // Объект, для логирования
Перем ЭтоWindows; // Булево, призная операционной системы WINDOWS
@@ -17,7 +18,7 @@
Перем ГитРепозиторийСохр; // Объект.ГитРепозиторий
// Определяем мин количество коммитов между разницей версии уже в git и в хранилище
// для случаев, когда пересоздали хранилище и в гите находится версия 1234, а в хранилище 4,
-// тогда вызываем исключение если разница в коммитах больше чем на эту велечину.
+// тогда вызываем исключение если разница в коммитах больше чем на эту величину.
Перем МинимальнаяРазницаМеждуКоммитамиНовогоХранилища;
Перем ОбработчикПодписок; // Объект.МенеджерПодписок
@@ -26,6 +27,7 @@
Перем РабочийКонфигуратор; // Объект.УправлениеКонфигуратором
Перем ПутьКИсполняемомуФайлуGit; // Строка, полный путь к исполняемому файлу git
Перем ИмяРасширения; // Строка, Имя расширения для синхронизации
+Перем КонтекстВыполнения; // Структура, Ключи СтрокаСоединения, Пользователь, Пароль
///////////////////////////////////////////////////////////////////////////////////////////////
// ПРОГРАММНЫЙ ИНТЕРФЕЙС
@@ -92,34 +94,27 @@
// ИмяРасширения - Строка - имя расширения для выгрузки
//
Функция ПолучитьИмяРасширения() Экспорт
- Возврат ИмяРасширения
-КонецФункции
-
-// Устанавливает работу с хранилищем расширения
-//
-// Параметры:
-// ПарамЭтоРасширение - Булево - признак работы с расширением.
-//
-// Возвращаемое значение:
-// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
-//
-Функция РежимРаботыСХранилищемРасширения(Знач ПарамЭтоРасширение) Экспорт
- ЭтоРасширение = ПарамЭтоРасширение;
- Возврат ЭтотОбъект;
+ Возврат ИмяРасширения
КонецФункции
// Устанавливает набор подписчиков
//
// Параметры:
-// НовыйИндексПодписчиков - Соответствие - набор подписчиков
+// ПИндексПодписчиков - Соответствие - набор подписчиков
// * ключ - Строка - имя подписчика
// * значение - Объект - ссылка на произвольный объект
+// ППараметрыПодписок - Соответствие - набор параметров для подписчиков
// Возвращаемое значение:
// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
//
-Функция ПодпискиНаСобытия(Знач НовыйИндексПодписчиков) Экспорт
+Функция ПодпискиНаСобытия(Знач ПИндексПодписчиков, Знач ППараметрыПодписок = Неопределено) Экспорт
- УстановитьОбработчикПодписок(НовыйИндексПодписчиков);
+ УстановитьОбработчикПодписок(ПИндексПодписчиков);
+
+ Если Не ППараметрыПодписок = Неопределено Тогда
+ ПараметрыПодписокНаСобытия(ППараметрыПодписок);
+ КонецЕсли;
+
Возврат ЭтотОбъект;
КонецФункции
@@ -231,6 +226,27 @@
КонецФункции
+// Устанавливает контекст выполнения синхронизации
+//
+// Параметры:
+// СтрокаСоединения - Строка - строка соединения с информационной базой
+// Пользователь - Строка - пользователь информационной базы
+// Пароль - Строка - пароль информационной базы
+//
+// Возвращаемое значение:
+// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
+//
+Функция УстановитьКонтекст(Знач СтрокаСоединения, Знач Пользователь, Знач Пароль) Экспорт
+
+ КонтекстВыполнения.СтрокаСоединения = СтрокаСоединения;
+ КонтекстВыполнения.Пользователь = Пользователь;
+ КонтекстВыполнения.Пароль = Пароль;
+
+ ПоказатьКонтекстВРежимеОтладки();
+
+ Возврат ЭтотОбъект;
+КонецФункции
+
// Основная функция синхронизации.
// Перемещает в git набор коммитов хранилища 1С
//
@@ -248,12 +264,12 @@
ХранилищеКонфигурации = ПолучитьХранилищеКонфигурации(ПутьКХранилищу);
- ТаблицаИсторииХранилища = ПрочитатьИзХранилищаИсториюКоммитовСАвторами(ПутьКХранилищу);
-
- ДополнитьТаблицуХранилищаИнформациейОСигнатуреПользователяВГит(ТаблицаИсторииХранилища, КаталогРабочейКопии);
-
ТекущаяВерсия = НомерСинхронизированнойВерсии(КаталогРабочейКопии);
+ ТаблицаИсторииХранилища = ПрочитатьИзХранилищаИсториюКоммитовСАвторами(ПутьКХранилищу, ТекущаяВерсия);
+
+ ДополнитьТаблицуХранилищаИнформациейОСигнатуреПользователяВГит(ТаблицаИсторииХранилища, КаталогРабочейКопии);
+
Лог.Информация("Номер синхронизированной версии: " + ТекущаяВерсия);
СледующаяВерсия = ТекущаяВерсия + 1;
@@ -356,7 +372,7 @@
КаталогВыгрузки = ВременныеФайлы.СоздатьКаталог();
- Лог.Отладка("Каталог выгрузки <%1> для версии <%2>", КаталогВыгрузки , НомерВерсии);
+ Лог.Отладка("Каталог выгрузки <%1> для версии <%2>", КаталогВыгрузки, НомерВерсии);
ОбработчикПодписок.ПередВыгрузкойКонфигурациюВИсходники(Конфигуратор,
КаталогРабочейКопии,
@@ -451,13 +467,13 @@
Исключение
// проверим текст ошибки, если текст содержит информацию о необходимости конвертировать
// тогда выполним конвертацию и повторно попытаемся загрузить файл
- ТекстОшибки = ВРег(ХранилищеКонфигурации.ПолучитьВыводКоманды());
- Если Найти(ТекстОшибки, Врег("Не обнаружено свободной лицензии!"))
- ИЛИ Найти(ТекстОшибки, Врег("Не найдена лицензия.")) Тогда
+ ТекстОшибки = ХранилищеКонфигурации.ПолучитьВыводКоманды();
+ Если Найти(ВРег(ТекстОшибки), Врег("Не обнаружено свободной лицензии!"))
+ ИЛИ Найти(ВРег(ТекстОшибки), Врег("Не найдена лицензия.")) Тогда
ПериодОжидания = 10000;
Лог.Ошибка(ТекстОшибки);
- Лог.Информация("Повторное подключение через 10сек. Осталось попыток: <%1>", КоличествоЦикловОжиданияЛицензии);
+ Лог.Информация("Повторное подключение через 10 сек. Осталось попыток: <%1>", КоличествоЦикловОжиданияЛицензии);
Приостановить(ПериодОжидания);
Иначе
@@ -494,13 +510,14 @@
Если СтандартнаяОбработка Тогда
- Параметры = Конфигуратор.ПолучитьПараметрыЗапуска();
- Параметры.Добавить(СтрШаблон("/DumpConfigToFiles %1", КаталогВыгрузки));
- Если ИмяРасширения <> "" Тогда
- Параметры.Добавить(СтрШаблон("-Extension %1", ИмяРасширения));
- КонецЕсли;
Попытка
- Конфигуратор.ВыполнитьКоманду(Параметры);
+
+ Если НЕ ПустаяСтрока(ИмяРасширения) Тогда
+ Конфигуратор.ВыгрузитьРасширениеВФайлы(КаталогВыгрузки, ИмяРасширения);
+ Иначе
+ Конфигуратор.ВыгрузитьКонфигурациюВФайлы(КаталогВыгрузки);
+ КонецЕсли;
+
Исключение
ОписаниеОшибки = ОписаниеОшибки();
Если Не ЭтоПропускаемаяОшибка(ОписаниеОшибки) Тогда
@@ -510,34 +527,12 @@
КонецЕсли;
КонецПопытки;
- КонецЕсли;
+ КонецЕсли;
ОбработчикПодписок.ПослеВыгрузкиКонфигурациюВИсходники(Конфигуратор, КаталогВыгрузки);
КонецПроцедуры
-Функция МассивИсключаемыхОшибок()
-
- Массив = Новый Массив;
- Массив.Добавить("Конфигурация содержит объекты метаданных, длина имен которых превышает 80 символов!");
-
- Возврат Массив;
-КонецФункции
-
-Функция ЭтоПропускаемаяОшибка(Знач ОписаниеОшибки)
-
- МассивИсключаемыхОшибок = МассивИсключаемыхОшибок();
-
- Для Каждого ИсключаемаяОшибка Из МассивИсключаемыхОшибок Цикл
-
- Если СтрНайти(ОписаниеОшибки, ИсключаемаяОшибка) > 0 Тогда
- Возврат Истина;
- КонецЕсли;
-
- КонецЦикла;
- Возврат Ложь;
-КонецФункции
-
#КонецОбласти
#Область Функциональность_очистки_каталога_рабочей_копии
@@ -557,8 +552,8 @@
СоответствиеИменФайловДляПропуска.Вставить(ИмяФайлаВерсииХранилища(), Истина); // Номер версии, может использоватся для синхронизации с хранилищем.
ОбработчикПодписок.ПриОчисткеКаталогаРабочейКопии(КаталогРабочейКопии,
- СоответствиеИменФайловДляПропуска,
- СтандартнаяОбработка);
+ СоответствиеИменФайловДляПропуска,
+ СтандартнаяОбработка);
Если СтандартнаяОбработка Тогда
@@ -630,7 +625,7 @@
Если СтандартнаяОбработка Тогда
ПереместитьВКаталогРабочейКопииСтандартнаяОбработка(КаталогРабочейКопии,
- КаталогВыгрузки);
+ КаталогВыгрузки);
КонецЕсли;
@@ -646,7 +641,7 @@
// КаталогВыгрузки - Строка - полный путь к каталогу выгрузки
//
Процедура ПереместитьВКаталогРабочейКопииСтандартнаяОбработка(Знач КаталогРабочейКопии,
- Знач КаталогВыгрузки)
+ Знач КаталогВыгрузки)
СписокФайлов = НайтиФайлы(КаталогВыгрузки, ПолучитьМаскуВсеФайлы(), Истина);
Лог.Отладка("Найдено файлов выгрузки: %1 шт.", СписокФайлов.Количество());
@@ -718,6 +713,13 @@
КаталогСборки = ВременныеФайлы.СоздатьКаталог();
УправлениеКонфигуратором.КаталогСборки(КаталогСборки);
+ Если ЗначениеЗаполнено(КонтекстВыполнения.СтрокаСоединения) Тогда
+
+ Лог.Отладка("Для синхронизации используется база <%1>", КонтекстВыполнения.СтрокаСоединения);
+ УправлениеКонфигуратором.УстановитьКонтекст(КонтекстВыполнения.СтрокаСоединения, КонтекстВыполнения.Пользователь, КонтекстВыполнения.Пароль);
+
+ КонецЕсли;
+
Если ЗначениеЗаполнено(ТекущийПутьКПлатформе) Тогда
Если Не ФС.ФайлСуществует(ТекущийПутьКПлатформе) Тогда
@@ -730,7 +732,7 @@
Лог.Информация("Используется путь к платформе 1С <%1>", ТекущийПутьКПлатформе);
Иначе
УправлениеКонфигуратором.ИспользоватьВерсиюПлатформы(ТекущаяВерсияПлатформы);
- Лог.Отладка("Используется платформа 1С версии <%1>", ТекущийПутьКПлатформе);
+ Лог.Отладка("Используется платформа 1С версии <%1>", ТекущаяВерсияПлатформы);
КонецЕсли;
Возврат УправлениеКонфигуратором;
@@ -836,6 +838,7 @@
//
// Параметры:
// ПутьКХранилищу - Строка - путь к хранилищу 1С
+// НачальнаяВерсия - Число - номер начальной версии хранилища
//
// Возвращаемое значение:
// ТаблицаВерсий - ТаблицаЗначений - инициализированная таблица с колонками:
@@ -847,13 +850,17 @@
// * ГУИД_Автора - Строка - уникальный идентификатор автора версии
// * ПредставлениеАвтора - Строка - представление автора для коммита в git
//
-Функция ПрочитатьТаблицуИсторииХранилища(Знач ПутьКХранилищу) Экспорт
+Функция ПрочитатьТаблицуИсторииХранилища(Знач ПутьКХранилищу, Знач НачальнаяВерсия = 1) Экспорт
СтандартнаяОбработка = Истина;
+ Если НачальнаяВерсия = Неопределено Тогда
+ НачальнаяВерсия = 1;
+ КонецЕсли;
+
ТаблицаВерсий = НоваяТаблицаИсторииВерсий();
- ОбработчикПодписок.ПриПолученииТаблицыВерсий(ТаблицаВерсий, ПутьКХранилищу, СтандартнаяОбработка);
+ ОбработчикПодписок.ПриПолученииТаблицыВерсий(ТаблицаВерсий, ПутьКХранилищу, НачальнаяВерсия, СтандартнаяОбработка);
Если СтандартнаяОбработка Тогда
@@ -861,6 +868,12 @@
Если ХранилищеКонфигурации = Неопределено Тогда
ХранилищеКонфигурации = ПолучитьХранилищеКонфигурации(ПутьКХранилищу);
КонецЕсли;
+
+ Если Не ХранилищеКонфигурации.ЧтениеХранилищаВыполнено() Тогда
+
+ ХранилищеКонфигурации.ПрочитатьХранилище(НачальнаяВерсия);
+
+ КонецЕсли;
ТаблицаВерсийХранилища = ХранилищеКонфигурации.ПолучитьТаблицуВерсий();
@@ -903,6 +916,7 @@
//
// Параметры:
// ПутьКХранилищу - Строка - путь к хранилищу 1С
+// НачальнаяВерсия - Число - номер начальной версии хранилища
//
// Возвращаемое значение:
// ТаблицаЗначений - таблица пользователей с колонками
@@ -910,12 +924,16 @@
// * ПредставлениеАвтора - Строка - представление автора для коммита в git
// * ГУИД_Автора - Строка - уникальный идентификатор автора версии
//
-Функция ПрочитатьТаблицуПользователейХранилища(Знач ПутьКХранилищу) Экспорт
+Функция ПрочитатьТаблицуПользователейХранилища(Знач ПутьКХранилищу, Знач НачальнаяВерсия = 1) Экспорт
СтандартнаяОбработка = Истина;
ТаблицаПользователей = НоваяТаблицаПользователейХранилища();
+ Если НачальнаяВерсия = Неопределено Тогда
+ НачальнаяВерсия = 1;
+ КонецЕсли;
+
ОбработчикПодписок.ПриПолученииТаблицыПользователей(ТаблицаПользователей, ПутьКХранилищу, СтандартнаяОбработка);
Если СтандартнаяОбработка Тогда
@@ -923,7 +941,13 @@
Если ХранилищеКонфигурации = Неопределено Тогда
ХранилищеКонфигурации = ПолучитьХранилищеКонфигурации(ПутьКХранилищу);
КонецЕсли;
+
+ Если Не ХранилищеКонфигурации.ЧтениеХранилищаВыполнено() Тогда
+
+ ХранилищеКонфигурации.ПрочитатьХранилище(НачальнаяВерсия);
+ КонецЕсли;
+
МассивАвторовХранилища = ХранилищеКонфигурации.ПолучитьАвторов();
Для Каждого Автор Из МассивАвторовХранилища Цикл
@@ -946,6 +970,7 @@
//
// Параметры:
// ПутьКХранилищу - Строка - путь к хранилищу 1С
+// ТекущаяВерсия - Число - номер версии откуда начинать чтение
//
// Возвращаемое значение:
// ТаблицаВерсий - ТаблицаЗначений - инициализированная таблица с колонками:
@@ -957,10 +982,10 @@
// * ГУИД_Автора - Строка - уникальный идентификатор автора версии
// * ПредставлениеАвтора - Строка - представление автора для коммита в git
//
-Функция ПрочитатьИзХранилищаИсториюКоммитовСАвторами(Знач ПутьКХранилищу) Экспорт
+Функция ПрочитатьИзХранилищаИсториюКоммитовСАвторами(Знач ПутьКХранилищу, Знач НачальнаяВерсия = 1) Экспорт
- ТаблицаВерсий = ПрочитатьТаблицуИсторииХранилища(ПутьКХранилищу);
- ТаблицаПользователей = ПрочитатьТаблицуПользователейХранилища(ПутьКХранилищу);
+ ТаблицаВерсий = ПрочитатьТаблицуИсторииХранилища(ПутьКХранилищу, НачальнаяВерсия);
+ ТаблицаПользователей = ПрочитатьТаблицуПользователейХранилища(ПутьКХранилищу, НачальнаяВерсия);
ДополнитьТаблицуВерсийИменамиАвторов(ТаблицаВерсий, ТаблицаПользователей);
ТаблицаВерсий.Сортировать("НомерВерсии");
@@ -976,17 +1001,19 @@
// КаталогРабочейКопии - Строка - путь к каталогу рабочей копии git
//
Процедура ДополнитьТаблицуХранилищаИнформациейОСигнатуреПользователяВГит(Знач ТаблицаХранилища,
- Знач КаталогРабочейКопии) Экспорт
+ Знач КаталогРабочейКопии) Экспорт
ПутьКФайлуСопоставления = ОбъединитьПути(КаталогРабочейКопии, ИмяФайлаАвторов());
- ТаблицаСопоставления = ПрочитатьФайлАвторовГитВТаблицуПользователей(ПутьКФайлуСопоставления);
+
+ ТаблицаСопоставления = ПолучитьТаблицуАвторов(ПутьКФайлуСопоставления);
+
Для Каждого СтрокаТаблицы Из ТаблицаХранилища Цикл
СтрокаПользователя = ТаблицаСопоставления.Найти(СтрокаТаблицы.Автор, "Автор");
Если СтрокаПользователя = Неопределено Тогда
ПредставлениеАвтора = СтрШаблон("%1 <%1@%2>", СтрокаТаблицы.Автор, Строка(ДоменПочтыДляGit()));
Иначе
- ПредставлениеАвтора = строкаПользователя.ПредставлениеАвтора;
+ ПредставлениеАвтора = СтрокаПользователя.ПредставлениеАвтора;
КонецЕсли;
СтрокаТаблицы.ПредставлениеАвтора = ПредставлениеАвтора;
@@ -1026,7 +1053,7 @@
КонецПроцедуры
-// Читает файл авторов и возвращает таблицу пользователей
+// Получает таблицу авторов из файла
//
// Параметры:
// ПутьКФайлуАвторов - Строка - путь к файлу авторов
@@ -1035,52 +1062,68 @@
// ТаблицаЗначений - таблица пользователей с колонками
// * Автор - Строка - имя автора версии в хранилище
// * ПредставлениеАвтора - Строка - представление автора для коммита в git
-// * ГУИД_Автора - Строка - уникальный идентификатор автора версии
//
-Функция ПрочитатьФайлАвторовГитВТаблицуПользователей(Знач ПутьКФайлуАвторов) Экспорт
+Функция ПолучитьТаблицуАвторов(Знач ПутьКФайлуАвторов) Экспорт
- Если НЕ ЗначениеЗаполнено(ПутьКФайлуАвторов) Тогда
- Возврат Неопределено;
+ СтандартнаяОбработка = Истина;
+
+ ТаблицаАвторов = НоваяТаблицаАвторов();
+
+ ОбработчикПодписок.ПриПолученииТаблицыАвторов(ПутьКФайлуАвторов, ТаблицаАвторов, СтандартнаяОбработка);
+
+ Если СтандартнаяОбработка Тогда
+ ПрочитатьФайлАвторов(ПутьКФайлуАвторов, ТаблицаАвторов);
КонецЕсли;
+ ОбработчикПодписок.ПослеПолученияТаблицыАвторов(ПутьКФайлуАвторов, ТаблицаАвторов);
+
+ Возврат ТаблицаАвторов;
+
+КонецФункции
+
+Процедура ПрочитатьФайлАвторов(ПутьКФайлуАвторов, ТаблицаАвторов)
+
+ Если НЕ ЗначениеЗаполнено(ПутьКФайлуАвторов) Тогда
+ Возврат;
+ КонецЕсли;
+
Файл = Новый Файл(ПутьКФайлуАвторов);
Если Не Файл.Существует() Тогда
- Возврат НоваяТаблицаПользователейХранилища();
+ Возврат;
КонецЕсли;
+
+ ТекстовыйФайл = Новый ЧтениеТекста(ПутьКФайлуАвторов, "utf-8");
+ ТекстФайла = ТекстовыйФайл.Прочитать();
- Пользователи = НоваяТаблицаПользователейХранилища();
-
- Попытка
- ТекстовыйФайл = Новый ЧтениеТекста(ПутьКФайлуАвторов, "utf-8");
- СтрокаФайла = "";
- Пока СтрокаФайла <> Неопределено Цикл
- СтрокаФайла = ТекстовыйФайл.ПрочитатьСтроку();
- Индекс = Найти(СтрокаФайла, "=");
- Если Индекс > 0 Тогда
-
- Ключ = Лев(СтрокаФайла, Индекс - 1);
- АвторПредставление = Сред(СтрокаФайла, Индекс + 1);
-
- НоваяСтрока = Пользователи.Добавить();
- НоваяСтрока.ПредставлениеАвтора = АвторПредставление;
- НоваяСтрока.Автор = Ключ;
- КонецЕсли;
- КонецЦикла;
-
- Исключение
- Если ТекстовыйФайл <> Неопределено Тогда
- ОсвободитьОбъект(ТекстовыйФайл);
+ МассивСтрокФайла = СтрРазделить(ТекстФайла, Символы.ПС, Ложь);
+
+ Для каждого СтрокаФайла Из МассивСтрокФайла Цикл
+
+ Если СтрНачинаетсяС(СокрЛП(СтрокаФайла), "//") Тогда
+ Продолжить;
КонецЕсли;
- ВызватьИсключение;
- КонецПопытки;
-
+
+ МассивКлючей = СтрРазделить(СтрокаФайла, "=", Ложь);
+
+ Если Не МассивКлючей.Количество() = 2 Тогда
+ Лог.Предупреждение("Ошибка чтения файла авторов строка <%1>", СтрокаФайла);
+ Продолжить;
+ КонецЕсли;
+
+ НоваяСтрока = ТаблицаАвторов.Добавить();
+ НоваяСтрока.Автор = СокрЛП(МассивКлючей[0]);
+ НоваяСтрока.ПредставлениеАвтора = СокрЛП(МассивКлючей[1]);
+
+ КонецЦикла;
+
+ ТекстовыйФайл.Закрыть();
+
Если ТекстовыйФайл <> Неопределено Тогда
ОсвободитьОбъект(ТекстовыйФайл);
КонецЕсли;
-
- Возврат Пользователи;
-
-КонецФункции
+
+КонецПроцедуры
+
// Наполняет каталог рабочей копии служебными данными
//
@@ -1206,13 +1249,34 @@
КонецПроцедуры
+Функция МассивИсключаемыхОшибок()
+
+ Массив = Новый Массив;
+ Массив.Добавить("Конфигурация содержит объекты метаданных, длина имен которых превышает 80 символов!");
+
+ Возврат Массив;
+КонецФункции
+
+Функция ЭтоПропускаемаяОшибка(Знач ОписаниеОшибки)
+
+ МассивИсключаемыхОшибок = МассивИсключаемыхОшибок();
+
+ Для Каждого ИсключаемаяОшибка Из МассивИсключаемыхОшибок Цикл
+
+ Если СтрНайти(ОписаниеОшибки, ИсключаемаяОшибка) > 0 Тогда
+ Возврат Истина;
+ КонецЕсли;
+
+ КонецЦикла;
+ Возврат Ложь;
+КонецФункции
+
Процедура СоздатьРасширениеВБазе(УправлениеКонфигуратором)
Параметры = УправлениеКонфигуратором.ПолучитьПараметрыЗапуска();
- ФайлИсточника = Новый Файл(ТекущийСценарий().Источник);
- ПутьКИнструменту = Новый Файл(ОбъединитьПути(ФайлИсточника.Путь, "../../../")).ПолноеИмя;
- ПутьКШаблонуРасширения = ОбъединитьПути(ПутьКИнструменту, "./templates/temp.cfe");
- Параметры.Добавить("/LoadCfg " + """" + ПутьКШаблонуРасширения + """");
+ ЗагрузчикЗапакованныхФайловGitsync = Новый ЗагрузчикЗапакованныхФайловGitsync;
+ ПутьКШаблонуРасширения = ЗагрузчикЗапакованныхФайловGitsync.ПолучитьПутьКФайлу("tempExtension.cfe");
+ Параметры.Добавить(СтрШаблон("/LoadCfg ""%1""", ПутьКШаблонуРасширения));
Параметры.Добавить(СтрШаблон("-Extension %1", ИмяРасширения));
УправлениеКонфигуратором.ВыполнитьКоманду(Параметры);
@@ -1235,7 +1299,6 @@
КонецЕсли;
Логирование.ПолучитьЛог("oscript.lib.v8storage").УстановитьУровень(Лог.Уровень());
- Сообщить("Пользователь " + АвторизацияВХранилище.ПользовательХранилища);
ПроверитьПараметрыДоступаКХранилищу();
МенеджерХранилищаКонфигурации.УстановитьПараметрыАвторизации(АвторизацияВХранилище.ПользовательХранилища, АвторизацияВХранилище.ПарольХранилища);
МенеджерХранилищаКонфигурации.УстановитьПутьКХранилищу(ПутьКХранилищу);
@@ -1255,6 +1318,16 @@
КонецФункции
+Функция НоваяТаблицаАвторов()
+
+ Таблица = Новый ТаблицаЗначений;
+ Таблица.Колонки.Добавить("Автор");
+ Таблица.Колонки.Добавить("ПредставлениеАвтора");
+
+ Возврат Таблица;
+
+КонецФункции
+
Функция ПодготовитьФайлКоммита(Знач Комментарий)
ИмяФайлаКомментария = ВременныеФайлы.СоздатьФайл("txt");
@@ -1437,7 +1510,6 @@
Процедура УстановитьОбработчикПодписок(НовыйИндексПодписчиков)
ОбработчикПодписок.УстановитьПодписчиков(НовыйИндексПодписчиков);
-
ОбработчикПодписок.ПриАктивизации(ЭтотОбъект);
КонецПроцедуры
@@ -1491,6 +1563,12 @@
КонецПроцедуры
+Процедура ПоказатьКонтекстВРежимеОтладки()
+ Лог.Отладка("СтрокаСоединения <%1>", КонтекстВыполнения.СтрокаСоединения);
+ Лог.Отладка("Пользователь <%1>", КонтекстВыполнения.Пользователь);
+ Лог.Отладка(?(ПустаяСтрока(КонтекстВыполнения.Пароль), "Пароль не задан", СтрШаблон("Задан пароль <%1>", КонтекстВыполнения.Пароль)));
+КонецПроцедуры
+
Функция ФорматДвузначноеЧисло(ЗначениеЧисло)
ЧислоСтрокой = Строка(ЗначениеЧисло);
Если СтрДлина(ЧислоСтрокой) < 2 Тогда
@@ -1520,6 +1598,8 @@
ЭтоWindows = Найти(НРег(СистемнаяИнформация.ВерсияОС), "windows") > 0;
ТекущаяВерсияПлатформы = "8.3";
+
+ КонтекстВыполнения = Новый Структура("СтрокаСоединения, Пользователь, Пароль", "", "", "");
КонецПроцедуры
diff --git "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\260\320\272\320\265\321\202\320\275\320\260\321\217\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\321\217.os" "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\260\320\272\320\265\321\202\320\275\320\260\321\217\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\321\217.os"
index af3ef44e..9befb0f0 100644
--- "a/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\260\320\272\320\265\321\202\320\275\320\260\321\217\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\321\217.os"
+++ "b/src/core/\320\232\320\273\320\260\321\201\321\201\321\213/\320\237\320\260\320\272\320\265\321\202\320\275\320\260\321\217\320\241\320\270\320\275\321\205\321\200\320\276\320\275\320\270\320\267\320\260\321\206\320\270\321\217.os"
@@ -11,8 +11,8 @@
///////////////////////////////////////////////////////////////////////////////////////////////
// ПРОГРАММНЫЙ ИНТЕРФЕЙС
-Перем ДоменПочтыДляGitПоУмолчанию Экспорт; // Строка, домен пользователей по умолчанию
-Перем ТекущаяВерсияПлатформы Экспорт; // Строка, используемая версия 1С.Предприятие
+Перем ДоменПочтыДляGitПоУмолчанию; // Строка, домен пользователей по умолчанию
+Перем ТекущаяВерсияПлатформы; // Строка, используемая версия 1С.Предприятие
Перем ТаймерПовторения;
Перем ПутьКФайлуНастроек;
@@ -21,7 +21,8 @@
Перем ПутьКВременномуКаталогу;
Перем ИндексРепозиториев;
-Перем Параметры;
+Перем НастройкиПоУмолчанию;
+Перем РепозиторииСинхронизации;
#Область Публичное_API
@@ -134,19 +135,43 @@
КонецФункции
-// Устанавливает путь к файлу настроек пакетной синхронизации
+// Устанавливает путь к платформе 1С
//
// Параметры:
-// НовыйПутьКФайлуНастроек - Строка - путь к настроек пакетной синхронизации
+// НовыйПутьКПлатформе - Строка - путь к исполняемому файлу платформы 1С.Предприятие
//
// Возвращаемое значение:
// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
//
-Функция УстановитьНастройки(НовыйПутьКФайлуНастроек) Экспорт
- ПутьКФайлуНастроек = НовыйПутьКФайлуНастроек;
+Функция ПутьКПлатформе(Знач НовыйПутьКПлатформе) Экспорт
+
+ ТекущийПутьКПлатформе = НовыйПутьКПлатформе;
Возврат ЭтотОбъект;
+
КонецФункции
+// Читает настройки пакетной синхронизации из соответствия
+//
+// Параметры:
+// НастройкиСинхронизации - Соответствие - набор настроек для пакетной синхронизации
+//
+Процедура ПрочитатьНастройки(Знач НастройкиСинхронизации) Экспорт
+
+ Лог.Отладка("Количество настроек <%1>", НастройкиСинхронизации.Количество());
+
+ КонструкторПараметров = КонструкторПараметровПакетнойСинхронизации();
+ КонструкторПараметров.ИзСоответствия(НастройкиСинхронизации);
+
+ Параметры = КонструкторПараметров.ВСтруктуру();
+
+ НастройкиПоУмолчанию = Параметры.НастройкиПоУмолчанию;
+
+ ДополнитьНастройкиПоУмолчания();
+
+ РепозиторииСинхронизации = Параметры.Репозитории;
+
+КонецПроцедуры
+
// Устанавливает таймер повторения пакетной синхронизации
//
// Параметры:
@@ -173,23 +198,12 @@
Возврат ЭтотОбъект;
КонецФункции
-// Устанавливает путь к файлу включенных плагинов
-//
-// Параметры:
-// НовыйПутьКФайлуВключенныхПлагинов - Строка - путь к файлу включенных плагинов
-//
-// Возвращаемое значение:
-// Объект.МенеджерСинхронизации - ссылка на текущий объект класса <МенеджерСинхронизации>
-//
-Функция ФайлВключенныхПлагинов(Знач НовыйПутьКФайлуВключенныхПлагинов) Экспорт
- ПутьКФайлуВключенныхПлагинов = НовыйПутьКФайлуВключенныхПлагинов;
- Возврат ЭтотОбъект;
-КонецФункции
-
// Выполняет пакетную синхронизацию
//
-Процедура ВыполнитьСинхронизацию() Экспорт
+Процедура ВыполнитьСинхронизацию(Знач КоличествоПотоков = 1) Экспорт
+ ПодготовитьИндексРепозиториев();
+
Пока Истина Цикл
ПакетнаяСинхронизация();
@@ -209,87 +223,107 @@
КонецПроцедуры
-#КонецОбласти
+// Выполняет пакетную синхронизацию
+//
+Процедура ВыполнитьСинхронизациюПоНастройке(Знач ИмяНастройкиСинхронизации) Экспорт
+
+ ПодготовитьИндексРепозиториев();
-Процедура ПрочитатьФайлНастроек()
+ Пока Истина Цикл
- МенеджерПараметров = Новый МенеджерПараметров();
- МенеджерПараметров.УстановитьФайлПараметров(ПутьКФайлуНастроек);
- МенеджерПараметров.ИспользоватьПровайдерJSON();
- МенеджерПараметров.ИспользоватьПровайдерYAML();
- МенеджерПараметров.КонструкторПараметров(ЭтотОбъект);
- Лог.Отладка("Чтение файла настроек начато");
- МенеджерПараметров.Прочитать();
- Лог.Отладка("Чтение файла настроек завершено");
+ РепоСинхронизации = ИндексРепозиториев[ИмяНастройкиСинхронизации];
+
+ Если РепоСинхронизации = Неопределено Тогда
+ Лог.Информация("Не найдена или отключена настройка синхронизации <%1>", ИмяНастройкиСинхронизации);
+ Прервать;
+ КонецЕсли;
-КонецПроцедуры
+ Лог.Информация("Начата синхронизация с репозиторием <%1> ", ИмяНастройкиСинхронизации);
-#Область Интерфейс_конструктора_параметров
+ РепоСинхронизации.Синхронизировать();
-Функция Параметры() Экспорт
- Возврат Параметры;
-КонецФункции
+ Если ТаймерПовторения <= 0 Тогда
+
+ Прервать;
+
+ Иначе
+
+ Лог.Информация("Ожидаем <%1> секунд перед новым циклом", ТаймерПовторения);
+ Приостановить(ТаймерПовторения * 1000);
+
+ КонецЕсли;
+
+ КонецЦикла;
-Процедура УстановитьПараметры(Знач ВходящиеПараметры) Экспорт
- Параметры = ВходящиеПараметры;
КонецПроцедуры
-Процедура ОписаниеПараметров(Знач Конструктор) Экспорт
+#КонецОбласти
+
+#Область Интерфейс_конструктора_параметров
- ПараметрыПлагины = Конструктор.НовыеПараметры();
+Функция КонструкторОбщихПараметров()
+
+ ПараметрыПлагины = Новый КонструкторПараметров();
ПараметрыПлагины.ПолеМассив("ВключенныеПлагины enable", Тип("Строка"))
.ПолеМассив("ОтключенныеПлагины disable", Тип("Строка"))
+ .ПолеМассив("ДополнительныеПлагины extra additional more", Тип("Строка"))
;
- ПараметрыНастроекПлагинов = Конструктор.НовыеПараметры();
+ ПараметрыНастроекПлагинов = Новый КонструкторПараметров();
ПараметрыНастроекПлагинов.ПроизвольныеПоля();
- ГлобальныеПараметры = Конструктор.НовыеПараметры();
- ГлобальныеПараметры.ПолеСтрока("ПользовательХранилища storage-user user", АвторизацияВХранилище.ПользовательХранилища)
- .ПолеСтрока("ПарольПользователяХранилища storage-pwd storage-password password pwd", АвторизацияВХранилище.ПарольХранилища)
- .ПолеСтрока("ПутьИсполняемомуФайлуГит git-path git", ПутьКИсполняемомуФайлуGit)
- .ПолеСтрока("ПутьКВременномуКаталогу temp-dir tempdir temp", ПутьКВременномуКаталогу)
- .ПолеСтрока("ВерсияПлатформы v8version v8", ТекущаяВерсияПлатформы)
- .ПолеСтрока("ДоменПочтыПоУмолчанию domain-email email", ДоменПочтыДляGitПоУмолчанию)
- .ПолеЧисло("КоличествоЦикловОжиданияЛицензии lic-try-count", КоличествоЦикловОжиданияЛицензииПоУмолчанию)
+ КонструкторПараметров = Новый КонструкторПараметров();
+
+ КонструкторПараметров.ПолеСтрока("ПользовательХранилища storage-user user")
+ .ПолеСтрока("ПарольПользователяХранилища storage-pwd storage-password password pwd")
+ .ПолеСтрока("ПутьИсполняемомуФайлуГит git-path git")
+ .ПолеСтрока("ПутьКВременномуКаталогу temp-dir tempdir temp")
+ .ПолеСтрока("ВерсияПлатформы v8version v8")
+ .ПолеСтрока("ДоменПочтыПоУмолчанию domain-email email")
+ .ПолеЧисло("КоличествоЦикловОжиданияЛицензии lic-try-count")
.ПолеОбъект("Плагины plugins", ПараметрыПлагины)
.ПолеОбъект("НастройкиПлагинов plugins-config flags", ПараметрыНастроекПлагинов)
;
- ПараметрыПлагиныРепозитория = ПараметрыПлагины.Скопировать();
- ПараметрыПлагиныРепозитория.ПолеМассив("ДополнительныеПлагины extra additional more", Тип("Строка"));
+ Возврат КонструкторПараметров;
- ПараметрыРепозитория = Конструктор.НовыеПараметры();
- ПараметрыРепозитория.ПолеБулево("Отключено disable", Ложь)
+КонецФункции
+
+Функция КонструкторПараметровРепозитория()
+
+ КонструкторПараметров = КонструкторОбщихПараметров();
+
+ КонструкторПараметров.ПолеБулево("Отключено disable", Ложь)
.ПолеСтрока("Наименование storage-name name")
.ПолеСтрока("ПутьКХранилищу storage-path path")
.ПолеСтрока("ПутьКРабочемуКаталогу work-dir git-local-path dir")
- // Стандартные поля
- .ПолеСтрока("ПользовательХранилища storage-user user")
- .ПолеСтрока("ПарольПользователяХранилища storage-pwd storage-password password pass")
- .ПолеСтрока("ПутьИсполняемомуФайлуГит git-path git")
- .ПолеСтрока("ПутьКВременномуКаталогу temp-dir tempdir temp")
- .ПолеСтрока("ВерсияПлатформы v8version v8")
- .ПолеСтрока("ДоменПочтыПоУмолчанию domain-email email")
- .ПолеЧисло("КоличествоЦикловОжиданияЛицензии lic-try-count", КоличествоЦикловОжиданияЛицензииПоУмолчанию)
- .ПолеОбъект("Плагины plugins", ПараметрыПлагиныРепозитория)
- .ПолеОбъект("НастройкиПлагинов plugins-config flags", ПараметрыНастроекПлагинов)
+ .ПолеСтрока("ИмяРасширения extention")
;
- Конструктор.ПолеОбъект("НастройкиПоУмолчанию globals default", ГлобальныеПараметры)
+ Возврат КонструкторПараметров;
+
+КонецФункции
+
+Функция КонструкторПараметровПакетнойСинхронизации() Экспорт
+
+ КонструкторПараметров = Новый КонструкторПараметров();
+
+ ОбщиеПараметры = КонструкторОбщихПараметров();
+ ПараметрыРепозитория = КонструкторПараметровРепозитория();
+
+ КонструкторПараметров.ПолеОбъект("НастройкиПоУмолчанию globals default", ОбщиеПараметры)
.ПолеМассив("Репозитории repositories", ПараметрыРепозитория)
;
+
+ Возврат КонструкторПараметров;
-КонецПроцедуры
+КонецФункции
+
#КонецОбласти
Процедура ПакетнаяСинхронизация()
- ПрочитатьФайлНастроек();
-
- ПодготовитьИндексРепозиториев();
-
Лог.Информация("Начата пакетная синхронизация с <%1> репозиториями", ИндексРепозиториев.Количество());
Для каждого КлючЗначение Из ИндексРепозиториев Цикл
@@ -303,34 +337,21 @@
Процедура ПодготовитьИндексРепозиториев()
- Лог.Отладка("Готовлю индекс для <%1> репозиториев", Параметры.Репозитории.Количество());
- Для каждого ПараметрыРепозитория Из Параметры.Репозитории Цикл
+ ИндексРепозиториев = Новый Соответствие();
- РепоСинхронизации = ИндексРепозиториев[ПараметрыРепозитория.Наименование];
- ОтключенныйРепозиторий = ПараметрыРепозитория.Отключено;
+ Лог.Отладка("Готовлю индекс для <%1> репозиториев", РепозиторииСинхронизации.Количество());
+ Для каждого ПараметрыРепозитория Из РепозиторииСинхронизации Цикл
- Если ОтключенныйРепозиторий
- И НЕ РепоСинхронизации = Неопределено Тогда
- ИндексРепозиториев.Удалить(РепоСинхронизации);
- КонецЕсли;
- Если ОтключенныйРепозиторий Тогда
- Продолжить;
- КонецЕсли;
-
- Если РепоСинхронизации = Неопределено Тогда
-
- РепоСинхронизации = Новый РепозиторийСинхронизации();
- РепоСинхронизации.КаталогПлагинов(КаталогПлагинов)
- .ФайлВключенныхПлагинов(ПутьКФайлуВключенныхПлагинов)
- // .УровеньЛога(Лог.ПолучитьУровеньЛога())
- ;
-
- ИндексРепозиториев.Вставить(ПараметрыРепозитория.Наименование, РепоСинхронизации);
-
- КонецЕсли;
+ РепоСинхронизации = Новый РепозиторийСинхронизации();
+ РепоСинхронизации.КаталогПлагинов(КаталогПлагинов)
+ // .ФайлВключенныхПлагинов(ПутьКФайлуВключенныхПлагинов)
+ // .УровеньЛога(Лог.ПолучитьУровеньЛога())
+ ;
+
+ ИндексРепозиториев.Вставить(ПараметрыРепозитория.Наименование, РепоСинхронизации);
- ОбъединитьПараметрыРепозиторияИГлобальные(ПараметрыРепозитория);
+ ДополнитьПараметрыРепозитория(ПараметрыРепозитория);
РепоСинхронизации.ПрочитатьПараметры(ПараметрыРепозитория);
@@ -338,35 +359,69 @@
КонецПроцедуры
-Процедура ОбъединитьПараметрыРепозиторияИГлобальные(ПараметрыРепозитория)
+Процедура ДополнитьНастройкиПоУмолчания()
+
+ Если ЗначениеЗаполнено(АвторизацияВХранилище.ПользовательХранилища) Тогда
+ НастройкиПоУмолчанию.Вставить("ПользовательХранилища", АвторизацияВХранилище.ПользовательХранилища);
+ НастройкиПоУмолчанию.Вставить("ПарольПользователяХранилища", АвторизацияВХранилище.ПарольПользователяХранилища);
+ КонецЕсли;
- ГлобальныеПараметры = Параметры.НастройкиПоУмолчанию;
+ ЗаполнитьПриемникПриНеобходимости("ПутьИсполняемомуФайлуГит", ПутьКИсполняемомуФайлуGit, НастройкиПоУмолчанию);
+ ЗаполнитьПриемникПриНеобходимости("ПутьКВременномуКаталогу", ПутьКВременномуКаталогу, НастройкиПоУмолчанию);
+ ЗаполнитьПриемникПриНеобходимости("ВерсияПлатформы", ТекущаяВерсияПлатформы, НастройкиПоУмолчанию);
+ ЗаполнитьПриемникПриНеобходимости("ДоменПочтыПоУмолчанию", ДоменПочтыДляGitПоУмолчанию, НастройкиПоУмолчанию);
+ ЗаполнитьПриемникПриНеобходимости("КоличествоЦикловОжиданияЛицензии", КоличествоЦикловОжиданияЛицензииПоУмолчанию, НастройкиПоУмолчанию);
- Для каждого ГлобальныйПараметр Из ГлобальныеПараметры Цикл
-
- КлючПараметра = ГлобальныйПараметр.Ключ;
- ЗначениеПараметра = ГлобальныйПараметр.Значение;
+КонецПроцедуры
- Если Не ЗначениеЗаполнено(ЗначениеПараметра) Тогда
- Продолжить;
- КонецЕсли;
+Процедура ДополнитьПараметрыРепозитория(ПараметрыРепозитория)
- ЗначениеИзПараметровРепо = ПараметрыРепозитория[КлючПараметра];
+ ГлобальныеПараметры = НастройкиПоУмолчанию;
- Если КлючПараметра = "Плагины" Тогда
- ОбъединитьПлагины(ЗначениеПараметра, ЗначениеИзПараметровРепо);
- Продолжить;
- ИначеЕсли КлючПараметра = "НастройкиПлагинов" Тогда
- Лог.Отладка("Тип значения настройки плагинов <%1>", ТипЗнч(ЗначениеИзПараметровРепо));
- ОбъединитьНастройкиПлагинов(ЗначениеПараметра, ЗначениеИзПараметровРепо);
- Продолжить;
- КонецЕсли;
+ ЗаполнитьПриНеобходимости("ПользовательХранилища", ГлобальныеПараметры, ПараметрыРепозитория);
+ ЗаполнитьПриНеобходимости("ПарольПользователяХранилища", ГлобальныеПараметры, ПараметрыРепозитория);
+ ЗаполнитьПриНеобходимости("ПутьИсполняемомуФайлуГит", ГлобальныеПараметры, ПараметрыРепозитория);
+ ЗаполнитьПриНеобходимости("ПутьКВременномуКаталогу", ГлобальныеПараметры, ПараметрыРепозитория);
+ ЗаполнитьПриНеобходимости("ВерсияПлатформы", ГлобальныеПараметры, ПараметрыРепозитория);
+ ЗаполнитьПриНеобходимости("ДоменПочтыПоУмолчанию", ГлобальныеПараметры, ПараметрыРепозитория);
+ ЗаполнитьПриНеобходимости("КоличествоЦикловОжиданияЛицензии", ГлобальныеПараметры, ПараметрыРепозитория);
- Если Не ЗначениеЗаполнено(ЗначениеИзПараметровРепо) Тогда
- ПараметрыРепозитория.Вставить(КлючПараметра, ЗначениеПараметра);
- КонецЕсли;
+ ОбъединитьПлагины(ГлобальныеПараметры.Плагины, ПараметрыРепозитория.Плагины);
+ ОбъединитьНастройкиПлагинов(ГлобальныеПараметры.НастройкиПлагинов, ПараметрыРепозитория.НастройкиПлагинов);
- КонецЦикла;
+КонецПроцедуры
+
+Процедура ЗаполнитьПриемникПриНеобходимости(Ключ, Значение, Приемник)
+
+ Если Не ЗначениеЗаполнено(Значение) Тогда
+ Возврат;
+ КонецЕсли;
+
+ ЗначениеПриемник = Приемник[Ключ];
+
+ Если ЗначениеЗаполнено(ЗначениеПриемник) Тогда
+ Возврат;
+ КонецЕсли;
+
+ Приемник.Вставить(Ключ, Значение);
+
+КонецПроцедуры
+
+Процедура ЗаполнитьПриНеобходимости(КлючНастройки, Источник, Приемник)
+
+ ЗначениеИсточник = Источник[КлючНастройки];
+
+ Если Не ЗначениеЗаполнено(ЗначениеИсточник) Тогда
+ Возврат;
+ КонецЕсли;
+
+ ЗначениеПриемник = Приемник[КлючНастройки];
+
+ Если ЗначениеЗаполнено(ЗначениеПриемник) Тогда
+ Возврат;
+ КонецЕсли;
+
+ Приемник.Вставить(КлючНастройки, ЗначениеИсточник);
КонецПроцедуры
@@ -388,9 +443,13 @@
КонецЕсли;
ЗначениеНастройкиИзРепозитория = ПолучитьЗначениеПоКлючу(НастройкиПлагиновРепозитория, КлючНастройки);
+ Лог.Отладка("Ключа <%1> значение из репозитория <%2>", КлючНастройки, ЗначениеНастройкиИзРепозитория);
Если ЗначениеНастройкиИзРепозитория = Неопределено Тогда
+
+ Лог.Отладка("Устанавливаю ключ настройки <%1> в значение <%2>", КлючНастройки, ЗначениеНастройки);
НастройкиПлагиновРепозитория.Вставить(КлючНастройки, ЗначениеНастройки);
+
КонецЕсли;
КонецЦикла;
diff --git a/tasks/get-plugins.os b/tasks/get-plugins.os
index e75a354d..021670d0 100644
--- a/tasks/get-plugins.os
+++ b/tasks/get-plugins.os
@@ -46,6 +46,8 @@
ФС.ОбеспечитьКаталог(КаталогПроекта);
+ УдалитьФайлы(КаталогПроекта, "gitsync-plugins*.ospx");
+
ФайлПриемник = ОбъединитьПути(КаталогПроекта, МассивФайлов[0].Имя);
КопироватьФайл(ФайлПлагина, ФайлПриемник);
diff --git a/tasks/get-v8storage.os b/tasks/get-v8storage.os
deleted file mode 100644
index 7f17775c..00000000
--- a/tasks/get-v8storage.os
+++ /dev/null
@@ -1,92 +0,0 @@
-#Использовать gitrunner
-#Использовать tempfiles
-#Использовать fs
-
-Перем Лог;
-
-Процедура ПолучитьИсходники(Знач URLРепозитория, Знач Ветка, Знач Каталог)
-
- ГитРепозиторий = Новый ГитРепозиторий;
-
- ГитРепозиторий.УстановитьРабочийКаталог(Каталог);
-
- ГитРепозиторий.КлонироватьРепозиторий(URLРепозитория, Каталог);
- ГитРепозиторий.ПерейтиВВетку(Ветка);
-
-КонецПроцедуры
-
-Процедура УстановитьПакет(Знач Каталог, ПутьКМанифестуСборки)
-
- // Лог.Информация("Каталог сборки <%1>", Каталог);
-
- // Лог.Информация("Сборка пакета библиотеки");
- // КомандаOpm = Новый Команда;
- // КомандаOpm.УстановитьРабочийКаталог(Каталог);
- // КомандаOpm.УстановитьКоманду("opm");
- // КомандаOpm.ДобавитьПараметр("build");
- // КомандаOpm.ДобавитьПараметр(Каталог);
- // КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
-
- // КодВозврата = КомандаOpm.Исполнить();
-
- // Если КодВозврата <> 0 Тогда
- // ВызватьИсключение КомандаOpm.ПолучитьВывод();
- // КонецЕсли;
-
- // МассивФайлов = НайтиФайлы(Каталог, "*.ospx");
-
- // Если МассивФайлов.Количество() = 0 Тогда
- // ВызватьИсключение Новый ИнформацияОбОшибке("Ошибка создания пакета opm", "Не найден собранный файл пакета opm");
- // КонецЕсли;
-
- // ФайлПлагина = МассивФайлов[0].ПолноеИмя;
-
- КаталогПроекта = ОбъединитьПути(ТекущийСценарий().Каталог, "..");
-
- // ФС.ОбеспечитьКаталог(КаталогПроекта);
-
- // Лог.Информация("Установка в каталог проекта <%1>", КаталогПроекта);
-
- ФайлПлагина = ОбъединитьПути(КаталогПроекта, "templates/v8storage-0.6.6.ospx");
-
- Лог.Информация("Установка пакета из файла <%1>", ФайлПлагина);
-
- КомандаOpm = Новый Команда;
- // КомандаOpm.УстановитьРабочийКаталог(КаталогПроекта);
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("install");
- КомандаOpm.ДобавитьПараметр("-l");
- КомандаOpm.ДобавитьПараметр("-f");
- КомандаOpm.ДобавитьПараметр(ФайлПлагина);
- // КомандаOpm.ДобавитьПараметр("-dest");
- // КомандаOpm.ДобавитьПараметр(КаталогПроекта);
- // КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
-
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение СтрШаблон("Ошибка установки opm из <%1> по причине <%2>", ФайлПлагина, КомандаOpm.ПолучитьВывод());
- КонецЕсли;
-
-КонецПроцедуры
-
-Процедура ПолезнаяРабота()
-
- URLРепозитория = "https://github.com/khorevaa/v8storage.git";
- КаталогСборки = ВременныеФайлы.СоздатьКаталог();
- Ветка = "feature/pack-epf";
-
- ПутьКМанифестуСборки = ОбъединитьПути(ТекущийСценарий().Каталог, "opm_packagedef_global");
-
- // ПолучитьИсходники(URLРепозитория, Ветка, КаталогСборки);
- УстановитьПакет(КаталогСборки, ПутьКМанифестуСборки);
-
- ВременныеФайлы.УдалитьФайл(КаталогСборки);
-
-КонецПроцедуры
-
-Лог = Логирование.ПолучитьЛог("task.install-opm");
-
-ПолезнаяРабота();
-
-
diff --git a/tasks/install-opm-global.os b/tasks/install-opm-global.os
deleted file mode 100644
index 35323d2d..00000000
--- a/tasks/install-opm-global.os
+++ /dev/null
@@ -1,89 +0,0 @@
-#Использовать gitrunner
-#Использовать tempfiles
-#Использовать fs
-
-Перем Лог;
-
-Процедура ПолучитьИсходники(Знач URLРепозитория, Знач Ветка, Знач Каталог)
-
- ГитРепозиторий = Новый ГитРепозиторий;
-
- ГитРепозиторий.УстановитьРабочийКаталог(Каталог);
-
- ГитРепозиторий.КлонироватьРепозиторий(URLРепозитория, Каталог);
- ГитРепозиторий.ПерейтиВВетку(Ветка);
-
-КонецПроцедуры
-
-Процедура УстановитьПакет(Знач Каталог, ПутьКМанифестуСборки)
-
- Лог.Информация("Каталог сборки <%1>", Каталог);
-
- Лог.Информация("Сборка пакета библиотеки");
- КомандаOpm = Новый Команда;
- КомандаOpm.УстановитьРабочийКаталог(Каталог);
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("build");
- КомандаOpm.ДобавитьПараметр(Каталог);
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
-
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение КомандаOpm.ПолучитьВывод();
- КонецЕсли;
-
- МассивФайлов = НайтиФайлы(Каталог, "*.ospx");
-
- Если МассивФайлов.Количество() = 0 Тогда
- ВызватьИсключение Новый ИнформацияОбОшибке("Ошибка создания пакета opm", "Не найден собранный файл пакета opm");
- КонецЕсли;
-
- ФайлПлагина = МассивФайлов[0].ПолноеИмя;
-
- КаталогПроекта = ОбъединитьПути(ТекущийСценарий().Каталог, "..", "oscript_modules");
-
- ФС.ОбеспечитьКаталог(КаталогПроекта);
-
- Лог.Информация("Установка в каталог проекта <%1>", КаталогПроекта);
-
- Лог.Информация("Установка пакета из файла <%1>", ФайлПлагина);
-
- КомандаOpm = Новый Команда;
- КомандаOpm.УстановитьРабочийКаталог(КаталогПроекта);
- КомандаOpm.УстановитьКоманду("opm");
- КомандаOpm.ДобавитьПараметр("install");
- КомандаOpm.ДобавитьПараметр("-f");
- КомандаOpm.ДобавитьПараметр(ФайлПлагина);
- // КомандаOpm.ДобавитьПараметр("-dest");
- // КомандаOpm.ДобавитьПараметр(КаталогПроекта);
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
-
- КодВозврата = КомандаOpm.Исполнить();
-
- Если КодВозврата <> 0 Тогда
- ВызватьИсключение СтрШаблон("Ошибка установки opm из <%1> по причине <%2>", ФайлПлагина, КомандаOpm.ПолучитьВывод());
- КонецЕсли;
-
-КонецПроцедуры
-
-Процедура ПолезнаяРабота()
-
- URLРепозитория = "https://github.com/khorevaa/opm.git";
- КаталогСборки = ВременныеФайлы.СоздатьКаталог();
- Ветка = "develop";
-
- ПутьКМанифестуСборки = ОбъединитьПути(ТекущийСценарий().Каталог, "opm_packagedef_global");
-
- ПолучитьИсходники(URLРепозитория, Ветка, КаталогСборки);
- УстановитьПакет(КаталогСборки, ПутьКМанифестуСборки);
-
- ВременныеФайлы.УдалитьФайл(КаталогСборки);
-
-КонецПроцедуры
-
-Лог = Логирование.ПолучитьЛог("task.install-opm");
-
-ПолезнаяРабота();
-
-
diff --git a/tasks/make.os b/tasks/make.os
index c4c6232d..daae77ee 100644
--- a/tasks/make.os
+++ b/tasks/make.os
@@ -15,7 +15,7 @@
КомандаOpm.ДобавитьПараметр("-o");
КомандаOpm.ДобавитьПараметр(ВыходнойКаталог);
КомандаOpm.ДобавитьПараметр(КаталогПроекта);
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
+ КомандаOpm.ПоказыватьВыводНемедленно(Истина);
КодВозврата = КомандаOpm.Исполнить();
@@ -46,7 +46,7 @@
КомандаOpm.ДобавитьПараметр(ФайлПлагина);
КомандаOpm.ДобавитьПараметр("--dest");
КомандаOpm.ДобавитьПараметр(КаталогУстановки);
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
+ КомандаOpm.ПоказыватьВыводНемедленно(Истина);
КодВозврата = КомандаOpm.Исполнить();
@@ -69,7 +69,7 @@
КомандаOpm.ДобавитьПараметр("-make");
КомандаOpm.ДобавитьПараметр(ФайлПриложения);
КомандаOpm.ДобавитьПараметр(ВыходнойФайл);
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
+ КомандаOpm.ПоказыватьВыводНемедленно(Истина);
КодВозврата = КомандаOpm.Исполнить();
@@ -92,7 +92,6 @@
КаталогПлагинов = ПараметрыПриложения.КаталогПлагинов();
КаталогВнутреннихКлассов = ОбъединитьПути(КаталогУстановки, "gitsync", "src/core/Классы/internal/Классы");
- СкопироватьЗагрузчикПлагинов(КаталогВнутреннихКлассов);
СкопироватьСтандартныйЗагрузчик(КаталогПлагинов);
ПодготовитьФайлИндексПлагиновEXE(КаталогВнутреннихКлассов, КаталогПлагинов);
@@ -103,7 +102,7 @@
МассивПлагинов = ПолучитьМассивПлагинов(КаталогПлагинов);
- ФайлИндексПлагиновEXE = ОбъединитьПути(КаталогВнутреннихКлассов, "ИндексПлагиновEXE.os");
+ ФайлИндексПлагиновEXE = ОбъединитьПути(КаталогВнутреннихКлассов, "ПодключениеЗапакованныхПлагинов.os");
ЗаписьТекста = Новый ЗаписьТекста(ФайлИндексПлагиновEXE);
@@ -119,7 +118,7 @@
КонецЦикла;
- ЗаписьТекста.ЗаписатьСтроку("Функция ПолучитьИндексПлагиновEXE() Экспорт");
+ ЗаписьТекста.ЗаписатьСтроку("Функция ИндексПлагинов() Экспорт");
ЗаписьТекста.ЗаписатьСтроку(" ИндексПлагинов = Новый Массив;");
Для каждого ИмяПлагина Из МассивПлагинов Цикл
@@ -224,28 +223,26 @@
КонецПроцедуры
-Процедура СкопироватьЗагрузчикПлагинов(Знач КаталогВнутреннихКлассов)
-
- ЗагрузчикПлагиновEXE = ОбъединитьПути(КаталогВнутреннихКлассов, "ЗагрузчикПлагиновEXE.os");
- ПриемникЗагрузчикПлагинов = ОбъединитьПути(КаталогВнутреннихКлассов, "ЗагрузчикПлагинов.os");
- КопироватьФайл(ЗагрузчикПлагиновEXE, ПриемникЗагрузчикПлагинов);
-
-КонецПроцедуры
-
Процедура ИнициализироватьВстроенныеПлагины(Знач КаталогУстановки)
ФайлПриложения = ОбъединитьПути(КаталогУстановки, "gitsync", "src/cmd", "gitsync.os");
КомандаOpm = Новый Команда;
+ КаталогПлагинов = ВременныеФайлы.СоздатьКаталог();
+
+ УстановитьПеременнуюСреды("GITSYNC_PLUGINS_PATH", КаталогПлагинов);
+ Лог.Информация("Каталог плагинов сборки <%1>", КаталогПлагинов);
+
КомандаOpm.УстановитьРабочийКаталог(КаталогУстановки);
КомандаOpm.УстановитьКоманду("oscript");
КомандаOpm.ДобавитьПараметр(ФайлПриложения);
КомандаOpm.ДобавитьПараметр("p init");
- КомандаOpm.ДобавитьЛогВыводаКоманды("task.install-opm");
+ КомандаOpm.ПоказыватьВыводНемедленно(Истина);
+ // КомандаOpm.("task.install-opm");
КодВозврата = КомандаOpm.Исполнить();
- Если КодВозврата <> 0 Тогда
+ Если КодВозврата <> 0 Тогда
ВызватьИсключение КомандаOpm.ПолучитьВывод();
КонецЕсли;
@@ -256,7 +253,6 @@
КаталогСборки = ВременныеФайлы.СоздатьКаталог();
КаталогУстановки = ВременныеФайлы.СоздатьКаталог();
-
ПутьКМанифестуСборки = ОбъединитьПути(КаталогПроекта, "build_packagedef");
СобратьПакет(КаталогСборки, ПутьКМанифестуСборки);
@@ -270,11 +266,12 @@
ВыполнитьСборкуEXE(КаталогУстановки);
ВременныеФайлы.УдалитьФайл(КаталогСборки);
- ВременныеФайлы.УдалитьФайл(КаталогУстановки);
+ //ВременныеФайлы.УдалитьФайл(КаталогУстановки);
КонецПроцедуры
КаталогПроекта = ОбъединитьПути(ТекущийСценарий().Каталог, "..");
Лог = Логирование.ПолучитьЛог("task.install-opm");
+// Лог.УстановитьУровень(УровниЛОга.отладка);
ПолезнаяРабота();
diff --git a/tasks/pack.os b/tasks/pack.os
new file mode 100644
index 00000000..e77635a9
--- /dev/null
+++ b/tasks/pack.os
@@ -0,0 +1,149 @@
+Перем ИндексКлассов;
+Перем КаталогBin;
+Перем КаталогКлассов;
+Перем ПрефиксКлассов;
+Перем ИмяМенеджераФайлов;
+
+Процедура ВыполнитьЗапаковку()
+
+ ТекущийКаталогЗадачи = ТекущийСценарий().Каталог;
+
+ КаталогПроекта = Новый Файл(ОбъединитьПути(ТекущийКаталогЗадачи, "..")).ПолноеИмя;
+
+ ПрефиксКлассов = "Gitsync";
+
+ КаталогКлассов = ОбъединитьПути(КаталогПроекта, "src", "core", ОбъединитьПути("Классы","internal","bindata","Классы"));
+
+ КаталогBin = ОбъединитьПути(КаталогПроекта, "bin");
+
+ ИмяМенеджераФайлов = СтрШаблон("МенеджерЗапакованныхФайлов%1.os", ПрефиксКлассов);
+
+ ИндексКлассов = Новый Соответствие;
+ ОбработатьКаталог(КаталогBin, "*.cfe");
+ ОбработатьКаталог(ОбъединитьПути(КаталогПроекта, "docs"), "*.md");
+
+ ЗаписатьКлассИндексаЗапаковки(ИндексКлассов);
+
+КонецПроцедуры
+
+Процедура ЗаписатьКлассИндексаЗапаковки(ИндексКлассов)
+
+ ТекстБлока = "Функция ПолучитьИндексФайлов() Экспорт
+ |
+ | ИндексФайлов = Новый Соответствие;
+ |";
+
+ ШаблонДобавленияВИндекс = " ИндексФайлов.Вставить(""%1"", ""%2"");";
+
+ Для каждого ДанныеКласса Из ИндексКлассов Цикл
+
+ ТекстБлока = ТекстБлока + СтрШаблон(ШаблонДобавленияВИндекс, ДанныеКласса.Ключ, ДанныеКласса.Значение) + Символы.ПС;
+
+ КонецЦикла;
+
+ ТекстБлока = ТекстБлока + "
+ | Возврат ИндексФайлов;
+ |
+ |КонецФункции";
+
+ ФайлКлассаМенеджерЗапакованныхФайлов = ОбъединитьПути(КаталогКлассов, ИмяМенеджераФайлов);
+
+ ЗаписьТекста = Новый ЗаписьТекста(ФайлКлассаМенеджерЗапакованныхФайлов);
+ ЗаписьТекста.ЗаписатьСтроку(ТекстБлока);
+ ЗаписьТекста.Закрыть();
+
+ Сообщить("Данные запакованы в классы");
+
+КонецПроцедуры
+
+Процедура ОбработатьКаталог(Знач КаталогОбработки, Знач МаскаПоискаФайлов)
+
+ МассивНайденныхФайлов = НайтиФайлы(КаталогОбработки, МаскаПоискаФайлов);
+
+ Для каждого НайденныйФайл Из МассивНайденныхФайлов Цикл
+
+ Если НайденныйФайл.ЭтоКаталог() Тогда
+ Продолжить;
+ КонецЕсли;
+
+ ИмяФайла = СтрЗаменить(НайденныйФайл.ИмяБезРасширения, ".", "_");
+ ПолныйПутьКФайлу = НайденныйФайл.ПолноеИмя;
+
+ ИмяКлассаФайла = СтрШаблон("%1_%2", ИмяФайла, ПрефиксКлассов);
+
+ ПутьКФайлуКласса = ОбъединитьПути(КаталогКлассов, ИмяКлассаФайла + ".os");
+ ДанныеФайла = ПолучитBase64Строка(ПолныйПутьКФайлу);
+ ХешСтрока = ПолучитьХешСтроку(ПолныйПутьКФайлу);
+
+ ЗаписатьКласс(ПутьКФайлуКласса, НайденныйФайл.Имя, "1.0.0", ХешСтрока, ДанныеФайла);
+
+ ИндексКлассов.Вставить(НайденныйФайл.Имя, ИмяКлассаФайла);
+
+ КонецЦикла;
+
+
+КонецПроцедуры
+
+Функция ПолучитьХешСтроку(ПутьКФайлу)
+
+ ХешФайла = Новый ХешированиеДанных(ХешФункция.MD5);
+ ХешФайла.ДобавитьФайл(ПутьКФайлу);
+
+ Возврат ХешФайла.ХешСуммаСтрокой;
+
+КонецФункции
+
+Процедура ЗаписатьКласс(ПутьКФайлуКласса, ИмяФайла, ВерсияФайла, ХешСтрока, ДанныеФайла)
+
+ ШаблонТекст = "
+ |///////////////////////////////////////////
+ |// ФАЙЛ СОЗДАН АВТОМАТИЧЕСКИ //
+ |///////////////////////////////////////////
+ |//
+ |// ФАЙЛ: <%1>
+ |//
+ |
+ |// Возвращает версию запакованного файла
+ |//
+ |Функция Версия() Экспорт
+ | Возврат ""%2"";
+ |КонецФункции
+ |
+ |// Возвращает имя запакованного файла
+ |//
+ |Функция ИмяФайла() Экспорт
+ | Возврат ""%1"";
+ |КонецФункции
+ |
+ |// Возвращает хеш строку запакованного файла
+ |//
+ |Функция Хеш() Экспорт
+ | Возврат ""%3"";
+ |КонецФункции
+ |
+ |// Возвращает запакованные данные файла
+ |//
+ |Функция ДвоичныеДанные() Экспорт
+ | ЗапакованныеДанные = ""%4"";
+ | Возврат ЗапакованныеДанные;
+ |КонецФункции
+ |
+ |";
+
+ ТекстКласса = СтрШаблон(ШаблонТекст, ИмяФайла, ВерсияФайла, ХешСтрока, ДанныеФайла);
+
+ ЗаписьТекста = Новый ЗаписьТекста(ПутьКФайлуКласса);
+ ЗаписьТекста.ЗаписатьСтроку(ТекстКласса);
+ ЗаписьТекста.Закрыть();
+
+КонецПроцедуры
+
+Функция ПолучитBase64Строка(ПутьКФайлу)
+
+ ДвоичныеДанныеФайла = Новый ДвоичныеДанные(ПутьКФайлу);
+ Строка = Base64Строка(ДвоичныеДанныеФайла);
+ Возврат Строка;
+
+КонецФункции
+
+ВыполнитьЗапаковку();
\ No newline at end of file
diff --git a/tasks/test.os b/tasks/test.os
index 46098aeb..034f396c 100644
--- a/tasks/test.os
+++ b/tasks/test.os
@@ -188,12 +188,12 @@
КонецФункции // ПрогнатьФичи()
Функция ПрогнатьФичи()
+
ФичиПрошли_opm = ПрогнатьФичи_opm();
ФичиПрошли_core = ПрогнатьФичи_core();
ФичиПрошли_cmd = ПрогнатьФичи_cmd();
-
- //ФичиПрошли_exe = ПрогнатьФичи_exe();
- ФичиПрошли_exe = Истина;
+ ФичиПрошли_exe = ПрогнатьФичи_exe();
+ // ФичиПрошли_exe = Истина;
Возврат
ФичиПрошли_opm
diff --git a/tests/fixtures/default.yaml b/tests/fixtures/default.yaml
new file mode 100644
index 00000000..c9b151f3
--- /dev/null
+++ b/tests/fixtures/default.yaml
@@ -0,0 +1,35 @@
+globals:
+ storage-user: Администратор
+ storage-pwd: ''
+ git-path: git
+ v8version: 8.3
+ domain-email: localhost
+ lic-try-count: 5
+ plugins:
+ enable:
+ - test
+ - test2
+ disable:
+ - test3
+repositories:
+ - name: ТестовыйРепозиторий
+ # disable: false
+ path: <КаталогХранилища1С_1>
+ dir: <ПутьКаталогаИсходников_1>
+ plugins:
+ more:
+ - test3
+ plugins-config:
+ URL: http
+
+ - name: ТестовыйРепозиторий2
+ # disable: true
+ path: <КаталогХранилища1С_2>
+ dir: <ПутьКаталогаИсходников_2>
+ storage-user: Администратор
+ storage-pwd: ''
+ git-path: git
+ temp-dir: ""
+ v8version: 8.3
+ domain-email: localhost
+ lic-try-count: 5
\ No newline at end of file
diff --git a/tests/fixtures/ext.yaml b/tests/fixtures/ext.yaml
new file mode 100644
index 00000000..3f02e665
--- /dev/null
+++ b/tests/fixtures/ext.yaml
@@ -0,0 +1,11 @@
+ name: Расширение1
+ extention: test
+ path: <КаталогХранилищаРасширения>
+ dir: <ПутьКаталогаИсходниковРасширения>
+ storage-user: Администратор
+ storage-pwd: ''
+ git-path: git
+ temp-dir: ""
+ v8version: 8.3
+ domain-email: localhost
+ lic-try-count: 5
\ No newline at end of file
diff --git a/tests/fixtures/extension_storage/1cv8ddb.1CD b/tests/fixtures/extension_storage/1cv8ddb.1CD
index 01c27148..bad3a7ee 100644
Binary files a/tests/fixtures/extension_storage/1cv8ddb.1CD and b/tests/fixtures/extension_storage/1cv8ddb.1CD differ
diff --git a/tests/fixtures/extension_storage/data/objects/09/0694564fb2cc20d4ee82dff29581aea6ebceb2 b/tests/fixtures/extension_storage/data/objects/09/0694564fb2cc20d4ee82dff29581aea6ebceb2
new file mode 100644
index 00000000..40436522
Binary files /dev/null and b/tests/fixtures/extension_storage/data/objects/09/0694564fb2cc20d4ee82dff29581aea6ebceb2 differ
diff --git a/tests/fixtures/extension_storage/data/objects/15/af5e8f18aea8397ae287ef2f0f237eca7ba410 b/tests/fixtures/extension_storage/data/objects/15/af5e8f18aea8397ae287ef2f0f237eca7ba410
new file mode 100644
index 00000000..778f3f5c
--- /dev/null
+++ b/tests/fixtures/extension_storage/data/objects/15/af5e8f18aea8397ae287ef2f0f237eca7ba410
@@ -0,0 +1 @@
+{0,0}
\ No newline at end of file
diff --git a/tests/fixtures/extension_storage/data/objects/3e/09dd8ca40ee4c38920ec37b53860a6335d9749 b/tests/fixtures/extension_storage/data/objects/3e/09dd8ca40ee4c38920ec37b53860a6335d9749
new file mode 100644
index 00000000..fa9ff593
Binary files /dev/null and b/tests/fixtures/extension_storage/data/objects/3e/09dd8ca40ee4c38920ec37b53860a6335d9749 differ
diff --git a/tests/fixtures/extension_storage/data/objects/51/ddb08f4a5453469fb93b1cdc90304d747357b7 b/tests/fixtures/extension_storage/data/objects/51/ddb08f4a5453469fb93b1cdc90304d747357b7
new file mode 100644
index 00000000..2d9537fe
Binary files /dev/null and b/tests/fixtures/extension_storage/data/objects/51/ddb08f4a5453469fb93b1cdc90304d747357b7 differ
diff --git a/tests/fixtures/extension_storage/data/objects/90/5786cba6e9271268f277226315b61c46427718 b/tests/fixtures/extension_storage/data/objects/90/5786cba6e9271268f277226315b61c46427718
new file mode 100644
index 00000000..ba0858ba
Binary files /dev/null and b/tests/fixtures/extension_storage/data/objects/90/5786cba6e9271268f277226315b61c46427718 differ
diff --git a/tests/fixtures/extension_storage/data/objects/fd/94de288b43ff531cadf282f9664dd70031a9cb b/tests/fixtures/extension_storage/data/objects/fd/94de288b43ff531cadf282f9664dd70031a9cb
new file mode 100644
index 00000000..06aa04e9
Binary files /dev/null and b/tests/fixtures/extension_storage/data/objects/fd/94de288b43ff531cadf282f9664dd70031a9cb differ
diff --git a/tests/fixtures/extension_storage/data/pack/pack-c262dc49d0c6254821c6af2f1aaced0d0d28d2b3.ind b/tests/fixtures/extension_storage/data/pack/pack-c262dc49d0c6254821c6af2f1aaced0d0d28d2b3.ind
new file mode 100644
index 00000000..d159252b
Binary files /dev/null and b/tests/fixtures/extension_storage/data/pack/pack-c262dc49d0c6254821c6af2f1aaced0d0d28d2b3.ind differ
diff --git a/tests/fixtures/extension_storage/data/pack/pack-c262dc49d0c6254821c6af2f1aaced0d0d28d2b3.pck b/tests/fixtures/extension_storage/data/pack/pack-c262dc49d0c6254821c6af2f1aaced0d0d28d2b3.pck
new file mode 100644
index 00000000..6e606fc3
Binary files /dev/null and b/tests/fixtures/extension_storage/data/pack/pack-c262dc49d0c6254821c6af2f1aaced0d0d28d2b3.pck differ
diff --git a/tests/fixtures/extension_storage/data/ver b/tests/fixtures/extension_storage/data/ver
new file mode 100644
index 00000000..20d5cb86
Binary files /dev/null and b/tests/fixtures/extension_storage/data/ver differ
diff --git a/tests/fixtures/extension_storage/ver b/tests/fixtures/extension_storage/ver
new file mode 100644
index 00000000..bbaa99cd
--- /dev/null
+++ b/tests/fixtures/extension_storage/ver
@@ -0,0 +1 @@
+{0,2,8,3,14,1533,"Designer"}
\ No newline at end of file
diff --git "a/tests/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262_test.os" "b/tests/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262_test.os"
new file mode 100644
index 00000000..45e707ca
--- /dev/null
+++ "b/tests/\320\234\320\265\320\275\320\265\320\264\320\266\320\265\321\200\320\237\320\273\320\260\320\263\320\270\320\275\320\276\320\262_test.os"
@@ -0,0 +1,100 @@
+#использовать "../src/core/"
+#Использовать asserts
+#Использовать logos
+
+Перем юТест;
+Перем Лог;
+
+Функция ПолучитьСписокТестов(Знач Тестирование) Экспорт
+
+ юТест = Тестирование;
+
+ ИменаТестов = Новый Массив;
+
+ ИменаТестов.Добавить("ТестДолжен_ПроверитьИндексПлагинов");
+ ИменаТестов.Добавить("ТестДолжен_ПроверитьВключениеПлагинов");
+ ИменаТестов.Добавить("ТестДолжен_ПроверитьВыключениеПлагинов");
+
+ Возврат ИменаТестов;
+
+КонецФункции
+
+Процедура ТестДолжен_ПроверитьИндексПлагинов() Экспорт
+
+ КаталогПлагинов = ВременныеФайлы.СоздатьКаталог();
+
+ МенеджерПлагинов = Новый МенеджерПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.УстановитьФайлПлагин(ОбъединитьПути(КаталогПроекта(), "tests", "test_plugin-0.0.1.ospx"));
+ МенеджерПлагинов.ЗагрузитьПлагины();
+
+ ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
+ Ожидаем.Что(ИндексПлагинов.Количество(), "Количество плагинов должно быть равны").Равно(1);
+ ВременныеФайлы.УдалитьФайл(КаталогПлагинов);
+
+КонецПроцедуры
+
+Процедура ТестДолжен_ПроверитьВключениеПлагинов() Экспорт
+
+ КаталогПлагинов = ВременныеФайлы.СоздатьКаталог();
+
+ МенеджерПлагинов = Новый МенеджерПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.УстановитьФайлПлагин(ОбъединитьПути(КаталогПроекта(), "tests", "test_plugin-0.0.1.ospx"));
+ МенеджерПлагинов.ЗагрузитьПлагины();
+
+ ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
+ Ожидаем.Что(ИндексПлагинов.Количество(), "Количество плагинов должно быть равны").Равно(1);
+
+ МенеджерПлагинов.ВключитьПлагин("test_plugin");
+
+ Ожидаем.Что(ИндексПлагинов["test_plugin"].Включен(), "Плагин должен быть включен").ЭтоИстина();
+
+ ВременныеФайлы.УдалитьФайл(КаталогПлагинов);
+
+КонецПроцедуры
+
+Процедура ТестДолжен_ПроверитьВыключениеПлагинов() Экспорт
+
+ КаталогПлагинов = ВременныеФайлы.СоздатьКаталог();
+
+ МенеджерПлагинов = Новый МенеджерПлагинов(КаталогПлагинов);
+ МенеджерПлагинов.УстановитьФайлПлагин(ОбъединитьПути(КаталогПроекта(), "tests", "test_plugin-0.0.1.ospx"));
+ МенеджерПлагинов.ЗагрузитьПлагины();
+
+ ИндексПлагинов = МенеджерПлагинов.ПолучитьИндексПлагинов();
+ Ожидаем.Что(ИндексПлагинов.Количество(), "Количество плагинов должно быть равны").Равно(1);
+
+ МенеджерПлагинов.ВключитьПлагин("test_plugin");
+
+ Ожидаем.Что(ИндексПлагинов["test_plugin"].Включен(), "Плагин должен быть включен").ЭтоИстина();
+
+ МассивПлагинов = Новый Массив();
+ МассивПлагинов.Добавить("test_plugin");
+
+ МенеджерПлагинов.ОтключитьПлагины(МассивПлагинов);
+
+ Ожидаем.Что(ИндексПлагинов["test_plugin"].Включен(), "Плагин должен быть выключен").ЭтоЛожь();
+
+ ВременныеФайлы.УдалитьФайл(КаталогПлагинов);
+
+КонецПроцедуры
+
+Функция КаталогПлагинов()
+
+ КаталогТестов = ТекущийСценарий().Каталог;
+
+ КаталогПлагинов = ОбъединитьПути(КаталогТестов, "fixtures", "КаталогПлагинов");
+ Файл = Новый Файл(КаталогПлагинов);
+ Возврат Файл.ПолноеИмя;
+
+КонецФункции
+
+Функция КаталогПроекта()
+
+ ПутьККаталогуПроекта = ОбъединитьПути(ТекущийСценарий().Каталог, "..");
+ Файл = Новый Файл(ПутьККаталогуПроекта);
+ Возврат Файл.ПолноеИмя;
+
+КонецФункции
+
+Лог = Логирование.ПолучитьЛог("oscript.lib.gitsync");
+// Лог.УстановитьУровень(УровниЛога.Отладка);
\ No newline at end of file