source: src/Jobs/JobMarket/FragmentResult.cpp@ d07be9

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since d07be9 was 9eb71b3, checked in by Frederik Heber <frederik.heber@…>, 8 years ago

Commented out MemDebug include and Memory::ignore.

  • MemDebug clashes with various allocation operators that use a specific placement in memory. It is so far not possible to wrap new/delete fully. Hence, we stop this effort which so far has forced us to put ever more includes (with clashes) into MemDebug and thereby bloat compilation time.
  • MemDebug does not add that much usefulness which is not also provided by valgrind.
  • Property mode set to 100644
File size: 2.9 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2014 Frederik Heber. All rights reserved.
5 *
6 *
7 * This file is part of MoleCuilder.
8 *
9 * MoleCuilder is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * MoleCuilder is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
21 */
22
23/*
24 * FragmentResult.cpp
25 *
26 * Originally taken from my JobMarket project at 1.1.4.
27 *
28 * Created on: Oct 19, 2011
29 * Author: heber
30 */
31
32// include config.h
33#ifdef HAVE_CONFIG_H
34#include <config.h>
35#endif
36
37//#include "CodePatterns/MemDebug.hpp"
38
39#ifdef HAVE_JOBMARKET
40#include "JobMarket/Results/FragmentResult.hpp"
41#else
42#include "Jobs/JobMarket/FragmentResult.hpp"
43#endif
44
45/** Private default Constructor of class FragmentResult.
46 *
47 * This cstor is for serialization of this class inside a vector
48 * only. Without it, we would not need it.
49 */
50FragmentResult::FragmentResult() :
51 JobId(JobId::NoJob),
52 result(std::string("NoJob")),
53 exitflag(0),
54 time_Work(0.)
55{}
56
57/** Constructor of class FragmentResult.
58 *
59 * \param _id id of FragmntJob associated to this FragmentResult.
60 */
61FragmentResult::FragmentResult(const JobId_t _id) :
62 JobId(_id),
63 result(std::string("Nothing")),
64 exitflag(0),
65 time_Work(0.)
66{}
67
68/** Constructor of class FragmentResult.
69 */
70FragmentResult::FragmentResult(const JobId_t _id, const std::string &_result) :
71 JobId(_id),
72 result(_result),
73 exitflag(0),
74 time_Work(0.)
75{}
76
77/** Copy constructor of class FragmentResult.
78 *
79 */
80FragmentResult::FragmentResult(const FragmentResult &other) :
81 JobId(other.getId()),
82 result(other.result),
83 exitflag(other.exitflag),
84 time_Work(other.time_Work)
85{}
86
87/** Destructor of class FragmentResult.
88 *
89 */
90FragmentResult::~FragmentResult()
91{}
92
93/** Equality operator: Equal if both JobIds are the same
94 *
95 * \param other instance to check against
96 * \return true - both JobIds are the same, false - JobIds are not the same.
97 */
98bool FragmentResult::operator==(const FragmentResult &other) const
99{
100 return getId() == other.getId();
101}
102
103/** Assigment operator.
104 *
105 * \note We can't use default assigment because of const member FragmentResult::JobId.
106 *
107 * \param other instance to make equal to
108 */
109FragmentResult& FragmentResult::operator=(const FragmentResult &other)
110{
111 /// check self-assignment
112 if (this != &other) {
113 setId(other.getId());
114 result = other.result;
115 exitflag = other.exitflag;
116 time_Work = other.time_Work;
117 }
118 return *this;
119}
Note: See TracBrowser for help on using the repository browser.