Skip to content

MarekSuchanek/hCM

master
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Code

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
app
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

hCM

Conceptual modelling support library for Haskell.

License Build Status Hackage Hackage-Deps

Introduction

This library is the result of finding a suitable way how to support conceptual modelling within Haskell programming language in the most simple but smart manner. hCM should allow you to build conceptual model with Haskell freely without any restrictions about selected representation of entities, relationships and model itself.

Advantages gained by applying hCM are:

  • Compiler-driven modelling = GHC guides you through implementing conceptual model via writing instances and mandatory functions.
  • Visualization = you can generate visualization of model and its instances (DOT format, see Graphviz)
  • Verification = correctness of model-implementation consistency is guaranteed by using conceptual model as part of implementation (model-is-a-code)
  • Validation = you can validate the conceptual model with domain expert thanks to visualization, instance generation (use QuickCheck's Arbitrary) and easy constraint construction as pure functions

Installation

  • Use standard Haskell way with stack.
  • Optionally you can use prepared Makefile.

Usage

There is very simple example of trivial model within app/Example.hs file. For more complex example, try to check hCM-CaseStudy.

If you have used this library and want to share your project, feel free to let me know via issues.

Sharing ideas and reporting bugs is more than welcome as well via issues!

License

This project is licensed under the MIT license - see the LICENSE file for more details.