~ubuntu-branches/ubuntu/intrepid/tcm/intrepid

« back to all changes in this revision

Viewing changes to src/dg/buffer.h

  • Committer: Bazaar Package Importer
  • Author(s): Otavio Salvador
  • Date: 2003-07-03 20:08:21 UTC
  • Revision ID: james.westby@ubuntu.com-20030703200821-se4xtqx25e5miczi
Tags: upstream-2.20
ImportĀ upstreamĀ versionĀ 2.20

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
//------------------------------------------------------------------------------
 
2
// 
 
3
// This file is part of Toolkit for Conceptual Modeling (TCM).
 
4
// (c) copyright 1995, Vrije Universiteit Amsterdam.
 
5
// Author: Frank Dehne (frank@cs.vu.nl).
 
6
//
 
7
// TCM is free software; you can redistribute it and/or modify
 
8
// it under the terms of the GNU General Public License as published by
 
9
// the Free Software Foundation; either version 2 of the License, or
 
10
// (at your option) any later version.
 
11
//
 
12
// TCM is distributed in the hope that it will be useful,
 
13
// but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
15
// GNU General Public License for more details.
 
16
//
 
17
// You should have received a copy of the GNU General Public License
 
18
// along with TCM; if not, write to the Free Software
 
19
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
 
20
// 02111-1307, USA.
 
21
//-----------------------------------------------------------------------------
 
22
#ifndef _BUFFER_H
 
23
#define _BUFFER_H
 
24
 
 
25
#include "llist.h"
 
26
#include "command.h"
 
27
class Subjects;
 
28
class Shapes;
 
29
 
 
30
/// shape and subject cut-paste buffer class.
 
31
class Buffer {
 
32
/*@Doc: {\large {\bf scope:} diagram} */
 
33
public:
 
34
        ///
 
35
        Buffer();
 
36
        ///
 
37
        ~Buffer();
 
38
 
 
39
        /// Copy lists of subjects and shapes and hold them in the buffer.
 
40
        void Put(Subjects *, Shapes *); 
 
41
 
 
42
        /// Copy subjects in the buffer and return them in a list.
 
43
        Subjects *GetSubjectsCopy(); 
 
44
 
 
45
        /// Copy shapes in the buffer and return them in a list.
 
46
        Shapes *GetShapesCopy();
 
47
 
 
48
        ///
 
49
        Subjects *GetSubjects() const {return subjects;}
 
50
        ///
 
51
        Shapes *GetShapes() const {return shapes;}
 
52
 
 
53
        /// Returns if buffer is empty.
 
54
        bool IsEmpty() const { return subjects == 0;} 
 
55
 
 
56
        /// Which command uses this buffer.
 
57
        void SetUser(Command *c) {user = c;}
 
58
        ///
 
59
        Command *GetUser() {return user;}
 
60
private:
 
61
        ///
 
62
        Subjects *subjects;
 
63
        ///
 
64
        Shapes *shapes;
 
65
        ///
 
66
        Command *user;
 
67
};
 
68
#endif