Source code on Github
------------------------------------------------------------------------
-- The Agda standard library
--
-- Sums (disjoint unions)
------------------------------------------------------------------------

{-# OPTIONS --cubical-compatible --safe #-}

module Data.Sum where

open import Data.Unit.Polymorphic.Base using (; tt)
open import Data.Maybe.Base using (Maybe; just; nothing)
open import Level
import Relation.Nullary.Decidable.Core as Dec

private
  variable
    a b : Level
    A B : Set a

------------------------------------------------------------------------
-- Re-export content from base module

open import Data.Sum.Base public

------------------------------------------------------------------------
-- Additional functions

module _ {A : Set a} {B : Set b} where

  isInj₁ : A  B  Maybe A
  isInj₁ (inj₁ x) = just x
  isInj₁ (inj₂ y) = nothing

  isInj₂ : A  B  Maybe B
  isInj₂ (inj₁ x) = nothing
  isInj₂ (inj₂ y) = just y

  From-inj₁ : A  B  Set a
  From-inj₁ (inj₁ _) = A
  From-inj₁ (inj₂ _) = 

  from-inj₁ : (x : A  B)  From-inj₁ x
  from-inj₁ (inj₁ x) = x
  from-inj₁ (inj₂ _) = _

  From-inj₂ : A  B  Set b
  From-inj₂ (inj₁ _) = 
  From-inj₂ (inj₂ _) = B

  from-inj₂ : (x : A  B)  From-inj₂ x
  from-inj₂ (inj₁ _) = _
  from-inj₂ (inj₂ x) = x

------------------------------------------------------------------------
-- DEPRECATED NAMES
------------------------------------------------------------------------
-- Please use the new names as continuing support for the old names is
-- not guaranteed.

-- Version 2.1

open Dec public using (fromDec; toDec)