LINUX.ORG.RU

Сообщения dimgel

 

Смарите какой шик. :)

Форум — Development

Захотелось мне проверить, будет ли вызываться memcmp() для невыровненных адресов. Или может оно там какой-нибудь instrinsic впаяет. Сижу ржу:

https://godbolt.org/z/6dWbP687e

Первый раз tail call optimization на сях-плюсях вижу, и как-то не задумывался, что оно не только к рекурсии применимо.

 , ,

dimgel
()

Кто-нить тестил, насколько Эльбрусы медленнее обращаются по невыровненным адресам?

Форум — Development

То, что обращение в принципе возможно, я нагуглил. Интересует просад по скорости при чтении/записи 64-битных слов. У amd64 он исчезающе мал, так что вопрос «упаковывать данные или нет» вообще не стоИт.

 

dimgel
()

Чё ей надо?

Форум — Development
#include <functional>

struct R {};
template<class... PP> void f(std::function<R(PP...)>) {}

struct P {};

int main() {
	// No matching function for call to 'f'.
	// Candidate template ignored: could not match 'std::function<R (PP...)>' against '(lambda at ...)'
	f([&](P) { return R{}; });

	// То же самое.
	// UPD: Впрочем, не совсем: тут could not match 'std::function<R (P, PP...)>'. Бред какой-то.
	f<P>([&](P) -> R { return R{}; });
}

 ,

dimgel
()

Ищу протокол и C-либы к нему: как UDP но с пакетами произвольного размера.

Форум — Development

Т.е. datagram, без подтверждения доставки, но с фрагментацией больших пакетов.

И чтобы сишная либа не выбрасывала хвост пакета если я ей буфер слишком маленький подсуну. Или например, чтобы я мог сначала спросить размер пакета, выделить буфер этого размера, и подсунуть этот буфер в recv().

Есть чё?

 , ,

dimgel
()

SPA (Single Page Application) с точки зрения юзера: голосуем реакциями!

Форум — Talks

Поскольку голосовалку если и подтвердят, то как обычно лет через 300, голосуем «палец вверх» / «палец вниз» своё отношение к SPA – КАК ЮЗЕРА (т.е. с т.з. usability), а не как программиста, SEO-шника, безопасника и т.п. – ПРИ ПРОЧИХ РАВНЫХ, в т.ч. при одинаковой нагрузке, прямоте рук программиста, размеру страниц (измеряемому количеством букв и картинок) и т.п.

В каментах накидаю аргументы, там голосуем «палец вверх» = «важный аргумент», «палец вниз» = «брехня это а не аргумент».

Погнали. :)

 ,

dimgel
()

C with C++, static non-const, void* casts, segfault

Форум — Development

А есть ли какие-нибудь отличия в поведении C и C++ при кастовании char* в void* и обратно?

А то я тут пишу плюсявый плагин к сявой софтине: из неё вызывается мой плюсявый callback f():

extern "C" void f() {
    static const char msg[] = "xxx";  
    g(msg, sizeof(msg) - 1);
}

void g(const char* data, size_t size) {
     сявая_структура x;
     x.data = data;
     x.size = size;
     сявый_вызов(x);
}

Если я уберу const с объявления msg внутри f(), и объявлю параметр data функции g() как const void*, а внутри напишу x.data = (char*)data, то всё сегфолтится. Почему?

 , ,

dimgel
()

