OberonCore https://forum.oberoncore.ru/ |
|
B01: HostFiles.NewWriter https://forum.oberoncore.ru/viewtopic.php?f=130&t=6169 |
Страница 3 из 3 |
Автор: | Иван Денисов [ Четверг, 10 Октябрь, 2019 10:39 ] |
Заголовок сообщения: | Re: B01: HostFiles.NewWriter |
Илья Ермаков писал(а): Тут дело в том, что снять авост (привести в соответствие с документацией) - это ослабить предусловие. Это не рушит обратную совместимость! И я практически уверен, что никто из разработчиков на ББ не полагался на авост как на часть штатного поведения в своих системах. Поэтому снять его было вполне логичным, обратно совместимым решением, убирающим ещё проблему невозможности заранее узнать, доступен ли файл для записи или нет. А менять интерфейс типа - это несовместимое изменение интерфейса. И снятие каких-то признаков файла тогда уже стоило бы делать обходными путями (некая процедура Files.HandleMsg и подключаемые хуки от реализаций и т.п.). Решение с NIL не позволяет дифференцировать ошибку на ранней стадии. Вот предположим программа стабильная, но раз в год выкидывает TRAP "разыменовывание NIL" при обращении к несуществующему Writer. Вы чешете репу, то ли память кончилась, то ли диск, то ли еще что. Ждем еще год следующего трапа. А тут вам сразу покажут, что файл был закрыт или он был открыт в режиме shared. Для отладки странных проблем Оминк сознательно сделали там ASSERT. Ценность обратной совместимости большая. Согласен, что надо это учитывать. Но так и не сделать ничего, если ничего не сломать. Отчасти поэтому ушел из Центра, потому что тяжело мне такие дебаты даются. Вот вы бы там поактивнее обсуждали. Правильные мысли выражаете. |
Автор: | Илья Ермаков [ Четверг, 10 Октябрь, 2019 17:18 ] |
Заголовок сообщения: | Re: B01: HostFiles.NewWriter |
Так код трепа сам по себе тоже ничего не значит. Берётся факт регистра PC, по которому произошло исключение. И тут уже один фиг, что выяснять, какая функция кинула трэп 20, или в каком выражении возвращён NIL. Хотя да, причина возврата NIL под вопросом. А на Центр сил и времени бодаться не хватает. |
Автор: | Info21 [ Четверг, 10 Октябрь, 2019 23:15 ] |
Заголовок сообщения: | Re: B01: HostFiles.NewWriter |
ТрАп. Треп читается по правилам как трёп. |
Страница 3 из 3 | Часовой пояс: UTC + 3 часа |
Powered by phpBB® Forum Software © phpBB Group https://www.phpbb.com/ |