Arcane  4.1.12.0
Developer documentation
Loading...
Searching...
No Matches
IDataSynchronizeImplementation.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2026 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* IDataSynchronizeImplementation.h (C) 2000-2023 */
9/* */
10/* Interface for the implementation of variable synchronization. */
11/*---------------------------------------------------------------------------*/
12/*---------------------------------------------------------------------------*/
13#ifndef ARCANE_IMPL_IDATASYNCHRONIZEIMPLEMENTATION_H
14#define ARCANE_IMPL_IDATASYNCHRONIZEIMPLEMENTATION_H
15/*---------------------------------------------------------------------------*/
16/*---------------------------------------------------------------------------*/
17
18#include "arcane/utils/Ref.h"
19
20/*---------------------------------------------------------------------------*/
21/*---------------------------------------------------------------------------*/
22
23namespace Arcane
24{
26class IParallelMng;
28
29/*---------------------------------------------------------------------------*/
30/*---------------------------------------------------------------------------*/
31
35
36using IGenericVariableSynchronizerDispatcher
37ARCANE_DEPRECATED_REASON("Use 'IDataSynchronizeImplementation' instead") = IDataSynchronizeImplementation;
38
39using IGenericVariableSynchronizerDispatcherFactory
40ARCANE_DEPRECATED_REASON("Use 'IDataSynchronizeImplementationFactory' instead") = IDataSynchronizeImplementationFactory;
41
42using AbstractGenericVariableSynchronizerDispatcher
43ARCANE_DEPRECATED_REASON("Use 'AbstractDataSynchronizeImplementation' instead") = AbstractDataSynchronizeImplementation;
44
45using ItemGroupSynchronizeInfo
46ARCANE_DEPRECATED_REASON("Use 'DataSynchronizeInfo' instead") = DataSynchronizeInfo;
47
48/*---------------------------------------------------------------------------*/
49/*---------------------------------------------------------------------------*/
50
54class ARCANE_IMPL_EXPORT IDataSynchronizeImplementation
55{
56 public:
57
58 virtual ~IDataSynchronizeImplementation() = default;
59
60 public:
61
62 virtual void setDataSynchronizeInfo(DataSynchronizeInfo* sync_info) = 0;
63 virtual void compute() = 0;
64 virtual void beginSynchronize(IDataSynchronizeBuffer* buf) = 0;
65 virtual void endSynchronize(IDataSynchronizeBuffer* buf) = 0;
66};
67
68/*---------------------------------------------------------------------------*/
69/*---------------------------------------------------------------------------*/
70
75{
76 public:
77
79
80 public:
81
82 virtual Ref<IDataSynchronizeImplementation> createInstance() = 0;
83};
84
85/*---------------------------------------------------------------------------*/
86/*---------------------------------------------------------------------------*/
87
88/*
89 * \brief Abstract base class for generic implementations.
90 *
91 * It allows retaining information about the group to be synchronized.
92 */
95{
96 public:
97
98 void setDataSynchronizeInfo(DataSynchronizeInfo* sync_info) final { m_sync_info = sync_info; }
99
100 protected:
101
102 DataSynchronizeInfo* _syncInfo() const { return m_sync_info; }
103
104 private:
105
106 DataSynchronizeInfo* m_sync_info = nullptr;
107};
108
109/*---------------------------------------------------------------------------*/
110/*---------------------------------------------------------------------------*/
111
112} // namespace Arcane
113
114/*---------------------------------------------------------------------------*/
115/*---------------------------------------------------------------------------*/
116
117#endif
Information necessary to synchronize entities across a group.
Generic buffer for data synchronization.
Interface for a generic dispatcher factory.
Interface of the parallelism manager for a subdomain.
Reference to an instance.
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --