= https://github.com/input-output-hk/plutus[Plutus Core] :email: plutus@iohk.io :author: Input Output HK Limited :toc: left :reproducible: image:https://img.shields.io/badge/policy-Cardano%20Engineering%20Handbook-informational[link=https://input-output-hk.github.io/cardano-engineering-handbook] == Introduction Plutus Core is the scripting language embedded in the Cardano ledger and forms the basis of the Plutus Platform, an application development platform for developing distributed applications using the Cardano blockchain. For more information about the projects, see the <<user-documentation>>. This repository contains: * The implementation, specification, and mechanized metatheory of Plutus Core * Plutus Tx, the compiler from Haskell to Plutus Core. For people who want to *use* the project, please consult the <<user-documentation>>. == Development [[how-to-develop]] === How to develop and contribute to the project Run `nix develop` to enter the development shell and you will be presented with a list of available commands. **Please see link:CONTRIBUTING{outfilesuffix}[CONTRIBUTING] for comprehensive documentation on how to contribute to the project, including development and submitting changes* === How to submit an issue Issues can be filed in the https://github.com/input-output-hk/plutus/issues[GitHub Issue tracker]. === How to depend on the project from another Haskell project The `plutus` libraries are published via https://input-output-hk.github.io/cardano-haskell-packages/[CHaP]. See the information there for how to use CHaP. After setting it up you should just be able to depend on the `plutus` packages as normal and cabal will find them. == Documentation === User documentation The main documentation is located https://plutus.readthedocs.io/en/latest/[here]. === Talks - https://www.youtube.com/watch?v=MpWeg6Fg0t8[Functional Smart Contracts on Cardano (2020)]: an overview of the ideas behind the Plutus Platform. - https://www.youtube.com/watch?v=usMPt8KpBeI[The Plutus Platform (2020)]: an overview of the Platform as a whole (including the Application Framework) at the time. === Specifications and design - https://cicero.ci.iog.io/api/fact/cd621238-b1b5-49b3-8971-cac97f27824d/binary[Plutus Technical Report (draft)]: a technical report and design document for the project. - https://cicero.ci.iog.io/api/fact/e620956c-f0f9-4605-bb06-e3d92cc92b6b/binary[Plutus Core Specification]: the formal specification of the core language. - https://cicero.ci.iog.io/api/fact/ffdcd1ee-97e2-4661-936d-4b41086d646a/binary[Extended UTXO Model]: a design document for the core changes to the Cardano ledger. === Academic papers - https://cicero.ci.iog.io/api/fact/37d63c20-a40c-499e-b2c9-7a183df88ae6/binary[Unraveling Recursion]: a description of some of the compilation strategies used in Plutus IR (https://doi.org/10.1007/978-3-030-33636-3_15[published version]). - https://cicero.ci.iog.io/api/fact/11d0d6b3-5245-4c4e-b1c8-d7989d2be773/binary[System F in Agda]: a formal model of System F in Agda (https://doi.org/10.1007/978-3-030-33636-3_10[published version]). - https://cicero.ci.iog.io/api/fact/81b80423-02e9-4067-858c-cc8f479e56bf/binary[The Extended UTXO Model]: a full presentation of the EUTXO ledger extension (https://doi.org/10.1007/978-3-030-54455-3_37[published version]). - https://cicero.ci.iog.io/api/fact/c7d73a9f-5a70-45a9-9e6c-7d20539af811/binary[UTXOma: UTXO with Multi-Asset Support]: a full presentation of the multi-asset ledger extension (https://doi.org/10.1007/978-3-030-61467-6_8[published version]). - https://cicero.ci.iog.io/api/fact/fa3522f8-b89f-415c-b03f-a78414312b97/binary[Native Custom Tokens in the Extended UTXO Model]: a discussion of the interaction of the multi-asset support with EUTXO (https://doi.org/10.1007/978-3-030-61467-6_7[published version]). - https://arxiv.org/abs/2201.04919[Translation Certification for Smart Contracts]: a certifier of Plutus IR compiler passes written in Coq. == Licensing You are free to copy, modify, and distribute this software under the terms of the Apache 2.0 license. See the link:./LICENSE[LICENSE] and link:./NOTICE[NOTICE] files for details.