caesar_cipher.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  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. //char upper[TEXT_BUFFER_SIZE];
  57. string_to_uppercase(caesar_state->input);
  58. FURI_LOG_D("caesar_cipher", "Upper text: %s", caesar_state->input);
  59. build_output(caesar_state->input, caesar_state->output);
  60. text_box_set_text(caesar_state->text_box, caesar_state->output);
  61. view_dispatcher_switch_to_view(caesar_state->view_dispatcher, 1);
  62. release_mutex((ValueMutex*)ctx, caesar_state);
  63. }
  64. static bool back_event_callback(void* ctx) {
  65. const CaesarState* caesar_state = acquire_mutex((ValueMutex*)ctx, 25);
  66. view_dispatcher_stop(caesar_state->view_dispatcher);
  67. release_mutex((ValueMutex*)ctx, caesar_state);
  68. return true;
  69. }
  70. static void caesar_cipher_state_init(CaesarState* const caesar_state) {
  71. caesar_state->view_dispatcher = view_dispatcher_alloc();
  72. caesar_state->text_input = text_input_alloc();
  73. caesar_state->text_box = text_box_alloc();
  74. text_box_set_font(caesar_state->text_box, TextBoxFontText);
  75. }
  76. static void caesar_cipher_state_free(CaesarState* const caesar_state) {
  77. text_input_free(caesar_state->text_input);
  78. text_box_free(caesar_state->text_box);
  79. view_dispatcher_remove_view(caesar_state->view_dispatcher, 0);
  80. view_dispatcher_remove_view(caesar_state->view_dispatcher, 1);
  81. view_dispatcher_free(caesar_state->view_dispatcher);
  82. free(caesar_state);
  83. }
  84. int32_t caesar_cipher_app() {
  85. CaesarState* caesar_state = malloc(sizeof(CaesarState));
  86. FURI_LOG_D("caesar_cipher", "Running caesar_cipher_state_init");
  87. caesar_cipher_state_init(caesar_state);
  88. ValueMutex state_mutex;
  89. if(!init_mutex(&state_mutex, caesar_state, sizeof(CaesarState))) {
  90. FURI_LOG_E("caesar_cipher", "cannot create mutex\r\n");
  91. free(caesar_state);
  92. return 255;
  93. }
  94. FURI_LOG_D("caesar_cipher", "Assigning text input callback");
  95. text_input_set_result_callback(
  96. caesar_state->text_input,
  97. text_input_callback,
  98. &state_mutex,
  99. caesar_state->input,
  100. TEXT_BUFFER_SIZE,
  101. //clear default text
  102. true
  103. );
  104. text_input_set_header_text(caesar_state->text_input, "Input");
  105. // Open GUI and register view_port
  106. Gui* gui = furi_record_open("gui");
  107. //gui_add_view_port(gui, view_port, GuiLayerFullscreen);
  108. FURI_LOG_D("caesar_cipher", "Enabling view dispatcher queue");
  109. view_dispatcher_enable_queue(caesar_state->view_dispatcher);
  110. FURI_LOG_D("caesar_cipher", "Adding text input view to dispatcher");
  111. view_dispatcher_add_view(caesar_state->view_dispatcher, 0, text_input_get_view(caesar_state->text_input));
  112. view_dispatcher_add_view(caesar_state->view_dispatcher, 1, text_box_get_view(caesar_state->text_box));
  113. FURI_LOG_D("caesar_cipher", "Attaching view dispatcher to GUI");
  114. view_dispatcher_attach_to_gui(caesar_state->view_dispatcher, gui, ViewDispatcherTypeFullscreen);
  115. FURI_LOG_D("ceasar_cipher", "starting view dispatcher");
  116. view_dispatcher_set_navigation_event_callback(caesar_state->view_dispatcher, back_event_callback);
  117. view_dispatcher_set_event_callback_context(caesar_state->view_dispatcher, &state_mutex);
  118. view_dispatcher_switch_to_view(caesar_state->view_dispatcher, 0);
  119. view_dispatcher_run(caesar_state->view_dispatcher);
  120. furi_record_close("gui");
  121. delete_mutex(&state_mutex);
  122. caesar_cipher_state_free(caesar_state);
  123. return 0;
  124. }