Это все началось, потому что я хотел man-страницы по типам / функциям C++. Я нашел репозиторий под названием Cppman , предназначенный для очистки этих страниц от cplusplus или cppreference. В этот момент man std::cout
отобразит ожидаемую man-страницу, но man -k cout
скажет «ничего не подходит».
С тех пор я удалил все, кроме папки cplusplus.com, переименовал ее в «man3» и запустил mandb
(от имени пользователя root, а затем и от меня), который создал пустую папку «cat3» и «index.db». Теперь я устанавливаю MANPATH следующим образом:
old_manpath=$(manpath 2>/dev/null)
export MANPATH=$HOME/.local/share/man:$old_manpath
Результат:
> man -k std::cout
std::cout (3) - Standard output stream
> man -k std::result_of
std::result_of (3) - Result of call
std::result_of (3cxx) - (unknown subject)
> man 3 std::result_of # the page I expect
> man 3cxx std::result_of # scrawny and malformed manpage
Если бы я мог просто спрятать эти страницы «3cxx» от man [-k]
, я был бы доволен. Тем не менее, я бы предпочел удалить файлы и не создавать их в первую очередь. У меня нет файлов '* .3cxx.gz'.
Где я неправ? Как и где я должен установить свою ПЗРК, если это действительно проблема?
Правка 1 - я снял много деталей с этого вопроса, но содержание справочных страниц 3cxx может показывать. Например, man 3cxx std::result_of
имеет заголовок std::result_of< _Signature >(3cxx)
(<_Signature>
отсутствует на обычной man-странице); ОПИСАНИЕ пусто, за которым следует "Подробное описание" вместо "ОПИСАНИЕ". Я попытался повторить то, на что это похоже ниже (подчеркивания представляют отступ.)
Подробное описание
____ шаблон <typename _Signature>
________ класс std::result_of <_Signature> "result_of
_______________ Определение в строке 2097 файла type_traits.
Эта паразитная "
как написано, и появляется сразу после основного типа на нескольких других страницах, которые я проверил. У страниц, которые отклонялись, все еще были некоторые несоответствующие кавычки после типов далее вниз по странице, или в конце строк, даже не включая шаблоны.
Редактировать 2 - я не могу понять, как найти файл, связанный с отображаемой man-страницей, или я могу проверить / удалить весь пакет. Используя lsof
я не вижу ничего похожего на открытую man-страницу, не то чтобы я ожидал, что файл останется открытым. Мое лучшее предположение, что эти короткие страницы запекаются в index.db
, файле базы данных "dbm / ndbm"; У меня есть пакет python3-gdbm
, поэтому я ткнул в него и обнаружил, что он имеет тип 'dbm.gnu', а его "первая" запись - b'std::list::cend\x00' => b'-\t3\t3\t1509183341\t749359924\tA\t-\t-\tgz\tReturn const_iterator to end\x00'
. Это подсказало бы мне, что index.db хранит только пары имя / описание, и, возможно, некоторые из этих чисел в заголовке будут соответствовать файлу, но даже тогда, как это больше, чем я могу надеяться выяснить, не увидев его в действии , Я думаю, что это насколько я могу управлять в одиночку.
Редактировать 3 - я расшифровал записи:
>>> from dbm.gnu import *
>>> o=open('/home/john/.local/share/man/index.db', 'c')
>>> def nextn(i,n):
... sum=""
... for j in range(0,n):
... sum += i.decode("utf-8") + "\n" + o[i].decode("utf-8")
... i=o.nextkey(i)
... return sum
>>> all=nextn(o.firstkey(), len(o.keys()))
>>> all.find('cxx')
-1
# Example entry for reference:
std::list::cend
- 3 3 1509183341 749359924 A - - gz Return const_iterator to end
Записи расположены в хэш (квазислучайном) порядке, поэтому хороший пример их должен показать примерно столько же записей типа «3cxx», сколько и типа «3». Вместо этого они буквально все типа «3». Index.db снят с крючка, но у меня официально нет идей.