# SairFramework **Repository Path**: sair520/sairframework ## Basic Information - **Project Name**: SairFramework - **Description**: SairFramework主框架程序 - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 6 - **Forks**: 0 - **Created**: 2022-09-01 - **Last Updated**: 2025-10-11 ## Categories & Tags **Categories**: Uncategorized **Tags**: Java, Swing ## README # SairFramework ![avatar][base64str] #### SFW的简单介绍 使用Java编写的一个多组件融合交互平台,作用是为了避免无用的冗余.
使用后缀名为ir的文本文件驱动,当然,你也可以直接java -jar SFW.jar来使用.

>Windows平台直接双击ir后缀的文件,然后将打开方式指向到run.bat这个批处理并记住打开方式就行了
>Linux平台则需要手动把ir文件的目录传给SFW.jar,只需要在命令后面加上ir文件的目录就行
>你也可以手动在SFW打开后输入/ir命令来进行ir脚本的执行操作

使用SFW.jar作为导入包来使用时,不需要将SFW.jar放到你的项目目录,仅需导入外部包即可,因为整个SairFrameWork目录就是一个整体.

SFW的plugins插件制作也就是如此进行.
#### 插件制作: 首先,插件需要在Java的jar文件META-INF/MANIFEST.MF文件中加入ACT标识来告诉SFW主入口在哪里
>比如原文是仅有一行的:Manifest-Version: 1.0
>那么你就需要在文件内容末尾加入ACT: Activity类的所在包名;
举例: Manifest-Version: 1.0 ACT: sair.ire.MyActivity; 或者: Manifest-Version: 1.0 ACT: sair.ire.IMyActivity_A;sair.ire.MyActivity_B; 继承了sair.user.Activity这个抽象类的类都可以视作一个Activity被SFW加载,但是需要如刚才所说的在MF文件中标注起来. #### 插件调试: 插件调试首先要将插件导入SFW.jar这个包,然后自行在插件里面创建一个public static void main函数,在这个主入口函数中,你可以这样操作:
方法一:
public static void main(String[] args) throws Exception { //新建一个自己的Activity对象 Activity myacti = new MyActivity(); // 使用Main中的toTest函数进行指令测试 Main.toTest(myacti, "list", ""); Main.toTest(myacti, "add", "\"E:\\Test\\LRCTEST\""); } 方法二:
public static void main(String[] args) throws Exception { // 新建一个自己的Activity Activity myacti = new MyActivity(); // 给定一个测试名称为kft myacti.setName("kft"); // 把这个kft对象放到Libraries的activities记录里面 Libraries.activities.put("kft", myacti); // 传入空参数调用toTest用于加载其他组件和依赖 Main.toTest(myacti, "", ""); // 使用SairCons.runner进行调用(此时可以对其他组件也进行使用) SairCons.runner(false, "jj/unstop"); SairCons.runner(false, "jj/setca 0"); SairCons.runner(false, "kft/reco"); } 插件在打包时仅需选择普通的Jar文件就行,不需要选择可执行Jar,并且只需要打包自己的目录,
不需要连同其他依赖一起打包.(插件的打包要记得改写MF文件才能被加载器识别)
#### 插件的使用: 如果是插件的依赖,其实你大可不必跟插件一起打包,除非是硬性需求,如果是普通依赖,直接丢进plugins/modlib即可,
会由SairLoader加载器负责加载,当然,你获取文件流也得使用SairLoader加载器进行.
如果这个插件对JVM的功能有所修补,需要用到线程上下文操作,
或者SPI,那么就得放进plugins/bootlib里面由系统加载器
来进行加载.

准备就绪的插件的本体放到plugins/exection,再打开SFW输入/list命令就能看到你的插件名称了.
插件初始名称是根据文件名来决定的,你可以在SFW内用命令进行临时重命名,这种命名在SFW重启后失效.
#### 命令格式: SFW命令格式是很简单的 举例: >
>有一条命令为: pl/start 5
>那么在其中pl指的是这个插件名,中间用/符号分隔告诉SFW命令名结束
>(这种是为了兼容空格文件名),
>然后紧跟其后的start是pl这个组件中的实现功能名称,后一个空格是告诉SFW功能名称结束,
>最后的数字5就是输入的功能参数,空格后面的内容不再有其他区分,
>完全由插件制作者再次进行加工.
>
>不输入插件名,直接输入/后面加功能名则会唤起SFW内置的命令,比如:
>/exit 就表示退出
>/println-c 255 0 0 Hello World 就是输出红色的Hello World
>

在ir脚本中,你可以直接用记事本打开编辑内容,内容就是一条一条的命令自动一行一行执行,
内容支持注释,一行的最前面加双斜杠//就是注释,内容去向就是SFW的控制台进行执行.

SFW不是单例窗口,你每双击一次ir文件打开,就是一个全新的SFW进程.
#### 兼容性: 系统支持:这个软件在Linux发行版,Windows,以及所有支持Java的系统中可以被直接运行,无需进行二次编译
Java支持:Java8及以上可以被直接打开,推荐使用Java8并且是JDK,
Java8以上的JDK/JRE是重启SFW后使用虚拟机参数加载的bootlib目录,
所以无法被热卸载,但是Java8可以.
#### 关于其他项目: 因为这整个账号的仓库都是围绕这一个SFW进行开源的,所以其他的仓库就不写README文件了
#### 参与开发: Sair [base64str]: