Api cleanup

This commit is contained in:
Frank 2021-08-06 23:29:41 +02:00
parent 3438c86de2
commit 4d3f7aa34b

View file

@ -23,132 +23,141 @@ import java.util.function.Function;
import java.util.function.Predicate; import java.util.function.Predicate;
public class DataExchangeAPI extends DataExchange { public class DataExchangeAPI extends DataExchange {
private final static List<String> MODS = Lists.newArrayList(); private final static List<String> MODS = Lists.newArrayList();
/** /**
* You should never need to create a custom instance of this Object. * You should never need to create a custom instance of this Object.
*/ */
public DataExchangeAPI() { public DataExchangeAPI() {
super(); super();
} }
@Environment(EnvType.CLIENT) @Environment(EnvType.CLIENT)
protected ConnectorClientside clientSupplier(DataExchange api) { protected ConnectorClientside clientSupplier(DataExchange api) {
return new ConnectorClientside(api); return new ConnectorClientside(api);
} }
protected ConnectorServerside serverSupplier(DataExchange api) { protected ConnectorServerside serverSupplier(DataExchange api) {
return new ConnectorServerside(api); return new ConnectorServerside(api);
} }
/** /**
* Register a mod to participate in the DataExchange. * Register a mod to participate in the DataExchange.
* *
* @param modID - {@link String} modID. * @param modID - {@link String} modID.
*/ */
public static void registerMod(String modID) { public static void registerMod(String modID) {
MODS.add(modID); MODS.add(modID);
} }
/** /**
* Returns the IDs of all registered Mods. * Returns the IDs of all registered Mods.
* @return List of modIDs *
*/ * @return List of modIDs
public static List<String> registeredMods(){ */
return MODS; public static List<String> registeredMods() {
} return MODS;
}
/** /**
* Add a new Descriptor for a {@link DataHandler}. * Add a new Descriptor for a {@link DataHandler}.
* @param desc The Descriptor you want to add. *
*/ * @param desc The Descriptor you want to add.
public static void registerDescriptor(DataHandlerDescriptor desc){ */
DataExchange api = DataExchange.getInstance(); public static void registerDescriptor(DataHandlerDescriptor desc) {
api.getDescriptors().add(desc); DataExchange api = DataExchange.getInstance();
} api.getDescriptors().add(desc);
}
/** /**
* Bulk-Add a Descriptors for your {@link DataHandler}-Objects. * Bulk-Add a Descriptors for your {@link DataHandler}-Objects.
* @param desc The Descriptors you want to add. *
*/ * @param desc The Descriptors you want to add.
public static void registerDescriptors(List<DataHandlerDescriptor> desc){ */
DataExchange api = DataExchange.getInstance(); public static void registerDescriptors(List<DataHandlerDescriptor> desc) {
api.getDescriptors().addAll(desc); DataExchange api = DataExchange.getInstance();
} api.getDescriptors().addAll(desc);
}
/** /**
* Sends the Handler. * Sends the Handler.
* <p> * <p>
* Depending on what the result of {@link DataHandler#getOriginatesOnServer()}, the Data is sent from the server * Depending on what the result of {@link DataHandler#getOriginatesOnServer()}, the Data is sent from the server
* to the client (if {@code true}) or the other way around. * to the client (if {@code true}) or the other way around.
* <p> * <p>
* The method {@link DataHandler#serializeData(FriendlyByteBuf)} is called just before the data is sent. You should * The method {@link DataHandler#serializeData(FriendlyByteBuf)} is called just before the data is sent. You should
* use this method to add the Data you need to the communication. * use this method to add the Data you need to the communication.
* @param h The Data that you want to send *
*/ * @param h The Data that you want to send
public static void send(DataHandler h){ */
if (h.getOriginatesOnServer()){ public static void send(DataHandler h) {
DataExchangeAPI.getInstance().server.sendToClient(h); if (h.getOriginatesOnServer()) {
} else { DataExchangeAPI.getInstance().server.sendToClient(h);
DataExchangeAPI.getInstance().client.sendToServer(h); } else {
} DataExchangeAPI.getInstance().client.sendToServer(h);
} }
}
/** /**
* Registers a File for automatic client syncing. * Registers a File for automatic client syncing.
* *
* @param modID The ID of the calling Mod * @param modID The ID of the calling Mod
* @param fileName The name of the File * @param fileName The name of the File
*/ */
public static void addAutoSyncFile(String modID, File fileName){ public static void addAutoSyncFile(String modID, File fileName) {
getInstance().addAutoSyncFileData(modID, fileName, false, FileHash.NEED_TRANSFER); getInstance().addAutoSyncFileData(modID, fileName, false, FileHash.NEED_TRANSFER);
} }
/** /**
* Registers a File for automatic client syncing. * Registers a File for automatic client syncing.
* * <p>
* @param modID The ID of the calling Mod * The file is synced of the {@link FileHash} on client and server are not equal. This method will not copy the
* @param uniqueID A unique Identifier for the File. (see {@link ru.bclib.api.dataexchange.FileHash#uniqueID} for * configs content from the client to the server.
* Details *
* @param fileName The name of the File * @param modID The ID of the calling Mod
*/ * @param uniqueID A unique Identifier for the File. (see {@link ru.bclib.api.dataexchange.FileHash#uniqueID} for
public static void addAutoSyncFile(String modID, String uniqueID, File fileName){ * Details
getInstance().addAutoSyncFileData(modID, uniqueID, fileName, false, FileHash.NEED_TRANSFER); * @param fileName The name of the File
} */
public static void addAutoSyncFile(String modID, String uniqueID, File fileName) {
getInstance().addAutoSyncFileData(modID, uniqueID, fileName, false, FileHash.NEED_TRANSFER);
}
/** /**
* Registers a File for automatic client syncing. * Registers a File for automatic client syncing.
* * <p>
* @param modID The ID of the calling Mod * The content of the file is requested for comparison. This will copy the
* @param fileName The name of the File * entire file from the client to the server.
* @param requestContent When {@code true} the content of the file is requested for comparison. This will copy the * <p>
* entire file from the client to the server. * You should only use this option, if you need to compare parts of the file in order to decide
* <p> * if the File needs to be copied. Normally using the {@link ru.bclib.api.dataexchange.FileHash}
* You should only use this option, if you need to compare parts of the file in order to decide * for comparison is sufficient.
* If the File needs to be copied. Normally using the {@link ru.bclib.api.dataexchange.FileHash} *
* for comparison is sufficient. * @param modID The ID of the calling Mod
* @param needTransfer If the predicate returns true, the file needs to get copied to the server. * @param fileName The name of the File
*/ * @param needTransfer If the predicate returns true, the file needs to get copied to the server.
public static void addAutoSyncFile(String modID, File fileName, boolean requestContent, NeedTransferPredicate needTransfer){ */
getInstance().addAutoSyncFileData(modID, fileName, requestContent, needTransfer); public static void addAutoSyncFile(String modID, File fileName, NeedTransferPredicate needTransfer) {
} getInstance().addAutoSyncFileData(modID, fileName, true, needTransfer);
}
/** /**
* Registers a File for automatic client syncing. * Registers a File for automatic client syncing.
* * <p>
* @param modID The ID of the calling Mod * The content of the file is requested for comparison. This will copy the
* @param uniqueID A unique Identifier for the File. (see {@link ru.bclib.api.dataexchange.FileHash#uniqueID} for * entire file from the client to the server.
* Details * <p>
* @param fileName The name of the File * You should only use this option, if you need to compare parts of the file in order to decide
* @param requestContent When {@code true} the content of the file is requested for comparison. This will copy the * if the File needs to be copied. Normally using the {@link ru.bclib.api.dataexchange.FileHash}
* entire file from the client to the server. * for comparison is sufficient.
* <p> *
* You should only use this option, if you need to compare parts of the file in order to decide * @param modID The ID of the calling Mod
* If the File needs to be copied. Normally using the {@link ru.bclib.api.dataexchange.FileHash} * @param uniqueID A unique Identifier for the File. (see {@link ru.bclib.api.dataexchange.FileHash#uniqueID} for
* for comparison is sufficient. * Details
* @param needTransfer If the predicate returns true, the file needs to get copied to the server. * @param fileName The name of the File
*/ * @param needTransfer If the predicate returns true, the file needs to get copied to the server.
public static void addAutoSyncFile(String modID, String uniqueID, File fileName, boolean requestContent, NeedTransferPredicate needTransfer){ */
getInstance().addAutoSyncFileData(modID, uniqueID, fileName, requestContent, needTransfer); public static void addAutoSyncFile(String modID, String uniqueID, File fileName, NeedTransferPredicate needTransfer) {
} getInstance().addAutoSyncFileData(modID, uniqueID, fileName, true, needTransfer);
}
} }