//Перем ДополнительныеСвойства Экспорт; //Перем ОбменДанными Экспорт; Перем _СчитанныйСнимок Экспорт; Перем _Тип Экспорт; Перем _СсылкаНового Экспорт; Процедура Конструктор(Объект) Экспорт ЭтотОбъект.ДополнительныеСвойства = Объект.ДополнительныеСвойства; ЭтотОбъект.ОбменДанными = ирОбщий.СтруктураОбменаДаннымиОбъектаЛкс(Объект); ЭтотОбъект.Ссылка = Объект.Ссылка; ЭтотОбъект._Тип = ТипЗнч(Объект); Если Объект.Ссылка.Пустая() Тогда ЭтотОбъект._СсылкаНового = Объект.ПолучитьСсылкуНового(); КонецЕсли; ОбъектМД = Объект.Метаданные(); ЕстьЭтоГруппа = ирОбщий.ЛиМетаданныеОбъектаСГруппамиЛкс(ОбъектМД); ПоляТаблицыБД = ирОбщий.ПолучитьПоляТаблицыМДЛкс(ОбъектМД,,,, Ложь); Данные = Новый Структура; ПоляШапки = Новый Массив; Для Каждого СтрокаПоля Из ПоляТаблицыБД Цикл Если Истина И ЕстьЭтоГруппа И СтрокаПоля.Метаданные <> Неопределено И ОбъектМД.Реквизиты.Найти(СтрокаПоля.Метаданные.Имя) <> Неопределено Тогда МетаРеквизит = СтрокаПоля.Метаданные; Если Ложь Или (Истина И Не Объект.ЭтоГруппа И МетаРеквизит.Использование = Метаданные.СвойстваОбъектов.ИспользованиеРеквизита.ДляГруппы) Или (Истина И Объект.ЭтоГруппа И МетаРеквизит.Использование = Метаданные.СвойстваОбъектов.ИспользованиеРеквизита.ДляЭлемента) Тогда Продолжить; КонецЕсли; КонецЕсли; Данные.Вставить(СтрокаПоля.Имя); Если СтрокаПоля.ТипЗначения.СодержитТип(Тип("ТаблицаЗначений")) Тогда Данные.Вставить(СтрокаПоля.Имя, Объект[СтрокаПоля.Имя].Выгрузить()); Иначе ПоляШапки.Добавить(СтрокаПоля.Имя); КонецЕсли; КонецЦикла; ЗаполнитьЗначенияСвойств(Данные, Объект, ирОбщий.ПолучитьСтрокуСРазделителемИзМассиваЛкс(ПоляШапки)); ЭтотОбъект.Данные = Данные; Если Не Объект.Модифицированность() Тогда ЭтотОбъект._СчитанныйСнимок = Снимок(Истина); КонецЕсли; КонецПроцедуры Функция Снимок(ТолькоДанные = Ложь) Экспорт СтруктураОбъекта = Новый Структура; Если Не ТолькоДанные Тогда СтруктураОбъекта.Вставить("ОбменДанными", ОбменДанными); СтруктураОбъекта.Вставить("ДополнительныеСвойства", ДополнительныеСвойства); СтруктураОбъекта.Вставить("_СчитанныйСнимок", _СчитанныйСнимок); СтруктураОбъекта.Вставить("_Тип", _Тип); КонецЕсли; СтруктураОбъекта.Вставить("Данные", Данные); СтруктураОбъекта.Вставить("Ссылка", Ссылка); СтруктураОбъекта.Вставить("_СсылкаНового", _СсылкаНового); ЗаписьXML = ирОбщий.ОптимальныйПотоковыйПисательЛкс(); #Если Сервер И Не Сервер Тогда ЗаписьXML = Новый ЗаписьXML; #КонецЕсли ЗаписьXML.УстановитьСтроку(); Попытка Если ТипЗнч(ЗаписьXML) = Тип("ЗаписьXML") Тогда СериализаторXDTO.ЗаписатьXML(ЗаписьXML, СтруктураОбъекта, НазначениеТипаXML.Явное); Иначе СериализаторXDTO.ЗаписатьJSON(ЗаписьXML, СтруктураОбъекта, НазначениеТипаXML.Явное); КонецЕсли; Исключение // Убираем неудобные типы значений из дополнительных свойств объекта http://devtool1c.ucoz.ru/forum/2-832-1#3587 СтруктураОбъекта.Вставить("ДополнительныеСвойства"); // Криво Если ТипЗнч(ЗаписьXML) = Тип("ЗаписьXML") Тогда СериализаторXDTO.ЗаписатьXML(ЗаписьXML, СтруктураОбъекта, НазначениеТипаXML.Явное); Иначе СериализаторXDTO.ЗаписатьJSON(ЗаписьXML, СтруктураОбъекта, НазначениеТипаXML.Явное); КонецЕсли; КонецПопытки; Результат = ЗаписьXML.Закрыть(); Возврат Результат; КонецФункции Процедура ЗагрузитьСнимок(Снимок) Экспорт ЧтениеXML = ирОбщий.ОптимальныйПотоковыйЧитательЛкс(); #Если Сервер И Не Сервер Тогда ЧтениеXML = Новый ЧтениеXML; #КонецЕсли ЧтениеXML.УстановитьСтроку(Снимок); Если ТипЗнч(ЧтениеXML) = Тип("ЗаписьXML") Тогда СтруктураОбъекта = СериализаторXDTO.ПрочитатьXML(ЧтениеXML); Иначе СтруктураОбъекта = СериализаторXDTO.ПрочитатьJSON(ЧтениеXML); КонецЕсли; ЧтениеXML.Закрыть(); ЗаполнитьЗначенияСвойств(ЭтотОбъект, СтруктураОбъекта,, "Данные"); Если Данные <> Неопределено Тогда Данные.Очистить(); ирОбщий.СкопироватьУниверсальнуюКоллекциюЛкс(СтруктураОбъекта.Данные, Данные); Иначе ЭтотОбъект.Данные = СтруктураОбъекта.Данные; КонецЕсли; КонецПроцедуры Функция КлючОбъекта() Результат = Данные.Ссылка; Если Истина И Не ЗначениеЗаполнено(Результат) И Данные.Свойство("ЭтоГруппа") И Данные.ЭтоГруппа Тогда Результат = Истина; КонецЕсли; Возврат Результат; КонецФункции Функция ОбъектБД(ВосстановитьДанные = Истина) Экспорт КлючОбъекта = КлючОбъекта(); ПолноеИмяТаблицы = ирОбщий.ПолучитьИмяТаблицыИзМетаданныхЛкс(Метаданные.НайтиПоТипу(_Тип)); Результат = ирОбщий.ОбъектБДПоКлючуЛкс(ПолноеИмяТаблицы, КлючОбъекта,, Ложь, Ложь).Данные; ирОбщий.СкопироватьУниверсальнуюКоллекциюЛкс(ДополнительныеСвойства, Результат.ДополнительныеСвойства); ирОбщий.ВосстановитьСтруктуруОбменаДаннымиОбъектаЛкс(Результат, ОбменДанными); Если ВосстановитьДанные Тогда Если Результат.Ссылка.Пустая() И ЗначениеЗаполнено(_СсылкаНового) Тогда Результат.УстановитьСсылкуНового(_СсылкаНового); КонецЕсли; ЗаполнитьЗначенияСвойств(Результат, Данные); СтруктураТЧ = ирОбщий.ПолучитьТабличныеЧастиОбъектаЛкс(Результат); Для Каждого КлючИЗначение Из СтруктураТЧ Цикл Результат[КлючИЗначение.Ключ].Загрузить(Данные[КлючИЗначение.Ключ]); КонецЦикла; КонецЕсли; Возврат Результат; КонецФункции Функция ПолучитьСсылкуНового() Экспорт Возврат _СсылкаНового; КонецФункции Функция Модифицированность() Экспорт Результат = _СчитанныйСнимок <> Снимок(Истина); Возврат Результат; КонецФункции Функция ЭтоНовый() Экспорт Результат = Данные.Ссылка.Пустая(); Возврат Результат; КонецФункции Функция ПолучитьКартуМаршрута() Экспорт ОбъектБД = ОбъектБД(); Результат = ОбъектБД.ПолучитьКартуМаршрута(); Возврат Результат; КонецФункции Процедура Прочитать(НаСервере = Истина) Экспорт Если НаСервере Тогда Снимок = Снимок(); ирСервер.ПрочитатьОбъектЧерезИмитаторЛкс(Снимок, ТипЗнч(ЭтотОбъект)); ЗагрузитьСнимок(Снимок); Иначе ОбъектБД = ОбъектБД(); ОбъектБД.Прочитать(); Конструктор(ОбъектБД); КонецЕсли; КонецПроцедуры Функция Скопировать(НаСервере = Истина) Экспорт Если НаСервере Тогда Снимок = Снимок(); Снимок = ирСервер.СкопироватьОбъектЧерезИмитаторЛкс(Снимок, ТипЗнч(ЭтотОбъект)); ИмитаторКопия = Новый (ТипЗнч(ЭтотОбъект)); ИмитаторКопия.ЗагрузитьСнимок(Снимок); Результат = Новый Структура; Результат.Вставить("Методы", ИмитаторКопия); Результат.Вставить("Данные", ИмитаторКопия.Данные); Иначе ОбъектБД = ОбъектБД(); ОбъектКопия = ОбъектБД.Скопировать(); ИмитаторКопия = Новый (ТипЗнч(ЭтотОбъект)); ИмитаторКопия.Конструктор(ОбъектКопия); Результат = ИмитаторКопия; КонецЕсли; Возврат Результат; КонецФункции Функция ДанныеВСтрокуXMLЧерезXDTO(Знач ИспользоватьXDTO = Истина, ВызыватьИсключение = Истина) Экспорт #Если Не Сервер Тогда Снимок = Снимок(); Результат = ирСервер.ОбъектБДИзИмитатораВСтрокуXMLЛкс(Снимок, ТипЗнч(ЭтотОбъект), ИспользоватьXDTO, ВызыватьИсключение); #Иначе ОбъектБД = ОбъектБД(); Результат = ирОбщий.СохранитьОбъектВВидеСтрокиXMLЛкс(ОбъектБД, ИспользоватьXDTO, , ВызыватьИсключение); #КонецЕсли Возврат Результат; КонецФункции Процедура ДанныеИзСтрокиXMLЧерезXDTO(СтрокаXML, Знач ИспользоватьXDTO = Истина, СообщатьОбОшибках = Истина) Экспорт #Если Не Сервер Тогда Снимок = ирСервер.ОбъектБДВИмитаторИзСтрокиXML(СтрокаXML, ТипЗнч(ЭтотОбъект), ИспользоватьXDTO, СообщатьОбОшибках); ЗагрузитьСнимок(Снимок); #Иначе ОбъектБД = ирОбщий.ВосстановитьОбъектИзСтрокиXMLЛкс(СтрокаXML,, ИспользоватьXDTO, СообщатьОбОшибках); Конструктор(ОбъектБД); #КонецЕсли КонецПроцедуры Процедура Записать(РежимЗаписи = Неопределено, РежимПроведения = Неопределено) Экспорт #Если Не Сервер Тогда Снимок = Снимок(); ирСервер.ЗаписатьОбъектXMLЛкс(Снимок,, РежимЗаписи, РежимПроведения,,, ТипЗнч(ЭтотОбъект)); ЗагрузитьСнимок(Снимок); #Иначе ОбъектБД = ОбъектБД(); Если РежимЗаписи <> Неопределено Тогда ОбъектБД.Записать(РежимЗаписи, РежимПроведения); Иначе ОбъектБД.Записать(); КонецЕсли; Конструктор(ОбъектБД); #КонецЕсли КонецПроцедуры Процедура УстановитьПометкуУдаления(НоваяПометка) Экспорт Если НоваяПометка = Данные.ПометкаУдаления Тогда Возврат; КонецЕсли; #Если Не Сервер Тогда Снимок = Снимок(); ирСервер.ЗаписатьОбъектXMLЛкс(Снимок,, "ПометкаУдаления",,,, ТипЗнч(ЭтотОбъект)); ЗагрузитьСнимок(Снимок); #Иначе ОбъектБД = ОбъектБД(Ложь); //Если ОбъектБД.Модифицированность() Тогда // ОбъектБД.Прочитать(); // Сделать: Надо найти и убрать установку модифированности //КонецЕсли; ОбъектБД.УстановитьПометкуУдаления(НоваяПометка); Конструктор(ОбъектБД); #КонецЕсли КонецПроцедуры Процедура Удалить() Экспорт #Если Не Сервер Тогда Снимок = Снимок(); ирСервер.УдалитьОбъектXMLЛкс(Снимок,, ТипЗнч(ЭтотОбъект)); #Иначе ОбъектБД = ОбъектБД(Ложь); ОбъектБД.Удалить(); #КонецЕсли КонецПроцедуры Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты) ОбъектБД = ОбъектБД(); Отказ = Не ОбъектБД.ПроверитьЗаполнение(); Конструктор(ОбъектБД); КонецПроцедуры Функция ЗаменитьИдентификаторОбъекта() Экспорт КонецФункции Процедура УстановитьНовыйКод(ПрефиксКода) Экспорт #Если Не Сервер Тогда Снимок = Снимок(); ирСервер.УстановитьНовыйКодXMLЛкс(Снимок, ПрефиксКода, ТипЗнч(ЭтотОбъект)); ЗагрузитьСнимок(Снимок); #Иначе ОбъектБД = ОбъектБД(); ОбъектБД.УстановитьНовыйКод(ПрефиксКода); Конструктор(ОбъектБД); #КонецЕсли КонецПроцедуры Процедура УстановитьНовыйНомер(ПрефиксНомера) Экспорт #Если Не Сервер Тогда Снимок = Снимок(); ирСервер.УстановитьНовыйКодXMLЛкс(Снимок, ПрефиксНомера, ТипЗнч(ЭтотОбъект)); ЗагрузитьСнимок(Снимок); #Иначе ОбъектБД = ОбъектБД(); ОбъектБД.УстановитьНовыйКод(ПрефиксНомера); Конструктор(ОбъектБД); #КонецЕсли КонецПроцедуры