RDK Documentation (Open Sourced RDK Components)
dsclientlogger.c
1 /*
2  * If not stated otherwise in this file or this component's Licenses.txt file the
3  * following copyright and licenses apply:
4  *
5  * Copyright 2016 RDK Management
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18 */
19 
20 
21 /**
22 * @defgroup devicesettings
23 * @{
24 * @defgroup rpc
25 * @{
26 **/
27 
28 
29 #include <stdarg.h>
30 #include "dsclientlogger.h"
31 #define MAX_LOG_BUFF 500
32 
33 DSClient_LogCb logCb = NULL;
34 
35 void DSClient_RegisterForLog(DSClient_LogCb cb)
36 {
37  logCb = cb;
38 }
39 
40 int ds_client_log(int priority,const char *format, ...)
41 {
42  char tmp_buff[MAX_LOG_BUFF];
43  va_list args;
44  va_start(args, format);
45  vsnprintf(tmp_buff,MAX_LOG_BUFF-1,format, args);
46  va_end(args);
47  if(logCb != NULL)
48  {
49  logCb(priority,tmp_buff);
50  }
51  else
52  {
53  return printf(tmp_buff);
54  }
55  return 0;
56 }
57 
58 
59 
60 
61 /** @} */
62 /** @} */