Skip to content
A bunch of Clojure code
Branch: master
Clone or download
jacobobryant 0.1.9
Fix embarassing bug in trident.cli
Latest commit 5b0c625 Jun 15, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
bin 0.1.7 Jun 13, 2019
doc Bugfix Jun 11, 2019
src-dev 0.1.7 Jun 13, 2019
src/trident 0.1.9 Jun 15, 2019
.gitignore Stop using planck, add pom/jar/install/deploy commands, rename May 23, 2019
LICENSE Add license May 22, 2019
README.md 0.1.9 Jun 15, 2019
deps.edn 0.1.9 Jun 15, 2019

README.md

trident/<artifact> {:mvn/version "0.1.9"}

Trident

Because I had to call it something

Trident is my personal experiment in creating a highly-abstracted web application framework for use with Datomic Cloud. But it's also just a collection of libraries, containing anything I happen to abstract out of projects I'm working on.

My top-level goal with Trident is to maximize code reuse (especially my own, but hopefully for others as well). This has two parts:

  • There should be high-level interfaces that give you lots of leverage (like frameworks).

  • When the high-level interfaces don't cut it, it should be easy to use only the parts you want, customizing behavior as needed (like libraries).

See this article for more information about my philosophy.

Contents

I keep the code in a single src dir, but I provide multiple artifacts. Any code in src/trident/<foo> is available in the tridnet/<foo> artifact. For example, {trident/cli {:mvn/version "<version>"}} will give you access to the trident.cli namespace. All artifacts use the same version.

I use the trident/docs artifact for documentation on cljdoc. You can browse the namespaces to see what's available, but here's a list of the artifacts for convenience:

  • trident/repl. A handful of convenience functions for use at the repl.
  • trident/util. A collection of utility functions & macros.
  • trident/cli (includes util). Makes it easy to define and reuse CLIs for tools.deps-based build tasks.
  • trident/ion-dev (includes cli). Stuff for ion develeopment
  • trident/build (includes util, cli). A collection of build tasks made with trident/cli.
  • trident/datomic (includes util). Janky file-based persistence for Datomic Free.
  • trident/datomic-cloud (includes util). Tools for Datomic Cloud.
  • trident/ring. Some Ring middleware.
  • trident/firebase. Functions for authenticating Firebase user tokens.
  • trident/ion (includes util). Utilities for working with Datomic Ions
  • trident/web (includes util, datomic-cloud, firebase, ion, ring). Highly contrived web framework.
  • trident/web-repl (includes web). A dev web server for use with trident/web.
  • trident/datascript (includes util). Frontend tools for syncing Datascript with Datomic.
  • trident/views (includes util). Some Reagent components and stuff.
  • trident/cljs-http. Slight additions to cljs-http
  • trident/frontend (includes util, datascript, views, cljs-http). Just a bundle of other artifacts.

Also see trident.cli Getting Started.

Progress

While I hope Trident will be useful for others, I'm primarily focusing on my own use cases because 1) there are things I want to build, 2) developing Trident as I build real things will help to make sure it's actually useful. With that out of the way, if you're interested in anything Trident does, I'd love to chat.

Projects using Trident:

Contact

License

Distributed under the EPL v2.0

Copyright © 2019 Jacob O'Bryant.

You can’t perform that action at this time.