1*77b80299SAndroid Build Coastguard Worker /* 2*77b80299SAndroid Build Coastguard Worker * Copyright (C) 2008 The Android Open Source Project 3*77b80299SAndroid Build Coastguard Worker * 4*77b80299SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*77b80299SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*77b80299SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*77b80299SAndroid Build Coastguard Worker * 8*77b80299SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*77b80299SAndroid Build Coastguard Worker * 10*77b80299SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*77b80299SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*77b80299SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*77b80299SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*77b80299SAndroid Build Coastguard Worker * limitations under the License. 15*77b80299SAndroid Build Coastguard Worker */ 16*77b80299SAndroid Build Coastguard Worker 17*77b80299SAndroid Build Coastguard Worker // All static variables go here, to control initialization and 18*77b80299SAndroid Build Coastguard Worker // destruction order in the library. 19*77b80299SAndroid Build Coastguard Worker 20*77b80299SAndroid Build Coastguard Worker #include <hwbinder/Static.h> 21*77b80299SAndroid Build Coastguard Worker 22*77b80299SAndroid Build Coastguard Worker #include "BufferedTextOutput.h" 23*77b80299SAndroid Build Coastguard Worker 24*77b80299SAndroid Build Coastguard Worker #include <hwbinder/IPCThreadState.h> 25*77b80299SAndroid Build Coastguard Worker #include <utils/Log.h> 26*77b80299SAndroid Build Coastguard Worker 27*77b80299SAndroid Build Coastguard Worker namespace android { 28*77b80299SAndroid Build Coastguard Worker namespace hardware { 29*77b80299SAndroid Build Coastguard Worker 30*77b80299SAndroid Build Coastguard Worker // ------------ Text output streams 31*77b80299SAndroid Build Coastguard Worker 32*77b80299SAndroid Build Coastguard Worker Vector<int32_t> gTextBuffers; 33*77b80299SAndroid Build Coastguard Worker 34*77b80299SAndroid Build Coastguard Worker class LogTextOutput : public BufferedTextOutput 35*77b80299SAndroid Build Coastguard Worker { 36*77b80299SAndroid Build Coastguard Worker public: LogTextOutput()37*77b80299SAndroid Build Coastguard Worker LogTextOutput() : BufferedTextOutput(MULTITHREADED) { } ~LogTextOutput()38*77b80299SAndroid Build Coastguard Worker virtual ~LogTextOutput() { }; 39*77b80299SAndroid Build Coastguard Worker 40*77b80299SAndroid Build Coastguard Worker protected: writeLines(const struct iovec & vec,size_t N)41*77b80299SAndroid Build Coastguard Worker virtual status_t writeLines(const struct iovec& vec, size_t N) 42*77b80299SAndroid Build Coastguard Worker { 43*77b80299SAndroid Build Coastguard Worker //android_writevLog(&vec, N); <-- this is now a no-op 44*77b80299SAndroid Build Coastguard Worker if (N != 1) ALOGI("WARNING: writeLines N=%zu\n", N); 45*77b80299SAndroid Build Coastguard Worker ALOGI("%.*s", (int)vec.iov_len, (const char*) vec.iov_base); 46*77b80299SAndroid Build Coastguard Worker return NO_ERROR; 47*77b80299SAndroid Build Coastguard Worker } 48*77b80299SAndroid Build Coastguard Worker }; 49*77b80299SAndroid Build Coastguard Worker 50*77b80299SAndroid Build Coastguard Worker static LogTextOutput gLogTextOutput; 51*77b80299SAndroid Build Coastguard Worker TextOutput& alog(gLogTextOutput); 52*77b80299SAndroid Build Coastguard Worker 53*77b80299SAndroid Build Coastguard Worker } // namespace hardware 54*77b80299SAndroid Build Coastguard Worker } // namespace android 55