OberonCore

Библиотека  Wiki  Форум  BlackBox  Компоненты  Проекты
Текущее время: Пятница, 13 Декабрь, 2019 05:31

Часовой пояс: UTC + 3 часа




Начать новую тему Ответить на тему  [ Сообщений: 43 ]  На страницу Пред.  1, 2, 3
Автор Сообщение
 Заголовок сообщения: Re: B01: HostFiles.NewWriter
СообщениеДобавлено: Четверг, 10 Октябрь, 2019 10:39 
Аватара пользователя

Зарегистрирован: Четверг, 08 Октябрь, 2009 15:00
Сообщения: 2481
Илья Ермаков писал(а):
Тут дело в том, что снять авост (привести в соответствие с документацией) - это ослабить предусловие. Это не рушит обратную совместимость!
И я практически уверен, что никто из разработчиков на ББ не полагался на авост как на часть штатного поведения в своих системах.

Поэтому снять его было вполне логичным, обратно совместимым решением, убирающим ещё проблему невозможности заранее узнать, доступен ли файл для записи или нет.

А менять интерфейс типа - это несовместимое изменение интерфейса.
И снятие каких-то признаков файла тогда уже стоило бы делать обходными путями (некая процедура Files.HandleMsg и подключаемые хуки от реализаций и т.п.).

Решение с NIL не позволяет дифференцировать ошибку на ранней стадии. Вот предположим программа стабильная, но раз в год выкидывает TRAP "разыменовывание NIL" при обращении к несуществующему Writer. Вы чешете репу, то ли память кончилась, то ли диск, то ли еще что. Ждем еще год следующего трапа. А тут вам сразу покажут, что файл был закрыт или он был открыт в режиме shared. Для отладки странных проблем Оминк сознательно сделали там ASSERT.

Ценность обратной совместимости большая. Согласен, что надо это учитывать. Но так и не сделать ничего, если ничего не сломать. Отчасти поэтому ушел из Центра, потому что тяжело мне такие дебаты даются. Вот вы бы там поактивнее обсуждали. Правильные мысли выражаете.


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: B01: HostFiles.NewWriter
СообщениеДобавлено: Четверг, 10 Октябрь, 2019 17:18 
Модератор
Аватара пользователя

Зарегистрирован: Понедельник, 14 Ноябрь, 2005 18:39
Сообщения: 9165
Откуда: Россия, Орёл
Так код трепа сам по себе тоже ничего не значит. Берётся факт регистра PC, по которому произошло исключение.

И тут уже один фиг, что выяснять, какая функция кинула трэп 20, или в каком выражении возвращён NIL. Хотя да, причина возврата NIL под вопросом.

А на Центр сил и времени бодаться не хватает.


Вернуться к началу
 Профиль  
 
 Заголовок сообщения: Re: B01: HostFiles.NewWriter
СообщениеДобавлено: Четверг, 10 Октябрь, 2019 23:15 
Аватара пользователя

Зарегистрирован: Пятница, 25 Ноябрь, 2005 12:02
Сообщения: 8215
Откуда: Троицк, Москва
ТрАп.

Треп читается по правилам как трёп.


Вернуться к началу
 Профиль  
 
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 43 ]  На страницу Пред.  1, 2, 3

Часовой пояс: UTC + 3 часа


Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 1


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Вся информация, размещаемая участниками на конференции (тексты сообщений, вложения и пр.) © 2005-2019, участники конференции «OberonCore», если специально не оговорено иное.
Администрация не несет ответственности за мнения, стиль и достоверность высказываний участников, равно как и за безопасность материалов, предоставляемых участниками во вложениях.
Без разрешения участников и ссылки на конференцию «OberonCore» любое воспроизведение и/или копирование высказываний полностью и/или по частям запрещено.
Powered by phpBB® Forum Software © phpBB Group
Русская поддержка phpBB