caesar_cipher.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. #include <furi.h>
  2. #include <input/input.h>
  3. #include <stdlib.h>
  4. #include <gui/gui.h>
  5. #include <gui/view.h>
  6. #include <gui/view_dispatcher.h>
  7. #include <gui/modules/text_input.h>
  8. #include <gui/modules/text_box.h>
  9. #define TEXT_BUFFER_SIZE 256
  10. typedef enum {
  11. EventTypeTick,
  12. EventTypeKey,
  13. } EventType;
  14. typedef struct {
  15. EventType type;
  16. InputEvent input;
  17. } PluginEvent;
  18. typedef struct {
  19. ViewDispatcher* view_dispatcher;
  20. TextInput* text_input;
  21. TextBox* text_box;
  22. char input[TEXT_BUFFER_SIZE];
  23. char output[(TEXT_BUFFER_SIZE*26) + (26)]; // linebreaks
  24. } CaesarState;
  25. static void string_to_uppercase(char* input) {
  26. int i;
  27. for (i=0; input[i] != '\0'; i++) {
  28. if (input[i] >= 'a' && input[i] <= 'z') {
  29. input[i] = input[i] - 32;
  30. } else {
  31. input[i] = input[i];
  32. }
  33. }
  34. }
  35. static void build_output(char* input, char* output) {
  36. int out = 0;
  37. for ( int rot = 1; rot < 26; rot++) {
  38. int in;
  39. for(in = 0; input[in] != '\0'; in++){
  40. if (input[in] >= 'A' && input[in] <= 'Z') {
  41. output[out] = 65 + ( ((input[in] - 65) + rot ) % 26);
  42. } else {
  43. output[out] = input[in];
  44. }
  45. out++;
  46. }
  47. output[out]= '\n';
  48. out++;
  49. }
  50. output[out]='\0';
  51. }
  52. static void text_input_callback(void* ctx) {
  53. CaesarState* caesar_state = acquire_mutex((ValueMutex*)ctx, 25);
  54. FURI_LOG_D("caesar_cipher", "Input text: %s", caesar_state->input);
  55. // this is where we build the output.
  56. string_to_uppercase(caesar_state->input);
  57. FURI_LOG_D("caesar_cipher", "Upper text: %s", caesar_state->input);
  58. build_output(caesar_state->input, caesar_state->output);
  59. text_box_set_text(caesar_state->text_box, caesar_state->output);
  60. view_dispatcher_switch_to_view(caesar_state->view_dispatcher, 1);
  61. release_mutex((ValueMutex*)ctx, caesar_state);
  62. }
  63. static bool back_event_callback(void* ctx) {
  64. const CaesarState* caesar_state = acquire_mutex((ValueMutex*)ctx, 25);
  65. view_dispatcher_stop(caesar_state->view_dispatcher);
  66. release_mutex((ValueMutex*)ctx, caesar_state);
  67. return true;
  68. }
  69. static void caesar_cipher_state_init(CaesarState* const caesar_state) {
  70. caesar_state->view_dispatcher = view_dispatcher_alloc();
  71. caesar_state->text_input = text_input_alloc();
  72. caesar_state->text_box = text_box_alloc();
  73. text_box_set_font(caesar_state->text_box, TextBoxFontText);
  74. }
  75. static void caesar_cipher_state_free(CaesarState* const caesar_state) {
  76. text_input_free(caesar_state->text_input);
  77. text_box_free(caesar_state->text_box);
  78. view_dispatcher_remove_view(caesar_state->view_dispatcher, 0);
  79. view_dispatcher_remove_view(caesar_state->view_dispatcher, 1);
  80. view_dispatcher_free(caesar_state->view_dispatcher);
  81. free(caesar_state);
  82. }
  83. int32_t caesar_cipher_app() {
  84. CaesarState* caesar_state = malloc(sizeof(CaesarState));
  85. FURI_LOG_D("caesar_cipher", "Running caesar_cipher_state_init");
  86. caesar_cipher_state_init(caesar_state);
  87. ValueMutex state_mutex;
  88. if(!init_mutex(&state_mutex, caesar_state, sizeof(CaesarState))) {
  89. FURI_LOG_E("caesar_cipher", "cannot create mutex\r\n");
  90. free(caesar_state);
  91. return 255;
  92. }
  93. FURI_LOG_D("caesar_cipher", "Assigning text input callback");
  94. text_input_set_result_callback(
  95. caesar_state->text_input,
  96. text_input_callback,
  97. &state_mutex,
  98. caesar_state->input,
  99. TEXT_BUFFER_SIZE,
  100. //clear default text
  101. true
  102. );
  103. text_input_set_header_text(caesar_state->text_input, "Input");
  104. // Open GUI and register view_port
  105. Gui* gui = furi_record_open("gui");
  106. //gui_add_view_port(gui, view_port, GuiLayerFullscreen);
  107. FURI_LOG_D("caesar_cipher", "Enabling view dispatcher queue");
  108. view_dispatcher_enable_queue(caesar_state->view_dispatcher);
  109. FURI_LOG_D("caesar_cipher", "Adding text input view to dispatcher");
  110. view_dispatcher_add_view(caesar_state->view_dispatcher, 0, text_input_get_view(caesar_state->text_input));
  111. view_dispatcher_add_view(caesar_state->view_dispatcher, 1, text_box_get_view(caesar_state->text_box));
  112. FURI_LOG_D("caesar_cipher", "Attaching view dispatcher to GUI");
  113. view_dispatcher_attach_to_gui(caesar_state->view_dispatcher, gui, ViewDispatcherTypeFullscreen);
  114. FURI_LOG_D("ceasar_cipher", "starting view dispatcher");
  115. view_dispatcher_set_navigation_event_callback(caesar_state->view_dispatcher, back_event_callback);
  116. view_dispatcher_set_event_callback_context(caesar_state->view_dispatcher, &state_mutex);
  117. view_dispatcher_switch_to_view(caesar_state->view_dispatcher, 0);
  118. view_dispatcher_run(caesar_state->view_dispatcher);
  119. furi_record_close("gui");
  120. delete_mutex(&state_mutex);
  121. caesar_cipher_state_free(caesar_state);
  122. return 0;
  123. }