2020-07-23 11:00:46 +08:00
|
|
|
|
module es {
|
2020-06-12 08:47:13 +08:00
|
|
|
|
/**
|
2020-07-23 11:00:46 +08:00
|
|
|
|
* 帮助处理位掩码的实用程序类
|
|
|
|
|
|
* 除了isFlagSet之外,所有方法都期望flag参数是一个非移位的标志
|
|
|
|
|
|
* 允许您使用普通的(0、1、2、3等)来设置/取消您的标记
|
2020-06-12 08:47:13 +08:00
|
|
|
|
*/
|
2020-07-23 11:00:46 +08:00
|
|
|
|
export class Flags {
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 检查位标志是否已在数值中设置
|
|
|
|
|
|
* 检查期望标志是否已经移位
|
|
|
|
|
|
* @param self
|
|
|
|
|
|
* @param flag
|
|
|
|
|
|
*/
|
2020-07-28 16:25:20 +08:00
|
|
|
|
public static isFlagSet(self: number, flag: number): boolean {
|
2020-07-23 11:00:46 +08:00
|
|
|
|
return (self & flag) != 0;
|
|
|
|
|
|
}
|
2020-06-12 08:47:13 +08:00
|
|
|
|
|
2020-07-23 11:00:46 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 检查位标志是否在数值中设置
|
|
|
|
|
|
* @param self
|
|
|
|
|
|
* @param flag
|
|
|
|
|
|
*/
|
2020-07-28 16:25:20 +08:00
|
|
|
|
public static isUnshiftedFlagSet(self: number, flag: number): boolean {
|
2020-07-23 11:00:46 +08:00
|
|
|
|
flag = 1 << flag;
|
|
|
|
|
|
return (self & flag) != 0;
|
|
|
|
|
|
}
|
2020-06-12 08:47:13 +08:00
|
|
|
|
|
2020-07-23 11:00:46 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 设置数值标志位,移除所有已经设置的标志
|
|
|
|
|
|
* @param self
|
|
|
|
|
|
* @param flag
|
|
|
|
|
|
*/
|
2020-08-27 18:48:20 +08:00
|
|
|
|
public static setFlagExclusive(self: Ref<number>, flag: number) {
|
|
|
|
|
|
self.value = 1 << flag;
|
2020-07-23 11:00:46 +08:00
|
|
|
|
}
|
2020-06-12 08:47:13 +08:00
|
|
|
|
|
2020-07-23 11:00:46 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 设置标志位
|
|
|
|
|
|
* @param self
|
|
|
|
|
|
* @param flag
|
|
|
|
|
|
*/
|
2020-08-27 18:48:20 +08:00
|
|
|
|
public static setFlag(self: Ref<number>, flag: number) {
|
|
|
|
|
|
self.value = (self.value | 1 << flag);
|
2020-07-23 11:00:46 +08:00
|
|
|
|
}
|
2020-06-12 08:47:13 +08:00
|
|
|
|
|
2020-07-23 11:00:46 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 取消标志位
|
|
|
|
|
|
* @param self
|
|
|
|
|
|
* @param flag
|
|
|
|
|
|
*/
|
2020-08-27 18:48:20 +08:00
|
|
|
|
public static unsetFlag(self: Ref<number>, flag: number) {
|
2020-07-23 11:00:46 +08:00
|
|
|
|
flag = 1 << flag;
|
2020-08-27 18:48:20 +08:00
|
|
|
|
self.value = (self.value & (~flag));
|
2020-07-23 11:00:46 +08:00
|
|
|
|
}
|
2020-06-12 08:47:13 +08:00
|
|
|
|
|
2020-07-23 11:00:46 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* 反转数值集合位
|
|
|
|
|
|
* @param self
|
|
|
|
|
|
*/
|
2020-08-27 18:48:20 +08:00
|
|
|
|
public static invertFlags(self: Ref<number>) {
|
|
|
|
|
|
self.value = ~self.value;
|
2020-07-23 11:00:46 +08:00
|
|
|
|
}
|
2020-06-12 08:47:13 +08:00
|
|
|
|
}
|
2020-07-23 11:00:46 +08:00
|
|
|
|
}
|