• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2023 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef INPUTMETHOD_IMF_INPUT__CLIENT_INFO_H
17 #define INPUTMETHOD_IMF_INPUT__CLIENT_INFO_H
18 
19 #include "event_status_manager.h"
20 #include "i_input_client.h"
21 #include "i_input_data_channel.h"
22 #include "input_attribute.h"
23 #include "input_death_recipient.h"
24 
25 namespace OHOS {
26 namespace MiscServices {
27 enum class UpdateFlag : uint32_t { EVENTFLAG = 0, ISSHOWKEYBOARD, BINDIMETYPE, STATE, TEXT_CONFIG };
28 enum class ImeType : int32_t { IME = 0, PROXY_IME, NONE };
29 enum class ClientState : uint32_t { INACTIVE = 0, ACTIVE };
30 struct InputClientInfo {
31     pid_t pid{ -1 };                                       // process id
32     pid_t uid{ -1 };                                       // uid
33     int32_t userID{ 0 };                                   // user id of input client
34     bool isShowKeyboard{ false };                          // soft keyboard status
35     ImeType bindImeType{ ImeType::NONE };                  // type of the ime client bind
36     TextTotalConfig config = {};                           // text config
37     uint32_t eventFlag{ EventStatusManager::NO_EVENT_ON }; // the flag of the all listen event
38     InputAttribute attribute;                              // the input client attribute
39     sptr<IInputClient> client{ nullptr };       // the remote object handler for service to callback input client
40     sptr<IInputDataChannel> channel{ nullptr }; // the remote object handler for ime to callback input client
41     sptr<InputDeathRecipient> deathRecipient{ nullptr }; // death recipient of client
42     ClientState state{ ClientState::INACTIVE };          // the state of input client
43     bool isNotifyInputStart { true };
44 };
45 } // namespace MiscServices
46 } // namespace OHOS
47 
48 #endif //INPUTMETHOD_IMF_INPUT_CLIENT_INFO_H
49