-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathCompile.os
450 lines (329 loc) · 24.6 KB
/
Compile.os
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
#Использовать v8runner
#Использовать logos
Перем Лог;
Перем УправлениеКонфигуратором;
Функция ДатуКСтроке(Дат)
Возврат Формат(Дат,"ДФ=yyyy.MM.dd.HH.mm.ss");
КонецФункции
// Перемещаят найденные по маскам файлы с сохранением пути.
//
// Параметры:
// КаталогКуда - Строка - Путь к каталогу в который переносятся файлы;
// КаталогиОткуда - Массив - Пути к каталогам в которых осуществляется поиск файлов;
// МассивМасок - Массив - Маски, по которым осуществляется поиск файлов.
//
// Взято из https://infostart.ru/public/537028/
Процедура ПереместитьФайлыВКаталог(КаталогКуда, КаталогиОткуда, МассивМасок)
Для Каждого КаталогПоиска Из КаталогиОткуда Цикл
КаталогПоискаОбъект = Новый Файл(КаталогПоиска);
Если НЕ КаталогПоискаОбъект.Существует() Тогда
Лог.Ошибка(НСтр("ru = 'Каталог не найден.'"));
Продолжить;
КонецЕсли;
Для Каждого Маска Из МассивМасок Цикл
МассивФайлов = НайтиФайлы(КаталогПоиска, Маска, Истина);
Для Каждого НайденныйФайл Из МассивФайлов Цикл
НовыйПуть = СтрЗаменить(НайденныйФайл.Путь, КаталогПоиска, КаталогКуда);
НовоеИмя = НайденныйФайл.Имя;
Если НЕ ОбеспечитьКаталог(НовыйПуть) Тогда
Продолжить;
КонецЕсли;
Если НайденныйФайл.ЭтоКаталог() Тогда
Продолжить;
КонецЕсли;
ИмяФайлаДляПеремещения = ОбъединитьПути(НовыйПуть, НовоеИмя);
УдалитьФайлы(ИмяФайлаДляПеремещения);
Попытка
ПереместитьФайл(НайденныйФайл.ПолноеИмя,ИмяФайлаДляПеремещения);
Исключение
Лог.Ошибка(СтрШаблон(НСтр("ru = 'Не удалось переместить файл:
|%1'"), ОписаниеОшибки()));
Продолжить;
КонецПопытки;
ФайлНаДиске = Новый Файл(ОбъединитьПути(НовыйПуть, НовоеИмя));
Если НЕ ФайлНаДиске.Существует() Тогда
Лог.Ошибка(НСтр("ru = 'Не удалось корректно переместить файл.'"));
Продолжить;
КонецЕсли;
КонецЦикла;
КонецЦикла;
КонецЦикла;
КонецПроцедуры
// Проверяет наличия каталога и в случае его отсутствия создает новый.
//
// Параметры:
// Каталог - Строка - Путь к каталогу, существование которого нужно проверить.
//
// Возвращаемое значение:
// Булево - признак существования каталога.
//
// Взято из https://infostart.ru/public/537028/
Функция ОбеспечитьКаталог(Знач Каталог)
Файл = Новый Файл(Каталог);
Если Не Файл.Существует() Тогда
Попытка
СоздатьКаталог(Каталог);
Исключение
Лог.Ошибка(СтрШаблон(НСтр("ru = 'Не удалось создать каталог %1.
|%2'"), Каталог, ИнформацияОбОшибке()));
Возврат Ложь;
КонецПопытки;
ИначеЕсли Не Файл.ЭтоКаталог() Тогда
Лог.Ошибка(СтрШаблон(НСтр("ru = 'Каталог %1 не является каталогом.'"), Каталог));
Возврат Ложь;
КонецЕсли;
Возврат Истина;
КонецФункции
Функция ПроверитьЧтоВсеФайлыИсходниковСоответствуютИхВерсиям(МассивВерсий,Знач ИмяКаталога)
ПромКаталог = СтрЗаменить(ИмяКаталога,"/","\");
Если Прав(ПромКаталог,1) <> "\" Тогда
ИмяКаталога = ИмяКаталога + ПолучитьРазделительПути();
КонецЕсли;
//Сообщить("ИмяКаталога="+ИмяКаталога);
МассивФайлов = Новый Массив;
МассивДляПоиска = Новый Массив;
Файлы = НайтиФайлы(ИмяКаталога,"*",Истина);
Для Каждого Файл Из Файлы Цикл
Если Файл.ЭтоКаталог() Тогда
Продолжить;
КонецЕсли;
Если ЭтоСлужебныйФайл(Файл.Имя) Тогда
Продолжить;
КонецЕсли;
МассивФайлов.Добавить(Файл);
Стр = Сред(Файл.ПолноеИмя,СтрДлина(ИмяКаталога));
Стр = СтрЗаменить(Стр,"/","\");
//Сообщить("СтрокаДляПоиска="+Стр);
МассивДляПоиска.Добавить(Стр);
КонецЦикла;
//Сообщить("МассивФайлов.Количество()="+МассивФайлов.Количество());
//Сообщить("МассивВерсий.Количество()="+МассивВерсий.Количество());
Если МассивФайлов.Количество() <> МассивВерсий.Количество() Тогда
Лог.Информация("Изменилось количество файлов.");
//значит в исходниках появился новый файл или исчез
Возврат Ложь;
КонецЕсли;
Для Каждого СтрокаВерсии Из МассивВерсий Цикл
Поз = Найти(СтрокаВерсии,"|");
Версия = Лев(СтрокаВерсии,Поз-1);
ЧастьПути = Сред(СтрокаВерсии,Поз+1);
ЧастьПути = СтрЗаменить(ЧастьПути,"/","\");
ИдФайла = МассивДляПоиска.Найти(ЧастьПути);
Если ИдФайла = Неопределено Тогда
Лог.Информация("Не найден файл версии: " + ЧастьПути);
Возврат Ложь;
КонецЕсли;
Файл = МассивФайлов[ИдФайла];
ТекущаяВерсияСтрокой = ДатуКСтроке(Файл.ПолучитьВремяИзменения());
Если ТекущаяВерсияСтрокой <> Версия Тогда
Лог.Информация("Изменилась версия у файла: " + ЧастьПути);
Возврат Ложь;
КонецЕсли;
КонецЦикла;
Возврат Истина;
КонецФункции
Процедура ЗагрузитьОбработкуИлиОтчетИзXML(ИмяФайла_filename,ИмяОбработкиИлиОтчета)
Файл_filename = Новый Файл(ИмяФайла_filename);
КаталогГдеЛежит_filename = Файл_filename.Путь;
ИмяФайлаВерсии = Файл_filename.Путь + "fileversion";
Файл_ИмяКаталога_filename = Новый Файл(Файл_filename.Путь);
ИмяКаталога_filename = Файл_ИмяКаталога_filename.Имя;
ФайлКаталогГдеЛежит_filename = Новый Файл(КаталогГдеЛежит_filename);
ИмяФайлаXML = ФайлКаталогГдеЛежит_filename.Имя + ".xml";
ИмяФайлаКорневойXml = ФайлКаталогГдеЛежит_filename.Путь + ИмяФайлаXML;
ФайлКорневойXML = Новый Файл(ИмяФайлаКорневойXml);
Если Не ФайлКорневойXML.Существует() Тогда
ВызватьИсключение "Файл " + ИмяФайлаКорневойXml + " не существует.";
КонецЕсли;
ИмяФайлаОбработкиИлиОтчета = ФайлКорневойXML.Путь + ИмяОбработкиИлиОтчета;
Если Прав(НРег(ИмяФайлаОбработкиИлиОтчета),4) = ".epf" Тогда
ИмяФайлаВременныйОбработкаИлиОтчет = ПолучитьИмяВременногоФайла("epf");
Иначе
ИмяФайлаВременныйОбработкаИлиОтчет = ПолучитьИмяВременногоФайла("erf");
КонецЕсли;
ФайлОбработкаИлиОтчет = Новый Файл(ИмяФайлаОбработкиИлиОтчета);
Если ФайлОбработкаИлиОтчет.Существует() Тогда
//Проверим версию. Если она совпадает, то собирать файл не надо.
ФайлВерсии = Новый Файл(ИмяФайлаВерсии);
Если ФайлВерсии.Существует() Тогда
Массив = Новый Массив;
Текст = Новый ЧтениеТекста;
Текст.Открыть(ИмяФайлаВерсии,"UTF-8");
Пока Истина Цикл
Стр = Текст.ПрочитатьСтроку();
Если Стр = Неопределено Тогда
Прервать;
КонецЕсли;
Массив.Добавить(Стр);
КонецЦикла;
Текст.Закрыть();
Если Массив.Количество() < 1 Тогда
ВызватьИсключение "Н смог прочитать файл версии: " + ИмяФайлаВерсии;
КонецЕсли;
ВерсияСтрокой = Массив[0];
Поз = Найти(ВерсияСтрокой,"|");
ВерсияСтрокой = Лев(ВерсияСтрокой,Поз-1);
ТекущаяВерсияСтрокой = ДатуКСтроке(ФайлОбработкаИлиОтчет.ПолучитьВремяИзменения());
Если НРег(ВерсияСтрокой) = НРег(ТекущаяВерсияСтрокой) Тогда
Массив.Удалить(0);
Если ПроверитьЧтоВсеФайлыИсходниковСоответствуютИхВерсиям(Массив,ФайлОбработкаИлиОтчет.Путь + ИмяКаталога_filename) Тогда
Лог.Информация("" + ИмяОбработкиИлиОтчета + " УЖЕ собран.");
Возврат;
КонецЕсли;
КонецЕсли;
Если ТекущаяВерсияСтрокой > ВерсияСтрокой Тогда
Лог.Ошибка("Файл <" + ИмяФайлаОбработкиИлиОтчета + "> имеет версию новее чем в исходниках. Удалите " + ФайлОбработкаИлиОтчет.Имя + ", если хотите пересобрать его.");
Лог.Ошибка("Версия в исходниках: " + ВерсияСтрокой);
Лог.Ошибка("Версия файла: " + ТекущаяВерсияСтрокой);
ВызватьИсключение "Обработка прервана.";
КонецЕсли;
КонецЕсли;
КонецЕсли;
ПараметрыЗапуска = УправлениеКонфигуратором.ПолучитьПараметрыЗапуска();
ПараметрыЗапуска.Добавить("/LoadExternalDataProcessorOrReportFromFiles """ + ИмяФайлаКорневойXml + """ """ + ИмяФайлаВременныйОбработкаИлиОтчет + """");
ИмяФайлаOut = ПолучитьИмяВременногоФайла("txt");
ПараметрыЗапуска.Добавить("/Out """ + ИмяФайлаOut + """");
Попытка
УправлениеКонфигуратором.ВыполнитьКоманду(ПараметрыЗапуска);
Исключение
Лог.Ошибка(ОписаниеОшибки());
Лог.Ошибка(УправлениеКонфигуратором.ВыводКоманды());
ВызватьИсключение "Выгрузка обработок в xml прервана.";
КонецПопытки;
УдалитьФайлы(ИмяФайлаОбработкиИлиОтчета);
ПереместитьФайл(ИмяФайлаВременныйОбработкаИлиОтчет,ИмяФайлаОбработкиИлиОтчета);
ФайлОбработкаИлиОтчет = Новый Файл(ИмяФайлаОбработкиИлиОтчета);
ВремяИзменения = ДатуКСтроке(ФайлОбработкаИлиОтчет.ПолучитьВремяИзменения());
//запишем версию файла
ЗаписатьВерсиюОбработкиИлиОтчета(ФайлОбработкаИлиОтчет,ИмяКаталога_filename,ИмяОбработкиИлиОтчета);
Лог.Информация("" + ИмяОбработкиИлиОтчета + " собран.");
КонецПроцедуры
Функция ЭтоСлужебныйФайл(ИмяФайла)
Если Нрег(ИмяФайла) = "filename" Тогда
Возврат Истина;
ИначеЕсли Нрег(ИмяФайла) = "fileversion" Тогда
Возврат Истина;
КонецЕсли;
Возврат Ложь;
КонецФункции
Функция ПолучитьВерсииФайловВКаталоге(Каталог)
//Сообщить("КаталогПолучитьВерсииФайловВКаталоге="+Каталог);
ТаблицаФайлов = Новый ТаблицаЗначений;
ТаблицаФайлов.Колонки.Добавить("ПолноеИмя");
ТаблицаФайлов.Колонки.Добавить("ЧастьПути");
ТаблицаФайлов.Колонки.Добавить("ЭтоКаталог");
ТаблицаФайлов.Колонки.Добавить("ВремяИзменения");
Файлы = НайтиФайлы(Каталог,"*",Истина);
Для Каждого Файл Из Файлы Цикл
Если ЭтоСлужебныйФайл(Файл.Имя) Тогда
Продолжить;
КонецЕсли;
СтрокаТаблицаФайлов = ТаблицаФайлов.Добавить();
СтрокаТаблицаФайлов.ПолноеИмя = Файл.ПолноеИмя;
СтрокаТаблицаФайлов.ЭтоКаталог = Файл.ЭтоКаталог();
СтрокаТаблицаФайлов.ЧастьПути = Сред(Файл.ПолноеИмя,СтрДлина(Каталог));
//Сообщить("СтрокаТаблицаФайлов.ЧастьПути="+СтрокаТаблицаФайлов.ЧастьПути);
Если СтрокаТаблицаФайлов.ЭтоКаталог Тогда
Продолжить;
КонецЕсли;
СтрокаТаблицаФайлов.ВремяИзменения = ДатуКСтроке(Файл.ПолучитьВремяИзменения());
КонецЦикла;
Возврат ТаблицаФайлов;
КонецФункции
Процедура ЗаписатьВерсиюОбработкиИлиОтчета(ФайлОбработкаИлиОтчет,ИмяКаталогаОбработки,ИмяОбработкиИлиОтчета)
ИмяФайлаВерсии = ФайлОбработкаИлиОтчет.Путь + ПолучитьРазделительПути()+ ИмяКаталогаОбработки + ПолучитьРазделительПути() + "fileversion";
//Сообщить("ИмяФайлаВерсии="+ИмяФайлаВерсии);
УдалитьФайлы(ИмяФайлаВерсии);
ВремяИзменения = ДатуКСтроке(ФайлОбработкаИлиОтчет.ПолучитьВремяИзменения());
ВерсииФайлов = ПолучитьВерсииФайловВКаталоге(ФайлОбработкаИлиОтчет.Путь + ИмяКаталогаОбработки + ПолучитьРазделительПути());
ЗТ = Новый ЗаписьТекста(ИмяФайлаВерсии,"UTF-8",,Истина);
ЗТ.ЗаписатьСтроку(ВремяИзменения + "|" + ИмяОбработкиИлиОтчета);
Для Каждого СтрокаВерсииФайлов Из ВерсииФайлов Цикл
Если СтрокаВерсииФайлов.ЭтоКаталог Тогда
Продолжить;
КонецЕсли;
Стр = "" + СтрокаВерсииФайлов.ВремяИзменения + "|" + СтрокаВерсииФайлов.ЧастьПути;
ЗТ.ЗаписатьСтроку(Стр);
КонецЦикла;
ЗТ.Закрыть();
КонецПроцедуры
Процедура СобратьОбработкуИлиОтчетВКаталогеИПодКаталогах(Путь)
Файл = Новый Файл(Путь);
Если НЕ Файл.Существует() Тогда
ВызватьИсключение "Каталог <" + Путь + "> не существует.";
КонецЕсли;
Файлы = НайтиФайлы(Путь,"filename.*",Истина);
КоличествоФайлов = Файлы.Количество();
НомерФайла = 0;
Для Каждого Файл Из Файлы Цикл
НомерФайла = НомерФайла + 1;
Текст = Новый ЧтениеТекста;
Текст.Открыть(Файл.ПолноеИмя,"UTF-8");
ИмяОбработкиИлиОтчета = "";
Пока Истина Цикл
Стр = Текст.ПрочитатьСтроку();
Если Стр = Неопределено Тогда
Прервать;
КонецЕсли;
ИмяОбработкиИлиОтчета = Стр;
КонецЦикла;
Текст.Закрыть();
Если ИмяОбработкиИлиОтчета = "" Тогда
ВызватьИсключение "В файле " + Файл.ПолноеИмя + " не найдено имя собираемого файла.";
КонецЕсли;
Лог.Информация("Файл " + НомерФайла + " из " + КоличествоФайлов + ": " + ИмяОбработкиИлиОтчета);
ЗагрузитьОбработкуИлиОтчетИзXML(Файл.ПолноеИмя,ИмяОбработкиИлиОтчета);
КонецЦикла;
КонецПроцедуры
Функция ПереместитьФайлыДляРазборки(КаталогКудаОбъект, КаталогОткудаОбъект, Маска, МассивУдаляемыхВременныхФайлов)
МассивПеремещения = НайтиФайлы(КаталогОткудаОбъект.ПолноеИмя, Маска, Истина);
Для каждого ЭлементМассиваПеремещения из МассивПеремещения Цикл
ПолноеИмяФайлаОткуда = ЭлементМассиваПеремещения.ПолноеИмя;
КороткоеИмяФайлаОткуда = ЭлементМассиваПеремещения.Имя;
ОтносительноеИмя = СтрЗаменить(ПолноеИмяФайлаОткуда, КаталогОткудаОбъект.ПолноеИмя, "");
ИмяНовогоКаталога = СтрЗаменить(КаталогКудаОбъект.ПолноеИмя + ОтносительноеИмя, КороткоеИмяФайлаОткуда, "");
Если НЕ ОбеспечитьКаталог(ИмяНовогоКаталога) Тогда
Продолжить;
КонецЕсли;
КопироватьФайл(ПолноеИмяФайлаОткуда, КаталогКудаОбъект.ПолноеИмя + ОтносительноеИмя);
МассивУдаляемыхВременныхФайлов.Добавить(КаталогОткудаОбъект.ПолноеИмя + ОтносительноеИмя);
//Лог.Информация("Копируем " + ПолноеИмяФайлаОткуда + " в " + КаталогКудаОбъект.ПолноеИмя + ОтносительноеИмя);
КонецЦикла;
Возврат МассивУдаляемыхВременныхФайлов;
КонецФункции
Процедура УстановитьПутьКПлатформеИзПеременнойСреды(УправлениеКонфигуратором)
// В Linux не видит путь к платформе, возможно из-за изменения пути установки
// Пока будем передавать путь через переменную среды.
// TODO: посмотреть и поправить библиотеки v8runner/v8find
ПутьКПлатформе = ПолучитьПеременнуюСреды("Path1C");
Если НЕ ПустаяСтрока(ПутьКПлатформе) Тогда
УправлениеКонфигуратором.ПутьКПлатформе1С(ПутьКПлатформе);
КонецЕсли;
КонецПроцедуры
Лог = Логирование.ПолучитьЛог("vb.compile.log");
Лог.УстановитьУровень(УровниЛога.Отладка);
Если АргументыКоманднойСтроки.Количество() = 0 Тогда
Лог.Ошибка("Не переданы параметры!");
ИначеЕсли АргументыКоманднойСтроки.Количество() > 2 Тогда
Лог.Ошибка("Скрипт принимает не больше двух параметров!");
Иначе
УправлениеКонфигуратором = Новый УправлениеКонфигуратором();
УстановитьПутьКПлатформеИзПеременнойСреды(УправлениеКонфигуратором);
КаталогБазы = ПолучитьИмяВременногоФайла();
УправлениеКонфигуратором.СоздатьФайловуюБазу(КаталогБазы);
УправлениеКонфигуратором.УстановитьКонтекст("/F""" + КаталогБазы + """","","");
Если АргументыКоманднойСтроки.Количество() = 2 Тогда
МассивУдаляемыхВременныхФайлов = Новый Массив;
КаталогКудаОбъект = Новый Файл(АргументыКоманднойСтроки[1]);
КаталогОткудаОбъект = Новый Файл(АргументыКоманднойСтроки[0]);
СобратьОбработкуИлиОтчетВКаталогеИПодКаталогах(КаталогОткудаОбъект.ПолноеИмя);
МассивУдаляемыхВременныхФайлов = ПереместитьФайлыДляРазборки(КаталогКудаОбъект,КаталогОткудаОбъект, "*.epf", МассивУдаляемыхВременныхФайлов);
МассивУдаляемыхВременныхФайлов = ПереместитьФайлыДляРазборки(КаталогКудаОбъект,КаталогОткудаОбъект, "*.erf", МассивУдаляемыхВременныхФайлов);
Для каждого ВременныйФайл из МассивУдаляемыхВременныхФайлов Цикл
УдалитьФайлы(ВременныйФайл);
КонецЦикла;
Иначе
СобратьОбработкуИлиОтчетВКаталогеИПодКаталогах(АргументыКоманднойСтроки[0]);
КонецЕсли;
КонецЕсли;
Сообщить("Обработка завершена.");