代码改变世界

A Trac Feeds Screen Plugin is added

  Tower Joo  阅读(415)  评论(0编辑  收藏  举报

A Trac Feeds Screen Plugin is added

An old sentence goes like this, "It's best to mock it when you want to learn something new". And  this sentence proves to be correct to me after my implementing the trac feeds screen plugin for Touch Screen.

Background

I'm a newbie to the GSoC and I'm lucky that I can work with the osuosl project. This project is a Django based project, which employs some other Python related technologies, including twistedmuddle and etc.

The whole framework is like this(quoted from my proposal)
(notice: the diagram may be not so precise and maybe misleading, and I will draw another diagram when I know better to this project).

Week One

After reading some codes of Touch Screen and its plugins examples, I try to write a Trac feeds plugin, which has the following features:
  1. support all Trac Rss feeds
  2. a good UI
  3. a good performance(acceptable response time)
  4. fault tolerance
  5. loose coupling with current codes
With hours' coding, the usable plugin can be found in this checkin, which currently supports:
  1. timeline, tickets,  changeset Rss feeds 
  2. to boost performance by
    • cache the requested feeds in client side(javascript), --this  feature is configurable(enable/disable) 
    • limit the feeds number in server side(add a max=50 to limit the number)
  3. it's kind of loose coupling, which means you only need to add the app to the settings.py and add a url dispatcher to the urls.py. See README for more information
  4. See the below screenshot about the plugin



Tips

If you want to check out the codes and run it by yourself, you can follow the steps as below:
  1. check out the codes using git (git://github.com/topman/touchscreen.git)
  2. setup the enviroment
  3. edit the settings.py and urls.py(see screens/trac_feeds/README to know more)
  4. run it as an ordinary django project
  5. go to http://127.0.0.1:8000/plugins (adjust to your running url) to enable the plugin and set the configuration as you need
  6. and go to http://127.0.0.1:8000/, then you should see the screen
  7. use arrow-left and arrow-right to request more feeds

Plan

Next week, I will follow the plan as below:
  1. Refine the plugin to make it more robust and a better UI.
    • fault tolerance
    • a self-adjustable UI
    • stable enough to release as a plugin
  2. Read more codes and try to understand the core logic of the project


编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示