RDK Documentation (Open Sourced RDK Components)
dsserverlogger.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 "dsserverlogger.h"
30 #include <stdarg.h>
31 
32 #define MAX_LOG_BUFF 500
33 
34 DSServer_LogCb logCb = NULL;
35 
36 void DSServer_RegisterForLog(DSServer_LogCb cb)
37 {
38  logCb = cb;
39 }
40 
41 int ds_server_log(int priority,const char *format, ...)
42 {
43  char tmp_buff[MAX_LOG_BUFF];
44  va_list args;
45  va_start(args, format);
46  vsnprintf(tmp_buff,MAX_LOG_BUFF-1,format, args);
47  va_end(args);
48  if(logCb != NULL)
49  {
50  logCb(priority,tmp_buff);
51  }
52  else
53  {
54  return printf(tmp_buff);
55  }
56  return 0;
57 }
58 
59 
60 
61 
62 /** @} */
63 /** @} */