Один `make install` имеет ли право создавать несколько /lib/pkgconfig/*.pc?

Форум — General

Есть у меня проектик X, в котором собирается две либы: libX-buildtime.so и libX-runtime.so. Как понятно из названий, они линкуются в непересекающихся случаях, поэтому писать для них общий pkgconfig с общей строкой:

Libs = -L${prefix}/lib -l:libX-buildtime.so -l:libX-runtime.so

коряво и глупо. Да и зависимости у buildtime и runtime тоже разные, так что строка Requires.private тоже должна различаться.

Отсюда сабжевый вопрос: насколько это корректно/коряво с точки зрения дистро-мейнтейнеров, если при установке ОДНОГО пакета, в /lib/pkgconfig создаётся ДВА файла: X-buildtime.pc и X-runtime.pc?

К слову, в этом же проекте собираются ещё buildtime-утилиты, которые линкуют libX-buildtime.so, но это пофиг: в .pc-файле они не фигурируют.

 ,

dimgel
()

Выгрузка из памяти ненужных ресурсов / глобальных переменных.

Форум — Development

Возьмём например Qt. Там есть xml-файл ресурсов resources.qrc, в который можно например картинки добавлять:

<RCC>
    <qresource prefix="/">
        <file>icons/hello.png</file>
        ...
    </qresource>
</RCC>

Компиляется он в сишный сорц, где все эти картинки заинлайнены как hex-литералы в глобальную переменную:

static const unsigned char qt_resource_data[] = {                                                                                                                                           
  // /blablabla/icons/hello.png                                                                                                                     
  0x0,0x0,0xb,0x5b, ...                                                                                                                                                                 
  ...
};
...

Что печалит: вот допустим загрузил я картинку в память (в объект QImage) из ресурсов – и больше мне эти ресурсы не нужны. Но они продолжают сидеть в памяти, фактически задвоение данных картинки. А если там не картинка (которая во-первых маленькая, а во-вторых в теории может и не копировать эти данные, а тупо хранить ссылку на них с флагом owner=false), а чего пообъёмнее?

Понятно, что можно тупо хранить ресурсы в отдельном файле и грузить его вручную. Но не хочется файлы плодить. Вдруг есть какая-нибудь фича в плане сабжа? Смутно помню, что винда умеет красиво в ресурсы в PE-файлах, но мне бы под лялих.

 , ,

dimgel
()

Правило не создаёт файл, но зависимости выполняются как будто файл обновлён.

Форум — Development
$ cat makefile
b: a
        cp a b
a:
        # noop

$ rm -f a; touch b; make
# noop
cp a b
cp: cannot stat 'a': No such file or directory
make: *** [makefile:2: b] Error 1

По правилу a понятно: target file не существует – выполняем команды. Что команд нет – не наши проблемы.

А по правилу b не понятно ни черта. Оба правила не .PHONY, файл b существует, a не существует – и правило тем не менее выполняется.

Либо make после отработки правила a вообще не считывает mtime(a) повторно, а тупо берёт текущее время – но это крайне дурацкое кроилово для тулзы, которая на каждый чих в шел форкается. Собственно, я тут вообще глупость написал: что mtime, что текущее время – один syscall.

Либо же явно закодировано: если файл-зависимость не существует после выполнения правила-зависимости, то выполняем зависимое как будто его mtime < mtime зависимости. А нахрена?

 ,

dimgel
()

QtCreator: add existing files/directory — как сделать чтобы не добавляло автоматом путь в .includes?

Форум — Development

Сабж. Задрало в конец. Это generic project если что.

 

dimgel
()

WebAssembly: юзать/нет? Отключение js браузерами/noscript/umatrix синхронно действует и на wasm?

Форум — Web-development

Здрасьти.

// Вводная: я люблю SPA, так что без JS моё поделие работать один хрен не будет.

Я тут прикидываю, что кое-какую логику можно перенести из JS в WebAssembly с целью снижения трафика. Но без понятия насчёт сабжа: каким боком это вылезет? Расскажите кто на какие косяки нарывался (как разраб или юзер)?

 ,

dimgel
()

GNU make: не работает ':='

Форум — Development

Имеется makefile:

all: bin lib

X := BIN
bin:
        @echo 'Hello $(X)'

X := LIB
lib:
        @echo 'Hello $(X)'

Вывод:

Hello LIB   <--- а мечтался BIN
Hello LIB

ЧЯДНТ?

Проблему поймал когда попытался заюзать временные переменные внутри define ... endef, который потом подавался на вход $(eval $(call ...)). Т.е. исходный вопрос на самом деле ещё замороченнее: как юзать временные переменные внутри таких вот самодельных «функций»?

 , ,

dimgel
()

А знаете как деплоить C++20 modules с библиотекой?

Форум — Development

А никак.

В доках GCC (ссылку не дам, уже потерял) прямым текстом сказано, что CMI (Compiled Module Interface) – формат не портабельный и может использоваться только для кеширования в процессе сборки. Он может меняться даже в зависимости от версии компилятора и целевой архитектуры, его смысл и scope примерно тот же что у precompiler headers. Что в общем естественно: компилятор сериализует туда свои внутренние структуры.

Следовательно, деплоить интерфейс модуля можно исключительно исходником. Т.е. если раньше было .h + .cpp, то теперь вместо .h у нас будет какой-нибудь .cppm – интерфейс модуля, который тоже надо деплоить вместе с либой, а в сорцах опять два исходника на модуль: .cppm + .cpp. Что поменялось? Расширение интерфейсного файла. Который теперь ещё и замусорен новыми кейвордами export и import.

Никаких намёков на попытки разработчиков компиляторов договориться о портабельном формате CMI и о расположении CMI-файлов внутри .a-архивов – не нагуглилось. Есть разве что вот такой пропозал в т.ч. про стандартный маппинг имён модулей на имена файлов, но читать его печально. Ну, может моим правнукам, работающим в поле пока светло, голубиная почта принесёт добрые вести.

Тьфу. Ни одну фичу не могут сразу нормально и ДО КОНЦА проработать.

 ,

dimgel
()

Есть ли задержки между write и read в unix domain sockets?

Форум — Development

Т.е. открыл я /run/my-socket, сишу слушаю, акцептю, пишу-читаю, всё non-blocking (select(2)).

  1. Полагаю, внутри ядра такое accepted connection для локального unix domain socket – реализовано как обычный pipe?

  2. Когда одна сторона пишет, мгновенно ли другой стороне прилетают данные (non-blocking просыпается из select(), клиентский blocking read() возвращает управление), или там может буферизация какая или ещё какая дичь?

 ,

dimgel
()

Печалит меня отсутствие в firefox поддержки DecompressionStream.

Форум — Web-development

@MozillaFirefox, чёзафигня?

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

А вот в хроме и edge всё есть. Особенно дико выглядит описание API на MDN: описание есть, а самого API нет.

 ,

dimgel
()

Как читать буфер памяти посимвольно в заданной кодировке?

Форум — Development

Здрасьти.

Хочу что-то такое:

uint8_t* buf = { open(argv[1]); бинарный read(); close(); buf[filesize] = 0; }
чтото_типа_set_charset_for_getc(argv[2]);
while ((int c = чтото_типа_getc(buf)) != 0) {
    блаблабла мистер Фримен;
}

Можно конечно тупо сконвертнуть весь буфер в wstring и потом работать с ним как белый человек. Но мой внутренний байтодрочер ужасается от sizeof(wchar_t) и подозревает, что посимвольно читать буфер будет быстрее.


SOLVED:

(1) тыц, тыц.

(2) Для парсинга сорцов это всё не нужно, по крайней мере поначалу.

 , ,

dimgel
()

Хочу залить на гитхаб опен-сорц с русскими каментами/доками/README.

Форум — Talks

Чтобы, значит, и рунглишом ни себя ни других не мучить, и чтобы, значит, своим распрекрасным и сверхнужным кодом поддержать отечественных программистов в их трудной борьбе конкуренции с буржуями.

Отговорите.

Кстати 1: а разрабы Astra Linux (или что там у нас для госорганов сертифицировано) в своём коде по-английски каментят?

Кстати 2, чтобы 2 раза не вставать: а внутри РФ вообще имеют смысл такие слова как GPL? В т.ч. с точки зрения суда.

 ,

dimgel
()

wine 7 белый плоский GUI

Форум — Desktop

Обновил wine 6.22 на 7.7. (Долго тянул т.к. глючная дрянь этот ваш wine.) Вид всех контролов в прогах (дочерних окон в MDI, кнопок, таблиц и т.п.) стал отвратительным: бьющим по глазам ярко белым и плоским. Весь гуй превратился в равномерно-ярко-белое пятно. В т.ч. в самом winecfg: тут не вполне белый, но светло-серый и тоже плоский (e.g. кнопки того же цвета что фон окна). Как вернуть взад?

 , ,

dimgel
()

Вышел QtCreator 7, в котором clangd включён по дефолту.

Форум — Talks

Конец тормозам. УРА ТОВАРИЩИ!!!

 ,

dimgel
()

mount bind + mount tmpfs на поддиректорию.

Форум — Admin
fstab:
tmpfs  /a/b  tmpfs  size=1M  0 0
/a1  /a  auto  bind  0 0
/a2  /a  auto  bind  0 0

Независимо от того, монтирую я /a/b до или после /a1 и /a2, оно не видно в /a1/b и /a2/b/. Т.е. делаю touch /a/b/xxx – и xxx не виден в /a1/b и /a2/b. А хочется чтобы был виден, т.е. чтобы /a/b, /a1/b и /a2/b ссылались на один и тот же tmpfs. Можно ли как-нибудь вылечить?

 

dimgel
()

RSS подписка на новые темы