view libinterp/parse-tree/pt-except.cc @ 23435:c452180ab672

begin refactoring parse tree evaluator * libinterp/parse-tree/pt-tm-const.cc, libinterp/parse-tree/pt-tm-const.h: New files, extracted from pt-mat.h and pt-mat.cc. * libinterp/parse-tree/module.mk: Update. * interpreter.cc, ov-class.cc, ov-classdef.cc, ov-classdef.h, ov-fcn-handle.cc, ov-fcn-handle.h, ov-usr-fcn.cc, oct-parse.in.yy, pt-arg-list.cc, pt-arg-list.h, pt-array-list.h, pt-assign.cc, pt-assign.h, pt-binop.cc, pt-binop.h, pt-cbinop.cc, pt-cbinop.h, pt-cell.cc, pt-cell.h, pt-classdef.cc, pt-classdef.h, pt-cmd.cc, pt-cmd.h, pt-colon.cc, pt-colon.h, pt-const.cc, pt-const.h, pt-decl.cc, pt-decl.h, pt-eval.cc, pt-eval.h, pt-except.cc, pt-except.h, pt-exp.cc, pt-exp.h, pt-fcn-handle.cc, pt-fcn-handle.h, pt-funcall.cc, pt-funcall.h, pt-id.cc, pt-id.h, pt-idx.cc, pt-idx.h, pt-jit.cc, pt-jump.cc, pt-jump.h, pt-loop.cc, pt-loop.h, pt-mat.cc, pt-mat.h, pt-misc.cc, pt-misc.h, pt-select.cc, pt-select.h, pt-stmt.cc, pt-stmt.h, pt-unop.cc, pt-unop.h: Use tree_evaluator class to walk the parse tree instead of rvalue methods in the parse tree classes. Maintain a stack in the evaluator class to accumulate results. Pass pointer to evaluator to function objects and other classes as needed for evaluation. This is a work in progress that is not yet complete. The ultimate goal is to move all evaluation into the tree_evaluator class instead of spreading that work among many different classes. The global pointer to the current evaluator should also be eliminated.
author John W. Eaton <jwe@octave.org>
date Fri, 21 Apr 2017 18:07:40 -0400
parents 092078913d54
children a3898679d459
line wrap: on
line source

/*

Copyright (C) 1996-2017 John W. Eaton

This file is part of Octave.

Octave is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.

Octave is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with Octave; see the file COPYING.  If not, see
<http://www.gnu.org/licenses/>.

*/

#if defined (HAVE_CONFIG_H)
#  include "config.h"
#endif

#include "quit.h"

#include "error.h"
#include "oct-lvalue.h"
#include "ov.h"
#include "pt-bp.h"
#include "pt-cmd.h"
#include "pt-except.h"
#include "pt-exp.h"
#include "pt-id.h"
#include "pt-jump.h"
#include "pt-stmt.h"
#include "pt-walk.h"
#include "unwind-prot.h"
#include "variables.h"

namespace octave
{
  // Simple exception handling.

  tree_try_catch_command::~tree_try_catch_command (void)
  {
    delete expr_id;
    delete try_code;
    delete catch_code;
    delete lead_comm;
    delete mid_comm;
    delete trail_comm;
  }

  tree_command *
  tree_try_catch_command::dup (symbol_table::scope_id scope,
                               symbol_table::context_id context) const
  {
    return new
      tree_try_catch_command (try_code ? try_code->dup (scope, context) : 0,
                              catch_code ? catch_code->dup (scope, context) : 0,
                              expr_id ? expr_id->dup (scope, context) : 0,
                              lead_comm ? lead_comm->dup () : 0,
                              mid_comm ? mid_comm->dup () : 0,
                              trail_comm ? trail_comm->dup () : 0,
                              line (), column ());
  }

  // Simple exception handling.

  tree_unwind_protect_command::~tree_unwind_protect_command (void)
  {
    delete unwind_protect_code;
    delete cleanup_code;
    delete lead_comm;
    delete mid_comm;
    delete trail_comm;
  }

  tree_command *
  tree_unwind_protect_command::dup (symbol_table::scope_id scope,
                                    symbol_table::context_id context) const
  {
    return new tree_unwind_protect_command
      (unwind_protect_code ? unwind_protect_code->dup (scope, context) : 0,
       cleanup_code ? cleanup_code->dup (scope, context) : 0,
       lead_comm ? lead_comm->dup () : 0,
       mid_comm ? mid_comm->dup () : 0,
       trail_comm ? trail_comm->dup () : 0,
       line (), column ());
  }
}