X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fprotected-scm.hh;h=0115cb9f9ff6e2d388dd2fc714ec5639cdcc180c;hb=3af0951f9a11677240efa6228683dd4fcea13eaf;hp=7a13b24b1fd485037d67850950953838f3149c0a;hpb=0817e0513d1016ff22a633b6fee20ddba2a062f2;p=lilypond.git diff --git a/lily/include/protected-scm.hh b/lily/include/protected-scm.hh index 7a13b24b1f..0115cb9f9f 100644 --- a/lily/include/protected-scm.hh +++ b/lily/include/protected-scm.hh @@ -1,33 +1,59 @@ -/* - protected-scm.hh -- declare Protected_scm - - source file of the GNU LilyPond music typesetter - - (c) 1998--2001 Han-Wen Nienhuys - - */ +/* + This file is part of LilyPond, the GNU music typesetter. + + Copyright (C) 1998--2015 Han-Wen Nienhuys + + LilyPond 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. + + LilyPond 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 LilyPond. If not, see . +*/ #ifndef PROTECTED_SCM_HH #define PROTECTED_SCM_HH - #include "lily-guile.hh" /* - Mix GUILE GC with C++ ctors and dtors. - */ + Mix GUILE GC with C++ ctors and dtors. + + This version is intended to be only used for variables of static + lifetime (which are not feasible to protect using the per-instance + mechanism of the smob classes) but possibly varying content. As a + result, the protection mechanism being used is the irreversible + scm_permanent_object. The destructor (typically called after the + end of program execution) does not free resources and consequently + does not require the memory subsystem to be still workable. A + working memory subsystem is only required once a non-immediate + Scheme value is assigned to the variable. Since creation of a + non-immediate Scheme value requires a working memory subsystem in + the first place, this is not really a restriction. + + To avoid accidental creation of temporaries, the copy constructor is + made unavailable. +*/ class Protected_scm { SCM object_; + static SCM list_; + static SCM last_; + Protected_scm (Protected_scm const &); + void protectify (SCM); public: Protected_scm (); Protected_scm (SCM); - Protected_scm (Protected_scm const &); - ~Protected_scm (); Protected_scm &operator = (SCM); - Protected_scm &operator = ( Protected_scm const&); - operator SCM () const; - SCM to_SCM () const; + Protected_scm &operator = (Protected_scm const &); + operator const SCM & () const; + operator SCM & (); }; #endif /* PROTECTED_SCM_HH */