WKEA 发表于 2025-5-6 04:16:25

ScriptIrc —— AI插件编写 并编译为服务器插件

本帖最后由 WKEA 于 2025-12-28 13:54 编辑


# ScriptIrc - 脚本编译,使用AI构建编写一键生成ScriptIrc专用脚本 | 基于服务器环境直接编译脚本为服务器插件

![版本](https://img.shields.io/badge/版本-1.4.0--SNAPSHOT-blue)
!(https://img.shields.io/badge/Minecraft-1.13+-green)
![语言](https://img.shields.io/badge/语言-Java-orange)

**建议用于测试服 / 开发中服务器:编译出来的插件脚本是标准 Bukkit 插件 JAR,不依赖 ScriptIrc 运行,你可以直接把生成的 JAR 丢进 `plugins` 目录使用。**

## 📚 介绍

ScriptIrc 是一个功能强大的 Bukkit/Spigot/Paper/Folia 插件,旨在简化插件管理和即时开发流程。你可以在不重启服务器的前提下,直接在服务端上**编写 / 修改 / 编译脚本插件**,并一键加载、卸载或重载;同时也支持直接从 **`.sirc` 插件项目** 解析并编译出可加载的 JAR。
@(BV1QFJaz3EaM)

### ✨ 主要特性

- 🚀 **支持 AI 构建脚本** - 基于 AI 服务快速创建指定需求脚本
- 🔄 **动态插件管理** - 无需重启服务器即可加载、卸载或重载外部插件
- 📝 **即时脚本编译** - 将 Java 源码脚本直接编译为功能完整的 Bukkit 插件
- 🧩 **`.sirc` 项目支持** - 直接解析 `.sirc` 插件项目文件,安全解包到临时目录后自动编译、打包并输出 JAR
- 🌐 **Folia 兼容** - 运行在支持全局 Region 调度的服务端时,自动在生成的 `plugin.yml` 中声明 `folia-supported: true`,方便在 Folia 端加载
- 🛡️ **数据目录隔离** - 为外部插件统一创建 `scripts/output/Data` 数据目录,减少与主服插件的数据冲突
- 🔧 **无缝集成** - 与现有的 Bukkit/Spigot/Paper 环境兼容
- 🔒 **资源释放** - 卸载外部插件后尽可能释放 JAR 句柄,方便覆盖与删除

## 🚀 安装说明

1. 下载最新版本的 `ScriptIrc.jar`
2. 将 JAR 文件放入服务器的 `plugins` 目录
3. 启动 / 重启服务器加载插件
4. 插件会自动创建必要的目录结构和配置文件

> ⚠ **从旧版本升级提示**:本版本调整了脚本与外部插件的数据目录结构(`scripts/output/Data`),建议在升级前**手动备份并删除旧版本的 ScriptIrc 数据目录**,避免历史结构残留带来的混用与冲突。

## 💡 使用方法

ScriptIrc 提供了直观的命令系统,让你可以轻松管理插件和脚本:

### 基本命令(所有命令可简写为 `/si`)

| 命令 | 描述 |
|------|------|
| `/scriptirc help` | 显示帮助信息 |
| `/scriptirc load <插件名>` | 从 `scripts/output` 目录加载指定的外部插件 JAR |
| `/scriptirc unload <插件名>` | 卸载指定的外部插件 |
| `/scriptirc reload <插件名>` | 重载指定的外部插件 |
| `/scriptirc list` | 列出所有已加载的外部插件 |
| `/scriptirc compiler <脚本名>` | 编译指定脚本:支持 `.java` 源码和 `.sirc` 项目 |
| `/scriptirc compiler <脚本名> fixreport` | 在最近一次编译失败后,分析错误并给出依赖修复建议 |
| `/scriptirc search <类名>` | 全局搜索给定类名的包路径 |
| `/scriptirc sirctree <项目名>` | 查看 `.sirc` 项目文件的虚拟目录结构(不落地解包) |
| `/ai-builder` | 打开 AI 脚本构建 Web UI(用于生成脚本源码) |

### 插件管理示例

```text
# 加载名为 TestPlugin 的外部插件(对应 scripts/output/TestPlugin.jar)
/si load TestPlugin

# 卸载插件
/si unload TestPlugin

# 重新加载插件(例如更新后)
/si reload TestPlugin

# 查看已加载的插件列表
/si list
```

### 脚本 / `.sirc` 编译示例

```text
# 编译位于 scripts/src 目录下的 HelloWorld.java 脚本(无需写后缀也可)
/si compiler HelloWorld

# 编译位于 plugins/ScriptIrc/scripts 下的 DemoProject.sirc 插件项目
/si compiler DemoProject

# 然后加载编译好的插件(自动输出到 scripts/output/ 目录)
/si load HelloWorld
/si load DemoProject
```

> 提示:对于 `.sirc` 项目,编译完成后如果包内存在 `README.md`,插件会尝试将其解析为游戏内书本并发送给执行命令的玩家,作为项目说明书。

## 📂 目录结构

安装后,ScriptIrc 将创建以下目录结构(简化示意):

```text
plugins/
└── ScriptIrc/
      ├── config.yml         # 插件配置文件
      ├── messages/            # 语言文件目录
      └── scripts/             # 所有脚本相关内容
          ├── src/             # 脚本源码目录(.java / .sirc 均可放在这里)
          │   ├── HelloWorld.java   # 示例脚本
          │   └── MathUtil.java   # 示例脚本
          ├── lib/             # 脚本额外依赖库目录(JAR)
          ├── output/          # 脚本 / 项目编译输出目录(可加载的外部插件 JAR)
          │   └── Data/      # 外部插件数据目录(可选重定向)
          └── build-cache/   # 编译临时目录(内部使用,会自动清理)
```

## 🛠️ 开发教程 - 创建你的第一个脚本插件

ScriptIrc 让插件开发变得异常简单。你只需要创建一个 Java 源文件,编译后即可立刻加载使用。下面是开发步骤:

### 1. 创建脚本文件

在 `plugins/ScriptIrc/scripts/src` 目录下创建一个新的 Java 文件,例如 `MyFirstPlugin.java`。

### 2. 编写插件代码(推荐使用注释元数据方式)

以下是一个简单的插件模板,元数据通过 JavaDoc 注释提供,ScriptIrc 会自动从注释中读取信息并生成 `plugin.yml`:

```java
// 包名可自定义(尽量合理即可,推荐使用反向域名)
package your.package.name;

import org.bukkit.command.Command;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;

/**
* @pluginName MyFirstPlugin                  // 插件名称
* @author 你的名字                              // 作者
* @version 1.0.0                               // 版本
* @description 我的第一个 ScriptIrc 脚本插件       // 简要描述(可多行)
* myfirstcmd|执行一个测试命令
* myfirstplugin.use|使用测试命令的权限
*/
public class MyFirstPlugin extends JavaPlugin {

    @Override
    public void onEnable() {
      getLogger().info("插件已启用!");
      // 初始化代码
    }

    @Override
    public void onDisable() {
      getLogger().info("插件已禁用!");
      // 卸载监听器 / 命令等相关清理代码可以放在这里
    }

    @Override
    public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
      if (command.getName().equalsIgnoreCase("myfirstcmd")) {
            if (sender instanceof Player) {
                Player player = (Player) sender;
                player.sendMessage("§a你好,这是我的第一个插件命令!");
            } else {
                sender.sendMessage("这个命令只能由玩家执行!");
            }
            return true;
      }
      return false;
    }
}
```

### 3. 编译并加载插件

使用以下命令编译和加载你的插件:

```text
/si compiler MyFirstPlugin
/si load MyFirstPlugin
```

就这么简单!你的插件现在已经在服务器上运行了,无需重启服务器。

### 重要的元数据标签(注释方式)

当前版本推荐且默认使用 **JavaDoc 注释方式** 定义元数据,ScriptIrc 会自动从主类注释中解析:

| 标签 | 必填 | 描述 |
|------|------|------|
| `@pluginName` | 是 | 插件名称(用于展示与生成 `plugin.yml`) |
| `@version` | 是 | 插件版本号 |
| `@description` | 是 | 插件描述,支持多行 |
| `@author` | 是 | 插件作者 |
| `name|description` | 否 | 命令定义,命令名与描述以 `|` 分隔 |
| `node|description` | 否 | 权限定义,节点与描述以 `|` 分隔 |

> 注:如果缺少上述必需标签,当前版本将无法正确生成 `plugin.yml`,编译会失败,请根据模板补全。

## ⚙️ 配置文件说明

ScriptIrc 的配置文件(`config.yml`)允许你自定义插件的行为,以下为当前版本的关键配置示例:

```yaml
# 插件自动重载配置 | Auto-reload configuration
auto-reload:
# 是否启用自动重载 | Whether to enable auto-reload
enabled: true
# 检测间隔(秒) | Check interval (seconds)
check-interval: 5
# 是否在控制台输出详细日志 | Whether to output verbose logs in console
verbose-logging: false

# 脚本编译设置 | Script compiler settings
compiler:
# 是否启用 Java 编译器的详细输出(等价于 javac 的 -verbose),默认关闭
# Whether to enable verbose output of Java compiler (equivalent to javac -verbose), default false
verbose-logging: false

# 插件管理设置 | Plugin management settings
plugin-management:
# 外部插件存放目录,相对于插件数据文件夹 | External plugins directory, relative to plugin data folder
# 默认:scripts/output
external-plugins-directory: "scripts/output"
# 是否在服务器启动时自动加载外部插件 | Whether to auto-load external plugins on server startup
load-on-startup: true
# 是否将外部插件的数据文件夹重定向到 ScriptIrc 目录下 | Whether to redirect external plugins' data folders to ScriptIrc directory
redirect-data-folder: true

# 权限设置 | Permission settings
permissions:
# 管理员权限节点 | Admin permission node
admin-permission: "scriptirc.admin"
# 是否只允许 OP 使用 | Whether to allow only OP to use
op-only: true

# 日志设置 | Logging settings
logging:
# 日志输出级别: VERBOSE(输出所有日志), NORMAL(标准输出), MINIMAL(只输出关键信息)
# Log output level: VERBOSE(all logs), NORMAL(standard output), MINIMAL(only critical information)
level: "MINIMAL"

# 语言设置 | Language settings
language:
# 当前语言: zh_CN(简体中文), en_US(英语)
# Current language: zh_CN(Simplified Chinese), en_US(English)
current: "zh_CN"
# 是否启用自定义语言文件 (放置在 plugins/ScriptIrc/messages/ 目录下)
# Whether to enable custom language files (placed in plugins/ScriptIrc/messages/ directory)
enable-custom: true
```

## 🤔 常见问题

### 编译脚本 / `.sirc` 项目时报错怎么办?

请检查:
1. Java 代码语法是否正确;
2. 主类是否包含完整、合法的注释元数据标签(`@pluginName/@version/@description/@author` 等);
3. 服务器是否运行在 **JDK** 而不是 JRE(编译需要 JDK 环境);
4. 如果是依赖相关报错,可先执行一次 `/si compiler <脚本名>`,然后使用 `/si compiler <脚本名> fixreport` 查看依赖修复建议;
5. 也可以尝试将错误日志交给 AI 工具协助分析,大多数常见问题都能快速定位。

### 如何删除动态加载的插件文件?

当使用 `/si unload` 命令卸载插件时,ScriptIrc 会尝试完全释放 JAR 文件,使其可以被删除或替换。如果仍然无法删除,通常需要重启服务器。

## 声明

* 有关插件卸载 / 加载相关的部分实现参考了 PlugManX 项目

---

## 关于 ai-builder

- `ai-builder` (AI:ScriptIrc) 功能基于当前插件之上,为你提供脚本开发与生成功能;
- `ai-builder` 服务本身是独立的在线服务;
- 条款链接:<https://scriptirc.io/terms>
- 当前插件的核心功能仍然是:在当前服务器环境下编译并管理服务器插件;
- `ai-builder` 服务存在内购,但仍可通过签到等方式获取免费试用额度。

寒风灬 发表于 2025-5-25 15:17:16

作者什么时候支持一下 1.21.X 版本
页: [1]
查看完整版本: ScriptIrc —— AI插件编写 并编译为服务器插件