xref: /aosp_15_r20/system/chre/host/common/log.cc (revision 84e339476a462649f82315436d70fd732297a399)
1 /*
2  * Copyright (C) 2023 The Android Open Source Project
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 #include <cstdio>
18 
19 #include "chre_host/log.h"
20 
21 namespace android::chre {
22 
outputHostLog(int priority,FILE * stream,const char * format,const char * func,unsigned int line,...)23 void outputHostLog(int priority, FILE *stream, const char *format,
24                    const char *func, unsigned int line, ...) {
25   va_list args;
26   va_start(args, line);
27   LOG_PRI_VA(priority, LOG_TAG, format, args);
28   va_end(args);
29   va_start(args, line);
30   fprintf(stream, "%s:%d: ", func, line);
31   vfprintf(stream, format, args);
32   fprintf(stream, "\n");
33   fflush(stream);  // flush the buffer to print out the log immediately
34   va_end(args);
35 }
36 
37 }  // namespace android::chre