generated from mingliqiye/lib-tem
feat(utils): 添加函数式接口和条件验证工具类
- 添加 RFunction 函数式接口用于无参数函数调用 - 更新文件头版权年份从 2025 到 2026 - 更新文件最后修改时间戳 - 新增 Require 类提供条件验证功能 - 支持多种构造方式包括布尔值、函数式参数等 - 提供多种异常抛出机制包括自定义异常类型 - 添加扩展函数和静态工厂方法简化使用 - 支持 Java 互操作性的 JvmStatic 注解
This commit is contained in:
parent
00c1be6387
commit
3f666d652d
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2025 mingliqiye
|
* Copyright 2026 mingliqiye
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
@ -16,7 +16,7 @@
|
|||||||
* ProjectName mingli-utils
|
* ProjectName mingli-utils
|
||||||
* ModuleName mingli-utils.main
|
* ModuleName mingli-utils.main
|
||||||
* CurrentFile Functions.kt
|
* CurrentFile Functions.kt
|
||||||
* LastUpdate 2025-09-15 09:56:54
|
* LastUpdate 2026-01-09 08:12:01
|
||||||
* UpdateUser MingLiPro
|
* UpdateUser MingLiPro
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -85,6 +85,11 @@ fun interface P1Function<P> {
|
|||||||
fun call(p: P)
|
fun call(p: P)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@FunctionalInterface
|
||||||
|
fun interface RFunction<R> {
|
||||||
|
fun call(): R
|
||||||
|
}
|
||||||
|
|
||||||
@FunctionalInterface
|
@FunctionalInterface
|
||||||
fun interface P1RFunction<P, R> {
|
fun interface P1RFunction<P, R> {
|
||||||
fun call(p: P): R
|
fun call(p: P): R
|
||||||
|
|||||||
126
src/main/kotlin/com/mingliqiye/utils/request/Require.kt
Normal file
126
src/main/kotlin/com/mingliqiye/utils/request/Require.kt
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2026 mingliqiye
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
* ProjectName mingli-utils
|
||||||
|
* ModuleName mingli-utils.main
|
||||||
|
* CurrentFile Require.kt
|
||||||
|
* LastUpdate 2026-01-10 08:53:26
|
||||||
|
* UpdateUser MingLiPro
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.mingliqiye.utils.request
|
||||||
|
|
||||||
|
import com.mingliqiye.utils.functions.P1RFunction
|
||||||
|
import com.mingliqiye.utils.functions.RFunction
|
||||||
|
|
||||||
|
class Require(private val must: Boolean) {
|
||||||
|
|
||||||
|
constructor(funs: RFunction<Boolean>) : this(funs.call())
|
||||||
|
|
||||||
|
constructor(must: RFunction<Boolean>, message: String) : this(must) {
|
||||||
|
throws(message)
|
||||||
|
}
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
must: RFunction<Boolean>,
|
||||||
|
message: String,
|
||||||
|
exception: Class<out Exception> = IllegalArgumentException::class.java
|
||||||
|
) : this(must) {
|
||||||
|
throws(message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
constructor(must: Boolean, message: String) : this(must) {
|
||||||
|
throws(message)
|
||||||
|
}
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
must: Boolean, message: String, exception: Class<out Exception> = IllegalArgumentException::class.java
|
||||||
|
) : this(must) {
|
||||||
|
throws(message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
must: Boolean, message: String, exception: P1RFunction<String, out Exception>
|
||||||
|
) : this(must) {
|
||||||
|
throws(message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
fun Boolean.require(message: String, exception: P1RFunction<String, out Exception>): Require {
|
||||||
|
return Require(this, message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
fun Boolean.require(
|
||||||
|
message: String,
|
||||||
|
exception: Class<out Exception> = IllegalArgumentException::class.java
|
||||||
|
): Require {
|
||||||
|
return Require(this, message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
@JvmStatic
|
||||||
|
fun require(
|
||||||
|
must: Boolean, message: String, exception: Class<out Exception> = IllegalArgumentException::class.java
|
||||||
|
): Require {
|
||||||
|
return Require(must, message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
@JvmStatic
|
||||||
|
fun require(must: Boolean, message: String): Require {
|
||||||
|
return Require(must, message)
|
||||||
|
}
|
||||||
|
|
||||||
|
@JvmStatic
|
||||||
|
fun require(must: Boolean): Require {
|
||||||
|
return Require(must)
|
||||||
|
}
|
||||||
|
|
||||||
|
@JvmStatic
|
||||||
|
fun require(
|
||||||
|
must: RFunction<Boolean>,
|
||||||
|
message: String,
|
||||||
|
exception: Class<out Exception> = IllegalArgumentException::class.java
|
||||||
|
): Require {
|
||||||
|
return Require(must, message, exception)
|
||||||
|
}
|
||||||
|
|
||||||
|
@JvmStatic
|
||||||
|
fun require(must: RFunction<Boolean>, message: String): Require {
|
||||||
|
return Require(must, message)
|
||||||
|
}
|
||||||
|
|
||||||
|
@JvmStatic
|
||||||
|
fun require(must: RFunction<Boolean>): Require {
|
||||||
|
return Require(must)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun throws(message: String) {
|
||||||
|
if (!must) {
|
||||||
|
throw IllegalArgumentException(message)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun throws(string: String, exception: Class<out Exception>) {
|
||||||
|
if (!must) {
|
||||||
|
throw exception.getConstructor(String::class.java).newInstance(string)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun throws(string: String, exception: P1RFunction<String, out Exception>) {
|
||||||
|
if (!must) {
|
||||||
|
throw exception.call(string)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user