/** * \file pros/misc.hpp * * Contains prototypes for miscellaneous functions pertaining to the controller, * battery, and competition control. * * Visit https://pros.cs.purdue.edu/v5/tutorials/topical/controller.html to * learn more. * * This file should not be modified by users, since it gets replaced whenever * a kernel upgrade occurs. * * \copyright Copyright (c) 2017-2023, Purdue University ACM SIGBots. * All rights reservered. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #ifndef _PROS_MISC_HPP_ #define _PROS_MISC_HPP_ #include "pros/misc.h" #include #include namespace pros { class Controller { public: /** * Creates a controller object for the given controller id. * * \param id * The ID of the controller (e.g. the master or partner controller). * Must be one of CONTROLLER_MASTER or CONTROLLER_PARTNER */ Controller(controller_id_e_t id); /** * Checks if the controller is connected. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \return 1 if the controller is connected, 0 otherwise */ std::int32_t is_connected(void); /** * Gets the value of an analog channel (joystick) on a controller. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param channel * The analog channel to get. * Must be one of ANALOG_LEFT_X, ANALOG_LEFT_Y, ANALOG_RIGHT_X, * ANALOG_RIGHT_Y * * \return The current reading of the analog channel: [-127, 127]. * If the controller was not connected, then 0 is returned */ std::int32_t get_analog(controller_analog_e_t channel); /** * Gets the battery capacity of the controller. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \return The controller's battery capacity */ std::int32_t get_battery_capacity(void); /** * Gets the battery level of the controller. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \return The controller's battery level */ std::int32_t get_battery_level(void); /** * Checks if a digital channel (button) on the controller is currently * pressed. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param button * The button to read. Must be one of * DIGITAL_{RIGHT,DOWN,LEFT,UP,A,B,Y,X,R1,R2,L1,L2} * * \return 1 if the button on the controller is pressed. * If the controller was not connected, then 0 is returned */ std::int32_t get_digital(controller_digital_e_t button); /** * Returns a rising-edge case for a controller button press. * * This function is not thread-safe. * Multiple tasks polling a single button may return different results under * the same circumstances, so only one task should call this function for any * given button. E.g., Task A calls this function for buttons 1 and 2. * Task B may call this function for button 3, but should not for buttons * 1 or 2. A typical use-case for this function is to call inside opcontrol * to detect new button presses, and not in any other tasks. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param button * The button to read. Must be one of * DIGITAL_{RIGHT,DOWN,LEFT,UP,A,B,Y,X,R1,R2,L1,L2} * * \return 1 if the button on the controller is pressed and had not been * pressed the last time this function was called, 0 otherwise. */ std::int32_t get_digital_new_press(controller_digital_e_t button); #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wunused-function" template T convert_args(T arg) { return arg; } const char* convert_args(const std::string& arg) { return arg.c_str(); } #pragma GCC diagnostic pop /** * Sets text to the controller LCD screen. * * \note Controller text setting is currently in beta, so continuous, fast * updates will not work well. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param line * The line number at which the text will be displayed [0-2] * \param col * The column number at which the text will be displayed [0-14] * \param fmt * The format string to print to the controller * \param ... * The argument list for the format string * * \return 1 if the operation was successful or PROS_ERR if the operation * failed, setting errno. */ template std::int32_t print(std::uint8_t line, std::uint8_t col, const char* fmt, Params... args) { return pros::c::controller_print(_id, line, col, fmt, convert_args(args)...); } /** * Sets text to the controller LCD screen. * * \note Controller text setting is currently in beta, so continuous, fast * updates will not work well. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param line * The line number at which the text will be displayed [0-2] * \param col * The column number at which the text will be displayed [0-14] * \param str * The pre-formatted string to print to the controller * * \return 1 if the operation was successful or PROS_ERR if the operation * failed, setting errno. */ std::int32_t set_text(std::uint8_t line, std::uint8_t col, const char* str); std::int32_t set_text(std::uint8_t line, std::uint8_t col, const std::string& str); /** * Clears an individual line of the controller screen. * * \note Controller text setting is currently in beta, so continuous, fast * updates will not work well. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param line * The line number to clear [0-2] * * \return 1 if the operation was successful or PROS_ERR if the operation * failed, setting errno. */ std::int32_t clear_line(std::uint8_t line); /** * Rumble the controller. * * \note Controller rumble activation is currently in beta, so continuous, fast * updates will not work well. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \param rumble_pattern * A string consisting of the characters '.', '-', and ' ', where dots * are short rumbles, dashes are long rumbles, and spaces are pauses. * Maximum supported length is 8 characters. * * \return 1 if the operation was successful or PROS_ERR if the operation * failed, setting errno. */ std::int32_t rumble(const char* rumble_pattern); /** * Clears all of the lines on the controller screen. * * \note Controller text setting is currently in beta, so continuous, fast * updates will not work well. On vexOS version 1.0.0 this function will * block for 110ms. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the controller * port. * * \return 1 if the operation was successful or PROS_ERR if the operation * failed, setting errno. */ std::int32_t clear(void); private: controller_id_e_t _id; }; namespace battery { /** * Gets the current voltage of the battery, as reported by VEXos. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the battery port. * * \return The current voltage of the battery */ double get_capacity(void); /** * Gets the current current of the battery in milliamps, as reported by VEXos. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the battery port. * * \return The current current of the battery */ int32_t get_current(void); /** * Gets the current temperature of the battery, as reported by VEXos. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the battery port. * * \return The current temperature of the battery */ double get_temperature(void); /** * Gets the current capacity of the battery in millivolts, as reported by VEXos. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the battery port. * * \return The current capacity of the battery */ int32_t get_voltage(void); } // namespace battery namespace competition { /** * Get the current status of the competition control. * * \return The competition control status as a mask of bits with * COMPETITION_{ENABLED,AUTONOMOUS,CONNECTED}. */ std::uint8_t get_status(void); std::uint8_t is_autonomous(void); std::uint8_t is_connected(void); std::uint8_t is_disabled(void); } // namespace competition namespace usd { /** * Checks if the SD card is installed. * * \return 1 if the SD card is installed, 0 otherwise */ std::int32_t is_installed(void); } // namespace usd } // namespace pros #endif // _PROS_MISC_HPP_