Mercurial > octave-libtiff
view libinterp/corefcn/interpreter-private.h @ 31177:c7c79973007f
Tiff: added octave_tiff_handle class to wrap the Tiff file pointer
* __tiff__.cc (octave_tiff_handle): implemented a new class octave_tiff_handle
as a child of octave_base_value to be a wrapper for the Tiff file handle to
be passed to Octave instead of passing a pointer around.
* __tiff__.cc (F__open_tiff__, F__tiff_close__): modified handling TIFF file
pointer to use the new class (Other internal functions were modified as well).
* Tiff.m: removed checking for closed file, it is now handled internally.
author | magedrifaat <magedrifaat@gmail.com> |
---|---|
date | Wed, 17 Aug 2022 18:51:16 +0200 |
parents | 796f54d4ddbf |
children |
line wrap: on
line source
//////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017-2022 The Octave Project Developers // // See the file COPYRIGHT.md in the top-level directory of this // distribution or <https://octave.org/copyright/>. // // 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 // <https://www.gnu.org/licenses/>. // //////////////////////////////////////////////////////////////////////// #if ! defined (octave_interpreter_private_h) #define octave_interpreter_private_h 1 #include "octave-config.h" #include <list> #include <string> #include "symtab.h" namespace octave { class bp_table; class cdef_manager; class child_list; class display_info; class dynamic_loader; class error_system; class event_manager; class gh_manager; class gtk_manager; class help_system; class input_system; class interpreter; class load_path; class load_save_system; class output_system; class tree_evaluator; class type_info; extern OCTINTERP_API interpreter& __get_interpreter__ (const std::string& who); extern OCTINTERP_API dynamic_loader& __get_dynamic_loader__ (const std::string& who); extern OCTINTERP_API error_system& __get_error_system__ (const std::string& who); extern OCTINTERP_API gh_manager& __get_gh_manager__ (const std::string& who); extern OCTINTERP_API help_system& __get_help_system__ (const std::string& who); extern OCTINTERP_API input_system& __get_input_system__ (const std::string& who); extern OCTINTERP_API load_path& __get_load_path__ (const std::string& who); extern OCTINTERP_API load_save_system& __get_load_save_system__ (const std::string& who); extern OCTINTERP_API event_manager& __get_event_manager__ (const std::string& who); extern OCTINTERP_API output_system& __get_output_system__ (const std::string& who); extern OCTINTERP_API type_info& __get_type_info__ (const std::string& who); extern OCTINTERP_API symbol_table& __get_symbol_table__ (const std::string& who); extern OCTINTERP_API symbol_scope __get_current_scope__ (const std::string& who); extern OCTINTERP_API symbol_scope __require_current_scope__ (const std::string& who); extern OCTINTERP_API tree_evaluator& __get_evaluator__ (const std::string& who); extern OCTINTERP_API bp_table& __get_bp_table__ (const std::string& who); extern OCTINTERP_API child_list& __get_child_list__ (const std::string& who); extern OCTINTERP_API cdef_manager& __get_cdef_manager__ (const std::string& who); extern OCTINTERP_API display_info& __get_display_info__ (const std::string& who); extern OCTINTERP_API gtk_manager& __get_gtk_manager__ (const std::string& who); // Functions that could be methods in the interpreter class but maybe // shouldn't be exposed as part of the public interface. // Convert octave_value object ARG to be a function handle object. It // may be a function handle, inline function, the name of a function, // or the text of an inline function that has the given argument names // PARAMETER_NAMES. Use of the latter form is discouraged. OCTINTERP_API octave_value get_function_handle (interpreter& interp, const octave_value& arg, const std::string& parameter_name); OCTINTERP_API octave_value get_function_handle (interpreter& interp, const octave_value& arg, const std::list<std::string>& parameter_names = std::list<std::string> ()); } #endif