🚧 Symphony(引起 || 处理)Bug 日志 & PR 日志

本贴最后更新于 2898 天前,其中的信息可能已经时移俗易

由于几乎每次贡献代码,都能引起点儿 bug 出来,让我深感惭愧,故觉有必要做一下记录,避免日后重复掉坑。给 D 大添麻烦真是太不好意思了 😭
顺便记录下自己处理的 bug(两种应该都不会很多,故而 Merge 了)

🐛 查看他人主页时标签页多出匿帖
错误原因:编辑此处代码时为了解逻辑,造成标签错误闭合
此处代码定义了四个标签页,分别是帖子、回复、匿帖、匿回。代码中嵌入了显示个数的标签。少写一个,此处显示就少一个(神奇的 FreeMarker,恕我并不了解)。写错的 if 标签,是用来判断是否在查看自己的主页,只有在自己的主页下才能查看匿帖和匿回。

🐛 编辑更新帖子报 500 错误
错误原因:在添加同步开关时,针对新增文章导向的页面 post.ftl 添加了新的字段,但没有在编辑文章处对新加的字段进行赋值
此外,判断值的时候,由于 CV 代码,对值进行了错误的判断,真是蠢哭……
在做此功能时,明明搜过 post.ftl,即知道不止一个 controller 导向了 post.ftl,却没有在相应的方法上加上需要的值,导致该 controller 导向这个页面时,引用了空对象导致异常。至于 CV 代码,实在是容易引发错误啊,
日后就算 CV,只要不是同一个东西,就手敲改写

🐛 同步文章失败
错误原因:蠢。。。瞎。。。
明明不到两行的位置下面就有自己打算添加的代码,没看到,添加重了不说,还特么添加错了 orz
太毛糙,急于提交代码,没有改后进行基本的测试。
缺少艺术家那种再小的细节也要认真处理的匠心、耐心……

🐛
错误原因:pegdown 对于纯 html 解析的不够完善,会进入死循环,可参考:PegdownIssue
这个问题一开始我跑偏了,试图从 pegdown 入手解决(心真大。。。),然而纠结了两三天的代码,并没有什么很好的解决办法(实际上,由于 eclipse 对于 maven 项目源码查看的问题,我跟踪代码困难重重,基本靠猜……),最终反过来还是在 sym 上入手,然而问题来了,虽然连蒙带猜的发现,对于纯 html,如果外面包裹上一层 < p > 标签,就可以解决,然而对于非纯 html 的 MD 语法就不行了(然而我由于太激动以为解决了就 PR 了,给自己造成了代码不同步的麻烦。。。说多了都是泪。 下次 PR 前一定要自己测清楚,之前的用例必须通过再说,一旦 PR 了,要改的话最好先合并了再改)

💄 升级 emoji 表情
TAPR(Thinking After PR):这次改动主要在图片文件上,原 emojify 是基于 gemoji 的,故而支持 alias 解析,而 twemoji 并没有 alias 一说,表情多达两千,看解析似乎是通过 unicode 码,具体怎么取调用,我是没看懂,不过感觉可能是那种选图的方式,其 emoji 图片命名是通过 codepoint,所以一开始的方案是,转换 alias 到 unicode,然后再转换为 codepoint,再转换为路径(sym 使用图库的方式比较偏门,不按他们的套路来,等同于只用了图片素材)。由此纠结了很久,诸如如何处理转换不了的,有没与可能通过 codepoint 转换为 alias 的,多余的图片是否保留等,一一搞定,到了最后,处理弹出快捷表情列表的时候,发现之前的方法统统不行了。。。强行做也行,无非就是再加一个 ajax,去后台获取 alias,然而为了这么个功能,在前端加了两个 ajax 请求,刚在看 web 性能的我觉得有点蛋疼,于是放弃了,同时回滚了两天的修修补补,在五点快下班的时候,用了大概三个小时,进行了图片文件改名,也是之前讨论的第二方案。一开始就感觉改名对代码改动最小,是比较靠谱的一个方案,但是 codepoint 不知到如何转换为 alias,后来做的时候已经通过 alias 生成了 codepoint,现在只要对应一下,写个脚本改就行了(脚本写的很丑陋就不放了,多谢 sublime 列编辑……)
说这么多,总结一下就两点: 对原逻辑改动最小的总是最优办法;重点是如何达到目的,而不是考虑解决办法看起来是否炫酷优雅。。

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3453 回帖 • 204 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 699 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    408 引用 • 3574 回帖 • 1 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    75 引用 • 1737 回帖 • 3 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 千万不要有愧疚感。你能一起帮忙维护这个开源项目已经很好了,我们这个不是火箭上天的工程,所以上线后再测试也是可以有的。

    说起细心、耐心来,确实是个习惯,但不一定这样做就是好的或者对的。我们都知道看待事情应该分多个角度,非要衡量对错的话我想唯一标准就是看“大部分人”是否都能接受罢了。讲道理就事论事,这几个 bugs 其实也增加我们之间的沟通,并且也有其他人发现了 bug 并且报告给了我们,对于我个人来说倍感欣慰啊。说大了,这才是一个生态系统的价值,我们的目标不是产出一个 Sym 程序,而是将对这个程序、对我们在做的事情感兴趣的人连接起来,这个代谢过程才是真正的价值。

    总之,还要谢谢你的。天冷了,多喝开水~

    1 回复
  • ZephyrJung

    相比愧疚感,更多的还是烦恼自己水平问题
    希望能在不断贡献代码中,让自己成为代码的艺术家 💰

ZephyrJung
一切有为法,如梦幻泡影,如露亦如电,应作如是观 北京

推荐标签 标签

  • 音乐

    你听到信仰的声音了么?

    60 引用 • 511 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    729 引用 • 1327 回帖 • 1 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 261 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    169 引用 • 506 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    32 引用 • 131 回帖 • 2 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 764 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖 • 4 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 589 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 4 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    179 引用 • 995 回帖
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    117 引用 • 99 回帖 • 212 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 391 关注
  • Ubuntu

    Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

    125 引用 • 169 回帖
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 114 关注
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    176 引用 • 815 回帖
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 62 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • 电影

    这是一个不能说的秘密。

    120 引用 • 599 回帖
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    568 引用 • 3532 回帖 • 1 关注
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    266 引用 • 665 回帖 • 1 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3453 回帖 • 204 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 680 关注
  • CodeMirror
    1 引用 • 2 回帖 • 129 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 407 回帖 • 488 关注