错误1 赋值问题

貌似编译器版本有点低,无法识别C#的高级语法糖

属性的初始值,必须是public bool IsEnabled { get{return true;} }

不能写成public bool IsEnabled { get; }=true;

Control

Compiler Error: \Plugins\AutoConcede\AutoConcede.cs(75,38) :

error CS0840: 'AutoConcede.AutoConcede.Control.get' must declare a body because it is not marked abstract or extern. Automatically implemented properties must define both get and set accessors.
Compiler Error: c:\Users\clu\Desktop\Hearthbuddy 0.3.1446.417\Plugins\AutoConcede\AutoConcede.cs(76,40) : error CS0840: 'AutoConcede.AutoConcede.Settings.get' must declare a body because it is not marked abstract or extern. Automatically implemented properties must define both get and set accessors.

2019-07-16 14:22:58,834 [14] DEBUG Logger (null) - [AutoConcede] Initialize

自动投降不工作,提示是

2019-07-16 15:10:03,568 [5] INFO Logger (null) - [Concede] GameState == null.
2019

public static bool Concede(bool logReason)
{
bool result;
try
{
if (GameState.Get() == null)
{
if (logReason)
{
TritonHs.ilog_0.InfoFormat("[Concede] GameState == null.", Array.Empty<object>());
}
result = false;
}
else if (!GameUtils.CanConcedeCurrentMission())
{
TritonHs.ilog_0.InfoFormat("[Concede] !GameUtils.CanConcedeCurrentMission().", Array.Empty<object>());
result = false;
}
else
{
GameState.Get().Concede();
using (TritonHs.Memory.ReleaseFrame(true))
{
Thread.Sleep();
}
result = true;
}
}
catch (Exception ex)
{
if (logReason)
{
TritonHs.ilog_0.InfoFormat("[Concede] An exception occurred. {0}", ex.ToString());
}
result = false;
}
return result;
}

关于在选牌阶段,以及回合开始投降

https://tieba.baidu.com/p/5929349383?red_tag=2707770290

Hearthbuddy\Routines\DefaultRoutine\DefaultRoutine.cs

public async Task MulliganLogic(MulliganData mulliganData)

public async Task OurTurnLogic()

DefaultRoutine继承了Triton.Bot.IRoutine接口

public interface IRoutine : IRunnable, IAuthored, IBase, IConfigurable
{
// Token: 0x06001185 RID: 4485
void SetConfiguration(string name, params object[] param); // Token: 0x06001186 RID: 4486
object GetConfiguration(string name); // Token: 0x06001187 RID: 4487
Task<bool> Logic(string type, object context);
}

主要逻辑的入口,都是在Logic函数里面

/// <summary>
/// The routine's coroutine logic to execute.
/// </summary>
/// <param name="type">The requested type of logic to execute.</param>
/// <param name="context">Data sent to the routine from the bot for the current logic.</param>
/// <returns>true if logic was executed to handle this type and false otherwise.</returns>
public async Task<bool> Logic(string type, object context)
{ // The bot is requesting mulligan logic.
if (type == "mulligan")
{
await MulliganLogic(context as MulliganData);
return true;
} // The bot is requesting emote logic.
if (type == "emote")
{
await EmoteLogic(context as EmoteData);
return true;
} // The bot is requesting our turn logic.
if (type == "our_turn")
{
await OurTurnLogic();
return true;
} // The bot is requesting opponent turn logic.
if (type == "opponent_turn")
{
await OpponentTurnLogic();
return true;
} // The bot is requesting our turn logic.
if (type == "our_turn_combat")
{
await OurTurnCombatLogic();
return true;
} // The bot is requesting opponent turn logic.
if (type == "opponent_turn_combat")
{
await OpponentTurnCombatLogic();
return true;
} // The bot is requesting arena draft logic.
if (type == "arena_draft")
{
await ArenaDraftLogic(context as ArenaDraftData);
return true;
} // The bot is requesting quest handling logic.
if (type == "handle_quests")
{
await HandleQuestsLogic(context as QuestData);
return true;
} // Whatever the current logic type is, this routine doesn't implement it.
return false;
}

无法识别Object,必须改成小写的object

如何确定插件是否加载成功

查看plugins的tab那边是否显示了相应的插件,如果没有显示,就说明插件编译失败。可以去日志文件看细节

需要依据GameEventManager 中的事件,来决定如何写代码

public class GameEventManager : IRunnable, IResetable

2019-07-17 11:51:33,227 [19] DEBUG Logger (null) - [AutoConcede] ConcedeThread for loop, index = 1
2019-07-17 11:51:33,228 [14] INFO Logger (null) - [GameEventManagerOnMulliganConfirm]
2019-07-17 11:51:49,782 [14] ERROR Logger (null) - [Tick] Exception during execution:
GreyMagic.InjectionDesyncException: Process must have frozen or gotten out of sync: Injection Finished Event was never fired
at GreyMagic.Executor.WaitForInjection(Int32 timeout)
at GreyMagic.Executor.SharedExecuteLogicEnd(Int32 timeout)
at GreyMagic.Executor.Execute(Int32 timeout)
at GreyMagic.Executor.GrabFrame()
at GreyMagic.ExternalProcessMemory.AcquireFrame(Boolean isHardLock)
at Triton.Bot.BotManager.smethod_1(IBot ibot_1)
2019-07-17 11:51:49,785 [14] DEBUG Logger (null) - [BotThreadFunction] An InjectionDesyncException was detected.

