Merge remote-tracking branch 'origin/API9' into tizen_6.5
[platform/core/csapi/tizenfx.git] / src / Tizen.Applications.Common / Tizen.Applications.CoreBackend / ICoreBackend.cs
1 /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the License);
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an AS IS BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 using System;
18
19 namespace Tizen.Applications.CoreBackend
20 {
21     /// <summary>
22     /// An interface that represents the backend lifecycles.
23     /// </summary>
24     /// <since_tizen> 3 </since_tizen>
25     public interface ICoreBackend : IDisposable
26     {
27         /// <summary>
28         /// Adds an event handler.
29         /// </summary>
30         /// <param name="evType">The type of event.</param>
31         /// <param name="handler">The handler method without arguments.</param>
32         /// <since_tizen> 3 </since_tizen>
33         void AddEventHandler(EventType evType, Action handler);
34
35         /// <summary>
36         /// Adds an event handler.
37         /// </summary>
38         /// <typeparam name="TEventArgs">The EventArgs type used in arguments of the handler method.</typeparam>
39         /// <param name="evType">The type of event.</param>
40         /// <param name="handler">The handler method with a TEventArgs type argument.</param>
41         /// <since_tizen> 3 </since_tizen>
42         void AddEventHandler<TEventArgs>(EventType evType, Action<TEventArgs> handler) where TEventArgs : EventArgs;
43
44         /// <summary>
45         /// Runs the mainloop of the backend.
46         /// </summary>
47         /// <param name="args"></param>
48         /// <since_tizen> 3 </since_tizen>
49         void Run(string[] args);
50
51         /// <summary>
52         /// Exits the mainloop of the backend.
53         /// </summary>
54         /// <since_tizen> 3 </since_tizen>
55         void Exit();
56     }
57 }