User Tools

Site Tools


ru:documentation:entrypoint

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Next revision
Previous revision
ru:documentation:entrypoint [2022/03/26 22:07] – created furnygoru:documentation:entrypoint [2022/03/27 22:36] (current) – external edit 127.0.0.1
Line 41: Line 41:
 ==== Типы ссылок на код ==== ==== Типы ссылок на код ====
  
-Ссылка на код точки входа преобразуется в экземпляр типа прототипа точки входа. Наиболее распространенный способ создания точки входа - это ссылка на класс, который реализует ожидаемый тип, но эти ссылки на код могут быть сделаны несколькими способами. Внутренне языковой адаптер отвечает за интерпретацию ссылок и превращение их в экземпляры. Языковой адаптер по умолчанию предназначен для кода Java и, таким образом, поддерживает следующие типы ссылок:\\+Ссылка на код точки входа преобразуется в экземпляр типа прототипа точки входа. Наиболее распространенный способ создания точки входа - это ссылка на класс, который реализует ожидаемый тип, но эти ссылки на код могут быть сделаны несколькими способами. Внутренне языковой адаптер отвечает за интерпретацию ссылок и превращение их в экземпляры. Языковой адаптер по умолчанию предназначен для кода Java и, таким образом, поддерживает следующие типы ссылок:
  
-**Будет переведено позже** +  * **Ссылка на класс**: например, ''net.fabricmc.example.ExampleMod'' относится к неабстрактному классу с этим именемКласс должен иметь открытый конструктор без аргументовКласс должен реализовывать или расширять ожидаемый типКонечный объект является новым экземпляром класса
------ +  * **Ссылка на метод**: например, ''net.fabricmc.example.ExampleMod::method'' сылается на открытый метод в этом классе с таким именемЕсли метод нестатичендля вызываемого метода создается новый экземпляр классачто означает, что класс должен быть неабстрактным, а также иметь открытый конструктор без аргументовМетоды могут использоваться только для типов интерфейсовМетод должен принимать те же аргументы и иметь тот же возвращаемый тип, что и абстрактные методы в интерфейсеКонечное значение представляет собой прокси-реализацию интерфейсакоторая будет реализовывать абстрактные методы путем делегирования этому методу
-  * **Ссылка на класс**: ex. ''net.fabricmc.example.ExampleMod'' refers to the non-abstract class by this nameThe class must have a public constructor with no argumentsThe class must implement or extend the expected typeThe resulting object is a new instance of the class+  * **Ссылка на статическое поле**: например, ''net.fabricmc.example.ExampleMod::field'' ссылается на поле в этом классе с таким именемПоле должно быть статическим и общедоступнымТип поля должен быть совместим с ожидаемым типомКонечное значение - это значение этого поля.
-  * **Ссылка на метод**: ex. ''net.fabricmc.example.ExampleMod::method'' refers to a public method in that class by that nameIf the method is nonstatica new instance of the class is constructed for the method to be called onmeaning the class must be non-abstract and also have a public constructor with no argumentsMethods can only be used for interface typesThe method must accept the same arguments and have the same return type as the abstract method(s) in the interfaceThe resulting value is a proxy implementation of the interfacewhich will implement abstract methods by delegating to this method+
-  * **Ссылка на статическое поле**: ex. ''net.fabricmc.example.ExampleMod::field'' refers to the field in that class by that nameThe field must be static and publicThe the type of the field must be compatible with the expected typeThe resuling value is the value of that field.+
  
-References to class members must be unambiguousmeaning the class must contain one and only one field or method with the targeted nameThe language adapter cannot resolve methods overloadsIn case of ambiguity, the entrypoint will fail to resolve.+Ссылки на члены класса должны быть однозначнымичто означает, что класс должен содержать одно и только одно поле или метод с целевым именемЯзыковой адаптер не может разрешить перегрузки методовВ случае двусмысленности точка входа не будет разрешена.
  