HearthBuddy Plugin编写遇到的问题的更多相关文章

  1. Bootstrap plugin编写

    滚动demo: <!doctype html> <html lang="en"> <head> <meta charset="U ...

  2. lua 5.3最简单plugin编写

    #include <windows.h> #include "lauxlib.h" /* Pop-up a Windows message box with your ...

  3. AS 自定义 Gradle plugin 插件 案例 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  4. 使用 CodeIgniter 框架快速开发 PHP 应用(三)

    原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...

  5. 使用dropwizard(4)-加入测试-jacoco代码覆盖率

    前言 dropwizard提供了一个简单的测试框架.这里简单集成并加入jacoco测试. Demo source https://github.com/Ryan-Miao/l4dropwizard 本 ...

  6. 30分钟带你了解Docker

    最近一直在忙项目,不知不觉2个多月没有更新博客了.正好自学了几天docker就干脆总结一下,也顺带增加一篇<30分钟入门系列>.网上能够查到的对于docker的定义我就不再重复了,说说我自 ...

  7. MQTT---HiveMQ源代码具体解释(四)插件载入

    源博客地址:http://blog.csdn.net/pipinet123 MQTT交流群:221405150 实现功能 将全部放在plugins文件夹下的全部符合plugin编写规范的plugin ...

  8. 掘金 Android 文章精选合集

    掘金 Android 文章精选合集 掘金官方 关注 2017.07.10 16:42* 字数 175276 阅读 50053评论 13喜欢 669 用两张图告诉你,为什么你的 App 会卡顿? - A ...

  9. 什么是SpringBoot

    随着动态语言的流行(Ruby,Groovy,Scala,Node.js),Java的开发显得格外的笨重;繁多的配置,低下的开发效率,复杂的部署流程以及第三方技术集成难度大. 在上述环境 下,Sprin ...

随机推荐

  1. Redis-设置key过期

    Redis-设置key过期 expire key seconds 设置指定key 多少秒后过期, seconds 为 -1 时表示永不过期 ttl key 查看指定key还有多少秒过期 persist ...

  2. Dockerfile初体验

    Dockerfile构建nginx 创建一个文件夹 mkdir -p /nginx 进入创建的目录 cd /nginx 创建并编辑 添加下面两行 vim Dockerfile 行1,去本地找基础的镜像 ...

  3. VMwarevSphere Client 链接 vCenter Server中的主机,开启虚拟机提示:在主机当前连接状况下不允许执行该操作

    VMwarevSphere Client 链接 vCenter Server中的主机,开启虚拟机提示:在主机当前连接状况下不允许执行该操作很多原因都可以导致该问题出现,例如 vCenter Serve ...

  4. 分布式之协调服务Zookeeper专题第一讲

    写在前面: 再谈架构演进: 1.单体架构->tomcat(war) 演进:水平拆分(服务拆分,(用户服务,订单服务,商品服务)) 涉及问题:1).服务通信(webservice) 2).三态问题 ...

  5. U盘加载速度慢的解决方法

    在日常的生活和工作中,我们经常用U盘存储一些文件和程序.然而,一些朋友发现U盘有时候在使用过程中的识别加载速度非常缓慢.是U盘出故障了吗?其实不尽然,下面就为大家分享一下如何快速解决U盘加载缓慢的方法 ...

  6. linux 启动tomcat

    操作步骤: 第一步:进入tomcat的bin目录 cd /usr/local/tomcat/bin 第二步:使用tomcat关闭命令 ./shutdown.sh 第三步:查看tomcat是否关闭 ps ...

  7. AD软件中可视栅格 捕捉栅格 电气栅格的功能和设置详解

    AD16的栅格设置 AD16系统共有3种栅格:可视栅格.电气栅格.捕捉栅格. Snap:捕获栅格,如果设定值是10mil,鼠标的光标拖动零件引脚,距离可视栅格在10mil范围之内时,零件引脚自动的准确 ...

  8. unzip解压3G或者4G以上文件失败的解决方法

    Linux下,使用unzip解压时,报错:End-of-central-directory signature not found.  Either this file is nota zipfile ...

  9. DP tricks and experiences

    [LeetCode] 关于动态规划的经验与技巧. 很多时候多分配一位空间是为了递推的方便,例如前推两位. 辅助数组的索引,用到的可能是 1 — N,或者是 0 — N-1. 具体要看清 f[i] 每一 ...

  10. 通过jenkins api远程调用job

    curl http://jenkins地址/job/job_name/config.xml --user username:token