|  | /* | 
|  | * Copyright (C) 2005-2017 The Android Open Source Project | 
|  | * | 
|  | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | * you may not use this file except in compliance with the License. | 
|  | * You may obtain a copy of the License at | 
|  | * | 
|  | *      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, software | 
|  | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | * See the License for the specific language governing permissions and | 
|  | * limitations under the License. | 
|  | */ | 
|  |  | 
|  | #pragma once | 
|  |  | 
|  | #include <stdio.h> | 
|  |  | 
|  | /* | 
|  | * The opaque context | 
|  | */ | 
|  | typedef struct android_logcat_context_internal* android_logcat_context; | 
|  |  | 
|  | /* Creates a context associated with this logcat instance | 
|  | * | 
|  | * Returns a pointer to the context, or a NULL on error. | 
|  | */ | 
|  | android_logcat_context create_android_logcat(); | 
|  |  | 
|  | /* Collects and outputs the logcat data to output and error file descriptors | 
|  | * | 
|  | * Will block, performed in-thread and in-process | 
|  | * | 
|  | * The output file descriptor variable, if greater than or equal to 0, is | 
|  | * where the output (ie: stdout) will be sent. The file descriptor is closed | 
|  | * on android_logcat_destroy which terminates the instance, or when an -f flag | 
|  | * (output redirect to a file) is present in the command.  The error file | 
|  | * descriptor variable, if greater than or equal to 0, is where the error | 
|  | * stream (ie: stderr) will be sent, also closed on android_logcat_destroy. | 
|  | * The error file descriptor can be set to equal to the output file descriptor, | 
|  | * which will mix output and error stream content, and will defer closure of | 
|  | * the file descriptor on -f flag redirection.  Negative values for the file | 
|  | * descriptors will use stdout and stderr FILE references respectively | 
|  | * internally, and will not close the references as noted above. | 
|  | * | 
|  | * Return value is 0 for success, non-zero for errors. | 
|  | */ | 
|  | int android_logcat_run_command(android_logcat_context ctx, int output, int error, int argc, | 
|  | char* const* argv, char* const* envp); | 
|  |  | 
|  | /* Finished with context | 
|  | * | 
|  | * Kill the command thread ASAP (if any), and free up all associated resources. | 
|  | * | 
|  | * Return value is the result of the android_logcat_run_command, or | 
|  | * non-zero for any errors. | 
|  | */ | 
|  | int android_logcat_destroy(android_logcat_context* ctx); |