annotate src/core_util.sig @ 20:1ab48e37d0ef

Some con reducing
author Adam Chlipala <adamc@hcoop.net>
date Sun, 08 Jun 2008 15:47:44 -0400
parents bc7b76ca57e0
children 067029c748e9
rev   line source
adamc@16 1 (* Copyright (c) 2008, Adam Chlipala
adamc@16 2 * All rights reserved.
adamc@16 3 *
adamc@16 4 * Redistribution and use in source and binary forms, with or without
adamc@16 5 * modification, are permitted provided that the following conditions are met:
adamc@16 6 *
adamc@16 7 * - Redistributions of source code must retain the above copyright notice,
adamc@16 8 * this list of conditions and the following disclaimer.
adamc@16 9 * - Redistributions in binary form must reproduce the above copyright notice,
adamc@16 10 * this list of conditions and the following disclaimer in the documentation
adamc@16 11 * and/or other materials provided with the distribution.
adamc@16 12 * - The names of contributors may not be used to endorse or promote products
adamc@16 13 * derived from this software without specific prior written permission.
adamc@16 14 *
adamc@16 15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
adamc@16 16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
adamc@16 17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
adamc@16 18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
adamc@16 19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
adamc@16 20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
adamc@16 21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
adamc@16 22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
adamc@16 23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
adamc@16 24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
adamc@16 25 * POSSIBILITY OF SUCH DAMAGE.
adamc@16 26 *)
adamc@16 27
adamc@16 28 signature CORE_UTIL = sig
adamc@16 29
adamc@16 30 structure Kind : sig
adamc@16 31 val mapfold : (Core.kind', 'state, 'abort) Search.mapfolder
adamc@16 32 -> (Core.kind, 'state, 'abort) Search.mapfolder
adamc@16 33 val map : (Core.kind' -> Core.kind') -> Core.kind -> Core.kind
adamc@16 34 val exists : (Core.kind' -> bool) -> Core.kind -> bool
adamc@16 35 end
adamc@16 36
adamc@16 37 structure Con : sig
adamc@16 38 datatype binder =
adamc@16 39 Rel of string * Core.kind
adamc@20 40 | Named of string * int * Core.kind * Core.con option
adamc@16 41
adamc@16 42 val mapfoldB : {kind : (Core.kind', 'state, 'abort) Search.mapfolder,
adamc@16 43 con : ('context, Core.con', 'state, 'abort) Search.mapfolderB,
adamc@16 44 bind : 'context * binder -> 'context}
adamc@16 45 -> ('context, Core.con, 'state, 'abort) Search.mapfolderB
adamc@16 46 val mapfold : {kind : (Core.kind', 'state, 'abort) Search.mapfolder,
adamc@16 47 con : (Core.con', 'state, 'abort) Search.mapfolder}
adamc@16 48 -> (Core.con, 'state, 'abort) Search.mapfolder
adamc@16 49
adamc@16 50 val map : {kind : Core.kind' -> Core.kind',
adamc@16 51 con : Core.con' -> Core.con'}
adamc@16 52 -> Core.con -> Core.con
adamc@16 53
adamc@16 54 val mapB : {kind : Core.kind' -> Core.kind',
adamc@16 55 con : 'context -> Core.con' -> Core.con',
adamc@16 56 bind : 'context * binder -> 'context}
adamc@16 57 -> 'context -> (Core.con -> Core.con)
adamc@16 58 val exists : {kind : Core.kind' -> bool,
adamc@16 59 con : Core.con' -> bool} -> Core.con -> bool
adamc@16 60 end
adamc@16 61
adamc@16 62 structure Exp : sig
adamc@16 63 datatype binder =
adamc@16 64 RelC of string * Core.kind
adamc@20 65 | NamedC of string * int * Core.kind * Core.con option
adamc@16 66 | RelE of string * Core.con
adamc@20 67 | NamedE of string * int * Core.con * Core.exp option
adamc@16 68
adamc@16 69 val mapfoldB : {kind : (Core.kind', 'state, 'abort) Search.mapfolder,
adamc@16 70 con : ('context, Core.con', 'state, 'abort) Search.mapfolderB,
adamc@16 71 exp : ('context, Core.exp', 'state, 'abort) Search.mapfolderB,
adamc@16 72 bind : 'context * binder -> 'context}
adamc@16 73 -> ('context, Core.exp, 'state, 'abort) Search.mapfolderB
adamc@16 74 val mapfold : {kind : (Core.kind', 'state, 'abort) Search.mapfolder,
adamc@16 75 con : (Core.con', 'state, 'abort) Search.mapfolder,
adamc@16 76 exp : (Core.exp', 'state, 'abort) Search.mapfolder}
adamc@16 77 -> (Core.exp, 'state, 'abort) Search.mapfolder
adamc@16 78
adamc@16 79 val map : {kind : Core.kind' -> Core.kind',
adamc@16 80 con : Core.con' -> Core.con',
adamc@16 81 exp : Core.exp' -> Core.exp'}
adamc@16 82 -> Core.exp -> Core.exp
adamc@16 83 val exists : {kind : Core.kind' -> bool,
adamc@16 84 con : Core.con' -> bool,
adamc@16 85 exp : Core.exp' -> bool} -> Core.exp -> bool
adamc@16 86 end
adamc@16 87
adamc@20 88 structure Decl : sig
adamc@20 89 datatype binder = datatype Exp.binder
adamc@20 90
adamc@20 91 val mapfoldB : {kind : (Core.kind', 'state, 'abort) Search.mapfolder,
adamc@20 92 con : ('context, Core.con', 'state, 'abort) Search.mapfolderB,
adamc@20 93 exp : ('context, Core.exp', 'state, 'abort) Search.mapfolderB,
adamc@20 94 decl : ('context, Core.decl', 'state, 'abort) Search.mapfolderB,
adamc@20 95 bind : 'context * binder -> 'context}
adamc@20 96 -> ('context, Core.decl, 'state, 'abort) Search.mapfolderB
adamc@16 97 end
adamc@20 98
adamc@20 99 structure File : sig
adamc@20 100 datatype binder = datatype Exp.binder
adamc@20 101
adamc@20 102 val mapfoldB : {kind : (Core.kind', 'state, 'abort) Search.mapfolder,
adamc@20 103 con : ('context, Core.con', 'state, 'abort) Search.mapfolderB,
adamc@20 104 exp : ('context, Core.exp', 'state, 'abort) Search.mapfolderB,
adamc@20 105 decl : ('context, Core.decl', 'state, 'abort) Search.mapfolderB,
adamc@20 106 bind : 'context * binder -> 'context}
adamc@20 107 -> ('context, Core.file, 'state, 'abort) Search.mapfolderB
adamc@20 108
adamc@20 109 val mapB : {kind : Core.kind' -> Core.kind',
adamc@20 110 con : 'context -> Core.con' -> Core.con',
adamc@20 111 exp : 'context -> Core.exp' -> Core.exp',
adamc@20 112 decl : 'context -> Core.decl' -> Core.decl',
adamc@20 113 bind : 'context * binder -> 'context}
adamc@20 114 -> 'context -> Core.file -> Core.file
adamc@20 115 end
adamc@20 116
adamc@20 117 end