internalA() При этом internalA используется в двух первых, но я бы не хотел его делать public. Какой есть способ это сделать или как то обозначить?
Только не делать первые два inline
@PublishedApi @JvmSynthetic internal
ну инлайн подразумевает, что во время компиляции байт код поставит туда байткод инлайн метода, вместо его вызова грубо говоря, во время компиляции будет вызываться internalA() и если он не публик, то ничего не получится, можно также internal сделать для inline функций
Есть @PublishedApi. И по идее вы даже эту функцию можете удалить потом без последствий.
У меня kotlin common
Как это без последствий? Это ж публичное апи джарника.
Так они ж тоже никуда не деваются. Нет, это, конечно, чисто формальная поломка, но всё же поломка.
Ну смотри: есть инлайн-функция, которую снаружи не видно. Во всех местах вызова она заинлайнена, т.е. не используется в скомпилированном коде напрямую. Соответственно, её можно смело вырезать.
Ладно, я бы поверил выводу котлиновского валидатора аби, но мне не настолько интересен этот кейс, чтобы идти его расчехлять 😅
Нельзя удалить без последствий. The declaration becomes effectively public, and this should be considered with respect to binary compatibility maintaining.
Ну он скорее всего увидит @PublishedApi и всё. Надо спрашивать про этот кейс у тех, кто его пишет) Да и в общем случае это наверное небезопасно, если в своём коде делать с этой функцией что-то такое, что на неё будет ссылка в байкткоде.
Я выше писал, почему я так считаю
Ну вот моё понимание, что делаешь ты с ней что-то, не делаешь, а она всё равно часть публичного интерфейса джарника -> её удаление -- поломка публичного аби. Не берусь утверждать, так ли это для котлиновских клиентов, но в общем случае для жвм -- так, по идее.
Но ведь все клиенты этой функции - строго твой код. Если internal функцию видно из джавы - это уже другая история.
Могут быть транзитивные зависимости. Если твоя либа используются двумя другими, и каждая использует свою версию.
А есть гарантии, что джавовый код не дёргает эту функцию?
И что это меняет? Исходная internal функция заинлайнена в этом же модуле. Снаружи можно вызвать только те функции, которые уже содержат её в своём теле, не вызывая.
Если сама publishedapi функция inline, то может быть и ок. Иначе точно не ок
Если в джавовом коде видно internal - это само по себе проблема посерьёзнее. @Harmonizr предлагал заодно @JvmSynthetic накинуть, но я сам не знаю, надо ли это.
Ну так я именно про этот случай. В других - конечно не ок.
Ну да синтетик аннотация из джавы не может дать найти этот метод), при автокомплите
Аа тогда извиняюсь. Но я бы проверил все равно.
Чёрт, ну и дела
Обсуждают сегодня