Contiki 2.6

menu.h

Go to the documentation of this file.
00001 /*
00002  *  Copyright (c) 2008  Swedish Institute of Computer Science
00003  *  All rights reserved.
00004  *
00005  *  Redistribution and use in source and binary forms, with or without
00006  *  modification, are permitted provided that the following conditions are met:
00007  *
00008  *  * Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  *  * Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in
00012  *    the documentation and/or other materials provided with the
00013  *    distribution.
00014  *  * Neither the name of the copyright holders nor the names of
00015  *    contributors may be used to endorse or promote products derived
00016  *    from this software without specific prior written permission.
00017  *
00018  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00019  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00020  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00021  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00022  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00023  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00024  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00025  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00026  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00027  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00028  * POSSIBILITY OF SUCH DAMAGE.
00029  */
00030 /**
00031  * \file
00032  *
00033  * \brief
00034  *      This file operates the menu flow chart described in the readme
00035  *      notes. This will create the proper commands needed to control the 1284p.
00036  *
00037  * \author
00038  *      Mike Vidales mavida404@gmail.com
00039  *
00040  */
00041 
00042 #ifndef MENU_H
00043 #define MENU_H
00044 
00045 #include <avr/pgmspace.h>
00046 #include <stdbool.h>
00047 
00048 /** \brief Pointer to function, used to dispatch a menu-driven function.  See tmenu_item */
00049 typedef void (*tmenufunc)(uint8_t *);
00050 
00051 /** \brief This structure defines the joystick operation within the menu_items[]. */
00052 typedef struct {
00053     const char * PROGMEM text;  /**< Menu text to display. */
00054     uint8_t left;               /**< Contains next menu position for left. */
00055     uint8_t right;              /**< Contains next menu position for right. */
00056     uint8_t up;                 /**< Contains next menu position for up. */
00057     uint8_t down;               /**< Contains next menu position for down. */
00058     uint8_t *state;             /**< State variable used as argument for menu enter function. */
00059     tmenufunc enter_func;       /**< Pointer to function to call when enter button is pressed. */
00060 } tmenu_item;
00061 
00062 extern uint8_t ping_response;
00063 extern bool ping_mode;
00064 extern bool timeout_flag;
00065 extern bool temp_flag;
00066 extern bool auto_temp;
00067 extern const PROGMEM tmenu_item menu_items[];
00068 char top_menu_text[20];
00069 
00070 #define EEPROM_DEBUG_ADDR   0
00071 
00072 void menu_run_sleep(uint8_t *val);
00073 void menu_run_doze(uint8_t *val);
00074 void dectoascii(uint8_t val, char *str);
00075 uint8_t *signed_dectoascii(int16_t n, uint8_t *str);
00076 void eeprom_init(void);
00077 void menu_ping_request(uint8_t * val);
00078 uint8_t menu_send_ping(void);
00079 void menu_stop_ping(void);
00080 void menu_debug_mode(uint8_t *val);
00081 void menu_read_temp(uint8_t *val);
00082 void menu_display_temp(void);
00083 void menu_clear_temp(void);
00084 void menu_prepare_temp(uint8_t *val);
00085 void menu_stop_temp(void);
00086 void menu_send_temp(void);
00087 
00088 #endif /* MENU_H */