1
1
mirror of https://github.com/aelve/guide.git synced 2025-01-03 19:19:11 +03:00
A workspace for research teams
Go to file
2019-06-19 15:23:42 +03:00
favicon Fix pragma style 2017-07-23 02:54:35 +03:00
front-ps Group categories (#173) 2018-01-02 11:09:02 +01:00
guidejs Add missing rollup dependency 2017-03-31 11:15:11 +02:00
scripts Use gzip instead of zstd 2019-06-19 15:18:31 +03:00
src Let sessions live for 30 days 2018-10-17 23:34:25 +02:00
static Style tweaks for notes 2019-05-06 14:40:36 +02:00
templates Update CSS further 2019-05-06 16:47:12 +02:00
tests Nicer "add category" 2018-10-09 19:39:10 +02:00
.ghci Add a .ghci file 2016-07-30 01:11:56 +03:00
.gitignore Don't use unsafe T.head (and don't fail on empty links) 2017-11-02 03:28:24 +03:00
.gitlab-ci.yml Force GHC to install on every build if necessary. 2017-08-17 13:28:47 -05:00
.hlint.yaml Add a HLint settings file 2017-08-17 22:39:31 +03:00
.travis.yml Use gzip instead of zstd 2019-06-19 15:18:31 +03:00
b Add --nix option to run build script 2017-06-29 20:17:36 +02:00
CHANGELOG.md Create the project 2016-02-02 12:36:07 +03:00
guide.cabal Bump all versions 2018-08-20 00:25:38 +02:00
INSTALL.md Use gzip instead of zstd 2019-06-19 15:18:31 +03:00
LICENSE Create the project 2016-02-02 12:36:07 +03:00
official.sh Use gzip instead of zstd 2019-06-19 15:18:31 +03:00
README.md Testing "instructions" 2018-08-20 00:31:28 +02:00
Setup.hs Add no-js option for building 2017-08-19 18:13:24 +03:00
shell.nix Add custom shell.nix file 2017-10-09 09:30:41 +02:00
stack.yaml Fix stack.yaml 2019-06-19 15:23:42 +03:00
zurihac.md Fix 2017-06-09 14:02:46 +02:00

Aelve Guide

Build status BSD3 license

The beta version is running at guide.aelve.com. The most complete section yet is the one about lenses.

Installation instructions and the explanation of config variables (in config.json) are here: INSTALL.md. Don't be afraid to install it locally it's very easy! You don't need to set up any databases or anything like that, and you can get a full copy of the data from the site by simply cloning it from Github.

Contributing

If you want to contribute but don't know where to start, grep the source for [very-easy] and [easy], or look at these issues:

  • “your first pull request” really easy things, with detailed “how to fix it” instructions
  • “your second pull request” less easy things, which assume that you already know where stuff happens in the code
  • “not-fleshed-out idea” discussion issues (“should we have users? what better ways are there to present pros and cons?”) which you can help with even if you don't know Haskell
  • “design” issues about design (which I'm not good at, and so help is wanted)

Testing

You need chromedriver and selenium-server-standalone installed (those are the package names on Arch Linux). Then you can do

$ java -jar /usr/share/selenium-server/selenium-server-standalone.jar
$ stack test

Overview of the code

Folder structure

  • lib actual code (as a library)
  • src just a dumb Main.hs file to compile an executable
  • tests tests
  • static icons, CSS, Markdown pages, HTML pages, and some JS libraries
  • templates HTML templates for pages and elements of pages
  • scripts some scripts used by automatic testing
  • favicon code used to generate a favicon
  • guidejs client side JavaScript

Notes

When you see something like

-- See Note [acid-state]

it means that there's an extensive comment somewhere else in the code, which you can find by grepping for Note [acid-state]. This convention was stolen from GHC. If you know some plugin for Emacs that would help with jumping to comments (even if those comments would have to be formatted differently), let me know.

Main modules

THIS SECTION IS OUTDATED

There are 4 main modules Guide.hs, JS.hs, View.hs, and Types.hs.

Guide.hs contains:

  • handlers for GET/POST requests (renderMethods, setMethods, etc)
  • feed generation (itemToFeedEntry)
  • some utility functions (undoEdit, lucidWithConfig, createCheckpoint')
  • the main function, which starts the server

JS.hs contains all Javascript that is used in pages. The way it works is tricky: each Javascript function is overloaded in such a way that it can generate either a function call or a function definition. allJSFunctions, exported by JS.hs, is made by producing definitions from all functions in the module and then concatenating them; later allJSFunction is served by the server as /js.js. When you see something like JS.foo (a, b, c) in Haskell code, a call to foo is being generated (and foo can be found in JS.hs).

View.hs contains HTML rendering code. (It's much uglier than using templates, and we should switch to templates one day. Actually, maybe we should even switch to Node.js or Elm from Haskell.)

Types.hs contains almost all types used in code elsewhere Item, Category, and so on. GlobalState is a type for, well, the whole database used by the site. All content, all edits, and all analytics data (i.e. users' IPs, etc) are stored there. The data is held in memory, and acid-state makes sure that data on hard drive is kept in sync with it. For a more detailed explanation, see Note [acid-state].

Currently changing database schema is somewhat painful; to see how exactly painful it is, look at Note [extending types]. Not painful enough to never touch it again, sure, but still kinda annoying. Making it easier is possible, but for that we'd need a different acid-state or a real database.

Other modules

Markdown.hs contains functions for rendering Markdown. There are special types for Markdown as well, coupling rendered Markdown, its text representation, and its parse tree.

Merge.hs contains an algorithm for merging edits if you are editing a description of an item and someone else is editing the same description, upon submitting your edit you'll get a popup showing both versions and a merged version.

Cache.hs provides some helpers for caching pages. (A cache is a global variable holding a map from cache keys to rendered HTML.)

Config.hs has a config type and functions for reading/writing said config.

Utils.hs is just that utility functions.