comparison Applications/Resources/Graveyard/Threading/IThreadSafety.h @ 1586:b5417e377636

reorganization
author Sebastien Jodogne <s.jodogne@gmail.com>
date Thu, 22 Oct 2020 16:17:10 +0200
parents OrthancStone/Resources/Graveyard/Threading/IThreadSafety.h@244ad1e4e76a
children 4fb8fdf03314
comparison
equal deleted inserted replaced
1585:94edbfa64c97 1586:b5417e377636
1 /**
2 * Stone of Orthanc
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics
4 * Department, University Hospital of Liege, Belgium
5 * Copyright (C) 2017-2020 Osimis S.A., Belgium
6 *
7 * This program is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU Affero General Public License
9 * as published by the Free Software Foundation, either version 3 of
10 * the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Affero General Public License for more details.
16 *
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 **/
20
21
22 #pragma once
23
24 #include <boost/noncopyable.hpp>
25
26 namespace OrthancStone
27 {
28 /**
29 * Dummy interface to explicitely tag the interfaces whose derived
30 * class must be thread-safe. The different methods of such classes
31 * might be simlultaneously invoked by several threads, and should
32 * be properly protected by mutexes.
33 **/
34 class IThreadSafe : public boost::noncopyable
35 {
36 public:
37 virtual ~IThreadSafe()
38 {
39 }
40 };
41
42
43 /**
44 * Dummy interface to explicitely tag the interfaces that are NOT
45 * expected to be thread-safe. The Orthanc Stone framework ensures
46 * that at most one method of such classes will be invoked at a
47 * given time. Such classes are automatically protected by the
48 * Orthanc Stone framework wherever required.
49 **/
50 class IThreadUnsafe : public boost::noncopyable
51 {
52 public:
53 virtual ~IThreadUnsafe()
54 {
55 }
56 };
57 }