/usr/share/hol88-2.02.19940316/Library/window/tactic.ml is in hol88-library-source 2.02.19940316-35.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 | % --------------------------------------------------------------------- %
% Copyright (c) Jim Grundy 1992 %
% All rights reserved %
% %
% Jim Grundy, hereafter referred to as `the Author', retains the %
% copyright and all other legal rights to the Software contained in %
% this file, hereafter referred to as `the Software'. %
% %
% The Software is made available free of charge on an `as is' basis. %
% No guarantee, either express or implied, of maintenance, reliability, %
% merchantability or suitability for any purpose is made by the Author. %
% %
% The user is granted the right to make personal or internal use %
% of the Software provided that both: %
% 1. The Software is not used for commercial gain. %
% 2. The user shall not hold the Author liable for any consequences %
% arising from use of the Software. %
% %
% The user is granted the right to further distribute the Software %
% provided that both: %
% 1. The Software and this statement of rights is not modified. %
% 2. The Software does not form part or the whole of a system %
% distributed for commercial gain. %
% %
% The user is granted the right to modify the Software for personal or %
% internal use provided that all of the following conditions are %
% observed: %
% 1. The user does not distribute the modified software. %
% 2. The modified software is not used for commercial gain. %
% 3. The Author retains all rights to the modified software. %
% %
% Anyone seeking a licence to use this software for commercial purposes %
% is invited to contact the Author. %
% --------------------------------------------------------------------- %
%============================================================================%
% CONTENTS: tactics for interfacing subgoal and window proof. %
%============================================================================%
%$Id: tactic.ml,v 3.1 1993/12/07 14:15:19 jg Exp $%
% Open a subwindow on the goal, transform it, close it, %
% transform the goal. %
let open_TAC p thms f gl =
let (hyps, foc) = gl in
let win = create_win (mk_comb (imp_tm, foc)) (term_setify hyps) thms in
let (subwin, close) = open_win_basis (FOCUS_PATH p) win in
let th = win_thm (close (f subwin) win) in
MATCH_MP_TAC th gl;;
% When we create a stack for a tactic, we do not place a window whose focus %
% is the current subgoal on the stack. The stack starts at the indicated %
% subterm. However, we need to store this bottom window and the close %
% function to get back from the window we store to the bottom window in %
% order for the whole thing to work. Hence this table of windows and %
% close functions called close_table. %
begin_section tacsec;;
letref close_table = [] :
(string # (window # (window -> window -> window))) list;;
let BEGIN_STACK_TAC name p thms gl =
let (hyps, foc) = gl in
let shyps = term_setify hyps in
let win = create_win (mk_comb (imp_tm, foc)) shyps thms in
let (subwin, close) = open_win_basis (FOCUS_PATH p) win in
let subfoc = focus subwin in
let subrel = relation subwin in
BEGIN_STACK name (mk_comb (subrel, subfoc)) shyps thms;
close_table := (name,(win,close)).close_table;
ALL_TAC gl;;
let END_STACK_TAC name =
if mem name (map fst close_table) then
let (_,(win,close)) = assoc name close_table in
letref the_stack = GET_STACK name in
let th =
while (not ((depth_stack the_stack) = 1)) do
(
the_stack := close_window the_stack
);
win_thm (close (top_window the_stack) win)
in
END_STACK name;
close_table := filter (\(n,_). (not (n = name))) close_table;
MATCH_MP_TAC th
else
failwith `END_STACK_TAC: not a tactic based stack`;;
(BEGIN_STACK_TAC, END_STACK_TAC);;
end_section tacsec;;
let (BEGIN_STACK_TAC, END_STACK_TAC) = it;;
|