|  | /* | 
|  | * Copyright (C) 2015 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. | 
|  | */ | 
|  |  | 
|  | #ifndef _ADB_UTILS_H_ | 
|  | #define _ADB_UTILS_H_ | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include <android-base/macros.h> | 
|  | #include <android-base/unique_fd.h> | 
|  |  | 
|  | void close_stdin(); | 
|  |  | 
|  | bool getcwd(std::string* cwd); | 
|  | bool directory_exists(const std::string& path); | 
|  |  | 
|  | // Like the regular basename and dirname, but thread-safe on all | 
|  | // platforms and capable of correctly handling exotic Windows paths. | 
|  | std::string adb_basename(const std::string& path); | 
|  | std::string adb_dirname(const std::string& path); | 
|  |  | 
|  | // Return the user's home directory. | 
|  | // |check_env_first| - if true, on Windows check the ANDROID_SDK_HOME | 
|  | // environment variable before trying the WinAPI call (useful when looking for | 
|  | // the .android directory) | 
|  | std::string adb_get_homedir_path(bool check_env_first); | 
|  |  | 
|  | bool mkdirs(const std::string& path); | 
|  |  | 
|  | std::string escape_arg(const std::string& s); | 
|  |  | 
|  | std::string dump_hex(const void* ptr, size_t byte_count); | 
|  |  | 
|  | std::string perror_str(const char* msg); | 
|  |  | 
|  | bool set_file_block_mode(int fd, bool block); | 
|  |  | 
|  | extern int adb_close(int fd); | 
|  |  | 
|  | // Given forward/reverse targets, returns true if they look sane. If an error is found, fills | 
|  | // |error| and returns false. | 
|  | // Currently this only checks "tcp:" targets. Additional checking could be added for other targets | 
|  | // if needed. | 
|  | bool forward_targets_are_valid(const std::string& source, const std::string& dest, | 
|  | std::string* error); | 
|  |  | 
|  | // Helper to automatically close an FD when it goes out of scope. | 
|  | struct AdbCloser { | 
|  | static void Close(int fd) { | 
|  | adb_close(fd); | 
|  | } | 
|  | }; | 
|  |  | 
|  | using unique_fd = android::base::unique_fd_impl<AdbCloser>; | 
|  |  | 
|  | #endif |