# Mirai Console - Run

Mirai Console 可以独立启动,也可以被嵌入到某个应用中。

## 使用工具自动独立启动

该部分文档已经转移到 [用户手册](/docs/UserManual.md)。

## 嵌入应用启动(实验性)

将 Mirai Console 作为一个依赖嵌入一个 JVM 应用启动,开发者主动加载插件。尤其适合在开发时启动真实环境的测试。

### 环境

- JDK 1.8+ / Android SDK 26+ (Android 8+)
- Kotlin 1.4+

### 添加依赖

[选择版本](ConfiguringProjects.md#选择版本)

`build.gradle.kts`:
```kotlin
dependencies {
    api("net.mamoe:mirai-console-terminal:2.0.0") // 自行替换版本
    api("net.mamoe:mirai-core:2.0.0")
}
```

### 启动 Terminal 前端

一行启动:
```kotlin
MiraiConsoleTerminalLoader.startAsDaemon()
```

注意, Mirai Console 将会以 '守护进程' 形式启动,不会阻止主线程退出。

### 从内存加载 JVM 插件(实验性)

在嵌入使用时,插件可以直接加载:

```kotlin
MiraiConsoleTerminalLoader.startAsDaemon()
// 先启动 Mirai Console

// Kotlin
Plugin.load() // 扩展函数
Plugin.enable() // 扩展函数 

// Java
PluginManager.INSTANCE.loadPlugin(Plugin.INSTANCE)
PluginManager.INSTANCE.enablePlugin(Plugin.INSTANCE)
```

但注意:这种方法目前是实验性的——一些特定的功能如注册扩展可能不会正常工作。


## 手动配置独立启动

强烈建议使用自动启动工具,若无法使用,可以参考如下手动启动方式。

### 环境
- JRE 8+ / JDK 8+

### 准备文件

要启动 Mirai Console,你需要:
- mirai-core
- mirai-console 后端
- mirai-console 任一前端
- 相关依赖

只有 mirai-console 前端才有入口点 `main` 方法。目前只有一个 terminal 前端可用。

#### 从 JCenter 下载模块

- mirai-core 会提供 [mirai-core-all]
- mirai-console 与其各个模块都会提供 `-all` 的 Shadowed 构建

```shell script
# 注: 自行更换对应版本号

# Download mirai-core-all

curl -L https://maven.aliyun.com/repository/central/net/mamoe/mirai-core-all/1.3.3/mirai-core-all-1.3.3-all.jar -o mirai-core-all-1.3.3.jar

# Download mirai-console

curl -L https://maven.aliyun.com/repository/central/net/mamoe/mirai-console/1.0.0/mirai-console-1.0.0-all.jar -o mirai-console-1.0.0.jar

# Download mirai-console-terminal

curl -L https://maven.aliyun.com/repository/central/net/mamoe/mirai-console-terminal/1.0.0/mirai-console-terminal-1.0.0-all.jar -o mirai-console-terminal-1.0.0.jar

```

### 启动 mirai-console-terminal 前端

1. 下载如下三个模块的最新版本文件并放到一个文件夹内 (如 `libs`)(详见 [下载模块](#从-jcenter-下载模块)):
   - mirai-core-all
   - mirai-console
   - mirai-console-terminal

2. 创建一个新的文件, 名为 `start-mirai-console.bat`/`start-mirai-console.ps1`/`start-mirai-console.sh`

Windows CMD:
```shell script
@echo off
title Mirai Console
java -cp "./libs/*" net.mamoe.mirai.console.terminal.MiraiConsoleTerminalLoader %*
pause
```

Windows PowerShell:
```shell script
$Host.UI.RawUI.WindowTitle = "Mirai Console"
java -cp "./libs/*" net.mamoe.mirai.console.terminal.MiraiConsoleTerminalLoader $args
pause
```

Linux:
```shell script
#!/usr/bin/env bash
echo -e '\033]2;Mirai Console\007'
java -cp "./libs/*" net.mamoe.mirai.console.terminal.MiraiConsoleTerminalLoader $*
```

然后就可以开始使用 mirai-console 了。

#### mirai-console-terminal 前端参数
使用 `./start-mirai-console --help` 查看 mirai-console-terminal 支持的启动参数。

[mirai-repo]: https://github.com/project-mirai/mirai-repo/tree/master/shadow
[mirai-core-all]: https://repo.maven.apache.org/maven2/net/mamoe/mirai-core-all/