Skip to content

Latest commit

 

History

History
98 lines (88 loc) · 3.32 KB

README.md

File metadata and controls

98 lines (88 loc) · 3.32 KB

Graphie

Graphie is a graph database converter and query frontend for HIE files for GHC. It converts the ASTs in HIE files to a Neo4J graph and provides a frontend client for navigating a codebase by following relationships and using graph queries.

Try it out at https://graphie.lam.io!

How to connect: This is the standard neo4j web client. Connect with:

  • Host: [scheme: bolt+s://] graphie.lam.io
  • Username: public
  • Password: public

The graph in this database is the code graph of graphie itself! Explore all the recursive dependencies of this project in all its graphical goodness.

Details

Compatibility note: Graphie is only compatible with Neo4J 3.x, as the BOLT/Neo4J driver for Haskell (Hasbolt) isn't yet compatible with Neo4J 4.x - the latest BOLT protocol has only recently been open-sourced.

Graphie fulfills a long-standing need I've had for a way to acquaint with a codebase quickly through statistics and data exploration. A notable example is stacker which I developed for this purpose too, specifically to identify the dependency set of a given callsite or value: this has been superceded by graphie. The Haskell code using the HIE API to navigate the ASTs can all be distilled into a few short graph queries.

2020-12-28: HIE → Neo4J direction works, albeit slowly. Investigating a faster way to shove data in, probably using the bulk insertion methods provided by Neo4J. Here's some idea of what the schema looks like, where node labels are camel-case and relationship types are uppercase snake-case (standard Neo4J naming conventions), standard DDL convention for 1 (one), >0 (+), 0 or 1 (?), ≥0 (*), relationships from (-) and to ([*+?1]->), parameter sets that are disjoint (based on a case over datacons usually) are represented by brackets and pipes |:

GraphieAST
  1 ann_ctors [str]
  1 ann_tys [str]
  1 <span>
GraphieTy
  1 con string
  1 path string
  1 idx int
    ( 1 name string )
  | ( 1 value (int | str) )
GRAPHIE_AST2TY
  - GraphieAST
  *-> GraphieTy
  1 pos int
GraphieIdent
  1 con {Name, ModuleName}
  1 name string
  1 uniq string
GRAPHIE_AST2CTX
  - GraphieAST
  *-> GraphieCtx
GRAPHIE_AST2IDENT
  - GraphieAST
  *-> GraphieIdent
GRAPHIE_IDENT2TY
  - GraphieIdent
  *-> GraphieTy
GRAPHIE_AST2AST
  - GraphieAST
  *-> GraphieAST
  1 pos int
GraphieCtx
  1 con string
  1 path string
    ( 1 ietycon string)
  | ( 1 bindtycon string
      ? bind_<span>
    )
  | ( ? bind_<span>
      1 pat_<scope>
      1 out_<scope>
    )
  | ( ? bind_<span> )
  | ( 1 decltycon string
      ? bind_<span>
    )
  | ( 1 <scope> )
  | ( 1 ctxtycon string
      ? bind_<span>
    )
GRAPHIE_TY_REL
  - GraphieTy
  *-> GraphieTy
  1 path string
  1 pos int
# GRAPHIE_NAME2NAME
#   - GraphieAST
#   - GraphieAST
GraphieHieFile
  1 hs_file string
  1 hie_module string
  1 hie_module_uniq string
GRAPHIE_FILE2AST
  - GraphieHieFile
  *-> GraphieHieAST
<span>
  1 ^sp_fn string
  1 ^sp_l0 int
  1 ^sp_ch0 int
  1 ^sp_lf int
  1 ^sp_chf int
<scope>
  1 ^scope string
  ? ^<span>