-Language adapters for other languages can be implemented by mods. [[https://github.com/FabricMC/fabric-language-kotlin|fabric-language-kotlin]] provides a language adapter for Kotlin.+Языковые адаптеры для других языков могут быть реализованы модами. [[https://github.com/FabricMC/fabric-language-kotlin|fabric-language-kotlin]] предоставляет языковой адаптер для Kotlin.
  
 ==== Другие приложения точек входа ==== ==== Другие приложения точек входа ====
  
-Mods can call each others' entrypoints for integration purposesAn entrypoint is loaded lazily when entrypoints for a specific entrypoint prototype are requestedwhich makes an entrypoint an excellent tool for optional mod integrationsA mod may become an entrypoint prototype provider by declaring that other mods should provide entrypoints based on an entrypoint prototypeoften using a class or interface that the mod provides in its API. Mods can safely use this class or interface even if the provider is not installed (rendering the class or interface inaccessiblebecause entrypoints are loaded only on requestWhen the provider is not presentthe entrypoint will simply be ignored.+Моды могут вызывать точки входа друг друга в целях интеграцииТочка входа загружается ленивокогда запрашиваются точки входа для определенного прототипа точки входа, что делает точку входа отличным инструментом для дополнительной интеграции модовМод может стать поставщиком прототипа точки входаобъявив, что другие моды должны предоставлять точки входа на основе прототипа точки входа, часто используя класс или интерфейс, который мод предоставляет в своем API. Моды могут безопасно использовать этот класс или интерфейс, даже если поставщик не установлен (что делает класс или интерфейс недоступными), поскольку точки входа загружаются только по запросуКогда провайдер отсутствуетточка входа будет просто проигнорирована.
  
-Entrypoint instances can be accessed by calling ''FabricLoader#getEntrypointContainers(nametype)''This returns a list of entrypoint containersThese containers contain the entrypoint instance and the mod container of the mod which provided the instanceThis can be used by a mod to determine which mods have registered an entrypoint.+Доступ к экземплярам точкам входа можно получить, вызвав ''FabricLoader#getEntrypointContainers(имятип)''Это возвращает список контейнеров точки входаЭти контейнеры содержат экземпляр точки хода и контейнер  мода, который предоставил экземплярЭто может быть использовано модом для определения того, какие моды зарегистрировали точку входа.
  
-Entrypoint instances are memoized by their name and also their typeUsing the same code reference for multiple entrypoints will result in multiple instancesThough highly absurd in practiceif ''getEntrypoints'' is called multiple times with the same name but different typesinstances are constructed and memoized per type.+Экземпляры точек входа запоминаются по их имени, а также по их типуИспользование одной и той же ссылки на код для нескольких точек входа приведет к созданию нескольких экземпляровХотя на практике это крайне абсурдноесли ''getEntrypoints'' вызывается несколько раз с одним и тем же именем, но разных типовэкземпляры создаются и запоминаются для каждого типа.
  
 ==== Примечание о порядке загрузки и фазах (или их отсутствии) ==== ==== Примечание о порядке загрузки и фазах (или их отсутствии) ====
  
-Fabric Loader does not have a concept of a load order or loading phasesInitializer entrypoints are the mechanism with which most mod loading is usually donebut whether or not an initializer has been called does not determine whether or not a mod can be considered to be "loaded"Thusit is unreasonable to expect that a mod has completed its modifications to the game after its initializers have been calledAdditionallythe order in which entrypoints are called is mostly undefined and cannot be alteredThe only guarantee is that a list of initializers in a fabric.mod.json file are called in the order in which they are declared. Fabric Loader does not provide multiple phases of initializers to work around the lack of order, either.+Fabric Loader не имеет понятия о порядке загрузки или фазах загрузкиТочки входа инициализатора - это механизмс помощью которого обычно выполняется большая часть загрузки модов, но независимо от того, был ли вызван инициализатор или нет, не определяет, можно ли считать мод "загруженным"Таким образомнеразумно ожидать, что мод завершил свои изменения в игре после того, как были вызваны его инициализаторыКроме тогопорядок, в котором вызываются точки входа, в основном не определен и не может быть измененЕдинственной гарантией является то, что список инициализаторов в файле fabric.mod.json вызывается в том порядке, в котором они объявлены. Fabric Loader также не предоставляет несколько этапов инициализаторов для решения проблемы отсутствия порядка.
  
-common example is the expectation that mod A should be able to load after mod because mod will replace an object registered by mod B. Alternativelymod wants to be loaded before mod because mod will do something in response to a registration performed by mod C. This is cannot be done for two reasons:+Распространенным примером является ожидание того, что мод должен иметь возможность загружаться после мода B, потому что мод заменит объект, зарегистрированный модом B. В качестве альтернативымод хочет быть загружен до мода D, потому что мод сделает что-то в ответ на регистрацию, выполняемую модом C. Это невозможно сделать по двум причинам:
  
-  - Mod initializers are not required to represent a transition in a "mod loading lifecycleso that after the initializer is calledall its registry objects are registered+  - Инициализаторы модов не требуются для представления перехода в "жизненном цикле загрузки модов", чтобы после вызова инициализатора регистрировались все его объекты реестра
-  - The order in which mod initializers are called is undefinedand cannot be influenced so that mod A's initializers are called after mod B's initializers, or so that mod C's initializers are called before mod D's initializers.+  - Порядокв котором вызываются инициализаторы мод, не определен, и на него нельзя повлиять, чтобы инициализаторы мода вызывались после инициализаторов мода или чтобы инициализаторы мода вызывались перед инициализаторами мода D.
  
-Leaving aside the missing guarantee of registration of all objects in initializersone might argue that there should therefore be other entrypoints to perform "pre-initializationand "post-initializationso that there is a sense of orderThis creates a multi-phase loading schemewhich in practice creates issues with the establishment of conventions for which operations are to be performed in which phaseuncertainty and lack of adherence to these conventions and outliers which do not fit.+Оставляя в стороне отсутствующую гарантию регистрации всех объектов в инициализаторахможно утверждать, что поэтому должны быть другие точки входа для выполнения "пре-инициализациии "пост-инициализации", чтобы было ощущение порядкаЭто создает многофазную схему загрузки, которая на практике создает проблемы с установлением соглашений, для которых операции должны выполняться на каком этапе, неопределенность и несоблюдение этих соглашенийа также выбросыкоторые не соответствуют.
ru/documentation/entrypoint.1648332423.txt.gz · Last modified: 2022/03/26 22:07 by furnygo