Documentation and Logs
Releases: 1 to 2 versions are released every month, and upgrades within a major version are always compatible, such as 21.1 is upgraded to any higher version 21.x
Version update summary
perf(room): OperationHandler adds the processVerify method to control whether the process method is executed, and deprecates the verify method, which is replaced by processVerify.
perf(core): Optimize BoolValue and reduce the creation of objects
perf(net-core): Enhance the invokeModuleMessage and invokeModuleCollectMessage methods of the BrokerClientItem. The return value must not be null, and error information is added.
fix(generate-code): action_method_void.txt
perf(doc): GameCode Support single parameter construction method
perf(kit): #412
perf(room): Player adds isRobot method. Room adds methods to distinguish between real players and robot players.
refactor(proto): #414 Enumeration supports custom value
perf(room): room add hasSeat、isRealPlayer method
refactor(kit): RandomKit add randomLong method
refactor(core): Because the FlowContext method name setUserId is ambiguous, the method name is deprecated.
- Deprecated FlowContext setUserId method; see bindingUserId.
- Deprecated FlowContext setUserIdAndGetResult method; see bindingUserIdAndGetResult.
refactor(core): broadcastMe Added Tip: Please bind UserId before using this method, see FlowContext.bindingUserId.
perf(proto): Generate .proto files in parallel
refactor(proto): ProtoGenerateFile supports adding multiple proto packages
refactor(kit): TaskKit supports setting Timer
refactor(room): Deprecated OperationHandler verify, see processVerify
refactor(room): Add OperationCode and enhance Operation
About [core]
The name of the FlowContext setUserId method is ambiguous. This method is deprecated and replaced by the bindingUserId method.
flowContext.setUserId(userId); // Deprecated
flowContext.bindingUserId(userId); // now
About [kit]
TaskKit supports setting Timer
TaskKit.setTimer(new HashedWheelTimer(17, TimeUnit.MILLISECONDS));
About [room]
- Add hasSeat method to room to check whether there are any empty seats in the room.
- Room add isRealPlayer method.
- Add isRobot method to Player, and add method to distinguish real players from robot players to Room.
- Add OperationCode and enhance Operation
- Add processVerify method to OperationHandler to control whether to execute process method, and deprecate verify method, replaced by processVerify.
When processVerify returns false, process method will not be executed. There is an assertion mechanism in processVerify, and when there is no seat, an error code will be sent to the client to prompt the player.
public final class EnterRoomOperationHandler implements OperationHandler {
@Override
public boolean processVerify(PlayerOperationContext context) {
// assert room spaceSize
Room room = context.getRoom();
GameCode.roomSpaceSizeNotEnough.assertTrue(room.hasSeat());
long userId = context.getUserId();
long score = AccountKit.getScore(userId);
return score > 500;
}
@Override
public void process(PlayerOperationContext context) {
Room room = context.getRoom();
... enterRoom
}
}
Example of combining OperationCode with enumeration
@ProtobufClass
@ProtoFileMerge(fileName = FileMerge.fileName, filePackage = FileMerge.filePackage)
public enum MyOperation implements OperationCode {
/** quitRoom */
quitRoom,
/** inRoom */
inRoom
;
final int operationCode;
FairOperation() {
this.operationCode = OperationCode.getAndIncrementCode();
}
@Override
public int getOperationCode() {
return operationCode;
}
}
// config
public void configOperation() {
RoomService roomService = ...
OperationFactory factory = roomService.getOperationFactory();
// mappingUser operation
factory.mappingUser(MyOperation.inRoom, new InRoomOperationHandler());
factory.mappingUser(MyOperation.quitRoom, new QuitRoomOperationHandler());
}
About [proto]
-
Optimize .proto generation and process file generation in parallel.
-
ProtoGenerateFile supports adding multiple proto packages
Supports adding multiple proto packages to better support modularization
private static void generateProtoFile() {
String generateFolder = "/Users/join/gitme/game/MyGames/proto";
List<String> protoPackageList = List.of("com.iohao.happy.robot"
,"com.iohao.happy.email");
var protoGenerateFile = new ProtoGenerateFile()
// Generate the directory where the .proto file is stored
.setGenerateFolder(generateFolder)
// The package name to be scanned
.addProtoPackage(protoPackageList)
.addProtoPackage("com.iohao.happy.common.provide.proto");
// generate .proto
protoGenerateFile.generate();
}
- Enumeration supports custom values, java code and generated .proto
@ProtobufClass
@ProtoFileMerge(fileName = TempProtoFile.fileName, filePackage = TempProtoFile.filePackage)
public enum AnimalTypeEnum implements EnumReadable {
/** the cat */
cat(0),
/** the tiger */
tiger(10),
;
final int value;
AnimalTypeEnum(int value) {
this.value = value;
}
@Override
public int value() {
return this.value;
}
}
.proto
// TestAnimalTypeEnum
enum AnimalTypeEnum {
// the cat
cat = 0;
// the tiger
tiger = 10;
}
[other updates]
<netty.version>4.1.116.Final</netty.version>