Browse Source

Consistent static/value item macros

Scott Lahteine 5 years ago
parent
commit
bff0c68078
3 changed files with 45 additions and 35 deletions
  1. 1
    2
      Marlin/src/lcd/fontutils.cpp
  2. 30
    33
      Marlin/src/lcd/menu/menu_info.cpp
  3. 14
    0
      Marlin/src/lcd/menu/menu_item.h

+ 1
- 2
Marlin/src/lcd/fontutils.cpp View File

73
   return -1;
73
   return -1;
74
 }
74
 }
75
 
75
 
76
-/* This function gets the character at the pstart position, interpreting UTF8 multybyte sequences
76
+/* This function gets the character at the pstart position, interpreting UTF8 multibyte sequences
77
    and returns the pointer to the next character */
77
    and returns the pointer to the next character */
78
 uint8_t* get_utf8_value_cb(uint8_t *pstart, read_byte_cb_t cb_read_byte, wchar_t *pval) {
78
 uint8_t* get_utf8_value_cb(uint8_t *pstart, read_byte_cb_t cb_read_byte, wchar_t *pval) {
79
   uint32_t val = 0;
79
   uint32_t val = 0;
161
 }
161
 }
162
 
162
 
163
 static inline uint8_t utf8_strlen_cb(const char *pstart, read_byte_cb_t cb_read_byte) {
163
 static inline uint8_t utf8_strlen_cb(const char *pstart, read_byte_cb_t cb_read_byte) {
164
-
165
   uint8_t cnt = 0;
164
   uint8_t cnt = 0;
166
   uint8_t *pnext = (uint8_t *)pstart;
165
   uint8_t *pnext = (uint8_t *)pstart;
167
   for (;;) {
166
   for (;;) {

+ 30
- 33
Marlin/src/lcd/menu/menu_info.cpp View File

34
   #include "game/game.h"
34
   #include "game/game.h"
35
 #endif
35
 #endif
36
 
36
 
37
-#define VALUE_ITEM(MSG, VALUE, STYL)    do{ char msg[21]; strcpy_P(msg, PSTR(": ")); strcpy(msg + 2, VALUE); STATIC_ITEM(MSG, STYL, msg); }while(0)
38
-#define VALUE_ITEM_P(MSG, PVALUE, STYL) do{ char msg[21]; strcpy_P(msg, PSTR(": ")); strcpy_P(msg + 2, PSTR(PVALUE)); STATIC_ITEM(MSG, STYL, msg); }while(0)
39
-
40
 #if ENABLED(PRINTCOUNTER)
37
 #if ENABLED(PRINTCOUNTER)
41
 
38
 
42
   #include "../../module/printcounter.h"
39
   #include "../../module/printcounter.h"
52
     char buffer[21];
49
     char buffer[21];
53
 
50
 
54
     START_SCREEN();                                                                         // 12345678901234567890
51
     START_SCREEN();                                                                         // 12345678901234567890
55
-    VALUE_ITEM(MSG_INFO_PRINT_COUNT, i16tostr3left(stats.totalPrints), SS_LEFT);            // Print Count: 999
56
-    VALUE_ITEM(MSG_INFO_COMPLETED_PRINTS, i16tostr3left(stats.finishedPrints), SS_LEFT);    // Completed  : 666
52
+    STATIC_ITEM(MSG_INFO_PRINT_COUNT,      SS_LEFT, i16tostr3left(stats.totalPrints));      // Print Count: 999
53
+    STATIC_ITEM(MSG_INFO_COMPLETED_PRINTS, SS_LEFT, i16tostr3left(stats.finishedPrints));   // Completed  : 666
57
 
54
 
58
     STATIC_ITEM(MSG_INFO_PRINT_TIME, SS_LEFT);                                              // Total print Time:
55
     STATIC_ITEM(MSG_INFO_PRINT_TIME, SS_LEFT);                                              // Total print Time:
59
-    STATIC_ITEM_P(PSTR("> "), SS_LEFT, duration_t(stats.printTime).toString(buffer));         // > 99y 364d 23h 59m 59s
56
+    STATIC_ITEM_P(PSTR("> "), SS_LEFT, duration_t(stats.printTime).toString(buffer));       // > 99y 364d 23h 59m 59s
60
 
57
 
61
     STATIC_ITEM(MSG_INFO_PRINT_LONGEST, SS_LEFT);                                           // Longest job time:
58
     STATIC_ITEM(MSG_INFO_PRINT_LONGEST, SS_LEFT);                                           // Longest job time:
62
-    STATIC_ITEM_P(PSTR("> "), SS_LEFT, duration_t(stats.longestPrint).toString(buffer));      // > 99y 364d 23h 59m 59s
59
+    STATIC_ITEM_P(PSTR("> "), SS_LEFT, duration_t(stats.longestPrint).toString(buffer));    // > 99y 364d 23h 59m 59s
63
 
60
 
64
     STATIC_ITEM(MSG_INFO_PRINT_FILAMENT, SS_LEFT);                                          // Extruded total:
61
     STATIC_ITEM(MSG_INFO_PRINT_FILAMENT, SS_LEFT);                                          // Extruded total:
65
     sprintf_P(buffer, PSTR("%ld.%im")
62
     sprintf_P(buffer, PSTR("%ld.%im")
73
     #endif
70
     #endif
74
 
71
 
75
     #if SERVICE_INTERVAL_1 > 0
72
     #if SERVICE_INTERVAL_1 > 0
76
-      STATIC_ITEM_P(PSTR(SERVICE_NAME_1 " "), SS_LEFT, buffer);                               // Service X in:
77
-      STATIC_ITEM_P(PSTR("> "), SS_LEFT, duration_t(stats.nextService1).toString(buffer));    // > 7d 12h 11m 10s
73
+      STATIC_ITEM_P(PSTR(SERVICE_NAME_1 " "), SS_LEFT, buffer);                             // Service X in:
74
+      STATIC_ITEM_P(PSTR("> "), SS_LEFT, duration_t(stats.nextService1).toString(buffer));  // > 7d 12h 11m 10s
78
     #endif
75
     #endif
79
 
76
 
80
     #if SERVICE_INTERVAL_2 > 0
77
     #if SERVICE_INTERVAL_2 > 0
104
     #define THERMISTOR_ID TEMP_SENSOR_0
101
     #define THERMISTOR_ID TEMP_SENSOR_0
105
     #include "../thermistornames.h"
102
     #include "../thermistornames.h"
106
     STATIC_ITEM_P(PSTR(LCD_STR_E0 ": " THERMISTOR_NAME), SS_INVERT);
103
     STATIC_ITEM_P(PSTR(LCD_STR_E0 ": " THERMISTOR_NAME), SS_INVERT);
107
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_0_MINTEMP), SS_LEFT);
108
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_0_MAXTEMP), SS_LEFT);
104
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_0_MINTEMP), SS_LEFT);
105
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_0_MAXTEMP), SS_LEFT);
109
   #endif
106
   #endif
110
 
107
 
111
   #if TEMP_SENSOR_1 != 0
108
   #if TEMP_SENSOR_1 != 0
113
     #define THERMISTOR_ID TEMP_SENSOR_1
110
     #define THERMISTOR_ID TEMP_SENSOR_1
114
     #include "../thermistornames.h"
111
     #include "../thermistornames.h"
115
     STATIC_ITEM_P(PSTR(LCD_STR_E1 ": " THERMISTOR_NAME), SS_INVERT);
112
     STATIC_ITEM_P(PSTR(LCD_STR_E1 ": " THERMISTOR_NAME), SS_INVERT);
116
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_1_MINTEMP), SS_LEFT);
117
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_1_MAXTEMP), SS_LEFT);
113
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_1_MINTEMP), SS_LEFT);
114
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_1_MAXTEMP), SS_LEFT);
118
   #endif
115
   #endif
119
 
116
 
120
   #if TEMP_SENSOR_2 != 0
117
   #if TEMP_SENSOR_2 != 0
122
     #define THERMISTOR_ID TEMP_SENSOR_2
119
     #define THERMISTOR_ID TEMP_SENSOR_2
123
     #include "../thermistornames.h"
120
     #include "../thermistornames.h"
124
     STATIC_ITEM_P(PSTR(LCD_STR_E2 ": " THERMISTOR_NAME), SS_INVERT);
121
     STATIC_ITEM_P(PSTR(LCD_STR_E2 ": " THERMISTOR_NAME), SS_INVERT);
125
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_2_MINTEMP), SS_LEFT);
126
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_2_MAXTEMP), SS_LEFT);
122
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_2_MINTEMP), SS_LEFT);
123
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_2_MAXTEMP), SS_LEFT);
127
   #endif
124
   #endif
128
 
125
 
129
   #if TEMP_SENSOR_3 != 0
126
   #if TEMP_SENSOR_3 != 0
131
     #define THERMISTOR_ID TEMP_SENSOR_3
128
     #define THERMISTOR_ID TEMP_SENSOR_3
132
     #include "../thermistornames.h"
129
     #include "../thermistornames.h"
133
     STATIC_ITEM_P(PSTR(LCD_STR_E3 ": " THERMISTOR_NAME), SS_INVERT);
130
     STATIC_ITEM_P(PSTR(LCD_STR_E3 ": " THERMISTOR_NAME), SS_INVERT);
134
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_3_MINTEMP), SS_LEFT);
135
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_3_MAXTEMP), SS_LEFT);
131
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_3_MINTEMP), SS_LEFT);
132
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_3_MAXTEMP), SS_LEFT);
136
   #endif
133
   #endif
137
 
134
 
138
   #if TEMP_SENSOR_4 != 0
135
   #if TEMP_SENSOR_4 != 0
140
     #define THERMISTOR_ID TEMP_SENSOR_4
137
     #define THERMISTOR_ID TEMP_SENSOR_4
141
     #include "../thermistornames.h"
138
     #include "../thermistornames.h"
142
     STATIC_ITEM_P(PSTR(LCD_STR_E4 ": " THERMISTOR_NAME), SS_INVERT);
139
     STATIC_ITEM_P(PSTR(LCD_STR_E4 ": " THERMISTOR_NAME), SS_INVERT);
143
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_4_MINTEMP), SS_LEFT);
144
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_4_MAXTEMP), SS_LEFT);
140
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_4_MINTEMP), SS_LEFT);
141
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_4_MAXTEMP), SS_LEFT);
145
   #endif
142
   #endif
146
 
143
 
147
   #if TEMP_SENSOR_5 != 0
144
   #if TEMP_SENSOR_5 != 0
149
     #define THERMISTOR_ID TEMP_SENSOR_5
146
     #define THERMISTOR_ID TEMP_SENSOR_5
150
     #include "../thermistornames.h"
147
     #include "../thermistornames.h"
151
     STATIC_ITEM_P(PSTR(LCD_STR_E5 ": " THERMISTOR_NAME), SS_INVERT);
148
     STATIC_ITEM_P(PSTR(LCD_STR_E5 ": " THERMISTOR_NAME), SS_INVERT);
152
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_5_MINTEMP), SS_LEFT);
153
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_5_MAXTEMP), SS_LEFT);
149
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_5_MINTEMP), SS_LEFT);
150
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_5_MAXTEMP), SS_LEFT);
154
   #endif
151
   #endif
155
 
152
 
156
   #if TEMP_SENSOR_6 != 0
153
   #if TEMP_SENSOR_6 != 0
158
     #define THERMISTOR_ID TEMP_SENSOR_6
155
     #define THERMISTOR_ID TEMP_SENSOR_6
159
     #include "../thermistornames.h"
156
     #include "../thermistornames.h"
160
     STATIC_ITEM_P(PSTR(LCD_STR_E6 ": " THERMISTOR_NAME), SS_INVERT);
157
     STATIC_ITEM_P(PSTR(LCD_STR_E6 ": " THERMISTOR_NAME), SS_INVERT);
161
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_6_MINTEMP), SS_LEFT);
162
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_6_MAXTEMP), SS_LEFT);
158
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_6_MINTEMP), SS_LEFT);
159
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_6_MAXTEMP), SS_LEFT);
163
   #endif
160
   #endif
164
 
161
 
165
   #if TEMP_SENSOR_7 != 0
162
   #if TEMP_SENSOR_7 != 0
167
     #define THERMISTOR_ID TEMP_SENSOR_7
164
     #define THERMISTOR_ID TEMP_SENSOR_7
168
     #include "../thermistornames.h"
165
     #include "../thermistornames.h"
169
     STATIC_ITEM_P(PSTR(LCD_STR_E7 ": " THERMISTOR_NAME), SS_INVERT);
166
     STATIC_ITEM_P(PSTR(LCD_STR_E7 ": " THERMISTOR_NAME), SS_INVERT);
170
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_7_MINTEMP), SS_LEFT);
171
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_7_MAXTEMP), SS_LEFT);
167
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(HEATER_7_MINTEMP), SS_LEFT);
168
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(HEATER_7_MAXTEMP), SS_LEFT);
172
   #endif
169
   #endif
173
 
170
 
174
   #if EXTRUDERS
171
   #if EXTRUDERS
180
     #define THERMISTOR_ID TEMP_SENSOR_BED
177
     #define THERMISTOR_ID TEMP_SENSOR_BED
181
     #include "../thermistornames.h"
178
     #include "../thermistornames.h"
182
     STATIC_ITEM_P(PSTR("BED:" THERMISTOR_NAME), SS_INVERT);
179
     STATIC_ITEM_P(PSTR("BED:" THERMISTOR_NAME), SS_INVERT);
183
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(BED_MINTEMP), SS_LEFT);
184
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(BED_MAXTEMP), SS_LEFT);
180
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(BED_MINTEMP), SS_LEFT);
181
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(BED_MAXTEMP), SS_LEFT);
185
     STATIC_ITEM(TERN(WATCH_BED, MSG_INFO_RUNAWAY_ON, MSG_INFO_RUNAWAY_OFF), SS_LEFT);
182
     STATIC_ITEM(TERN(WATCH_BED, MSG_INFO_RUNAWAY_ON, MSG_INFO_RUNAWAY_OFF), SS_LEFT);
186
   #endif
183
   #endif
187
 
184
 
190
     #define THERMISTOR_ID TEMP_SENSOR_CHAMBER
187
     #define THERMISTOR_ID TEMP_SENSOR_CHAMBER
191
     #include "../thermistornames.h"
188
     #include "../thermistornames.h"
192
     STATIC_ITEM_P(PSTR("CHAM:" THERMISTOR_NAME), SS_INVERT);
189
     STATIC_ITEM_P(PSTR("CHAM:" THERMISTOR_NAME), SS_INVERT);
193
-    VALUE_ITEM_P(MSG_INFO_MIN_TEMP, STRINGIFY(CHAMBER_MINTEMP), SS_LEFT);
194
-    VALUE_ITEM_P(MSG_INFO_MAX_TEMP, STRINGIFY(CHAMBER_MAXTEMP), SS_LEFT);
190
+    PSTRING_ITEM(MSG_INFO_MIN_TEMP, STRINGIFY(CHAMBER_MINTEMP), SS_LEFT);
191
+    PSTRING_ITEM(MSG_INFO_MAX_TEMP, STRINGIFY(CHAMBER_MAXTEMP), SS_LEFT);
195
     STATIC_ITEM(TERN(WATCH_CHAMBER, MSG_INFO_RUNAWAY_ON, MSG_INFO_RUNAWAY_OFF), SS_LEFT);
192
     STATIC_ITEM(TERN(WATCH_CHAMBER, MSG_INFO_RUNAWAY_ON, MSG_INFO_RUNAWAY_OFF), SS_LEFT);
196
   #endif
193
   #endif
197
 
194
 
209
   #ifdef BOARD_WEBSITE_URL
206
   #ifdef BOARD_WEBSITE_URL
210
     STATIC_ITEM_P(PSTR(BOARD_WEBSITE_URL), SS_LEFT);               // www.my3dprinter.com
207
     STATIC_ITEM_P(PSTR(BOARD_WEBSITE_URL), SS_LEFT);               // www.my3dprinter.com
211
   #endif
208
   #endif
212
-  VALUE_ITEM_P(MSG_INFO_BAUDRATE, STRINGIFY(BAUDRATE), SS_CENTER); // Baud: 250000
213
-  VALUE_ITEM_P(MSG_INFO_PROTOCOL, PROTOCOL_VERSION, SS_CENTER);    // Protocol: 1.0
214
-  VALUE_ITEM_P(MSG_INFO_PSU,      PSU_NAME, SS_CENTER);
209
+  PSTRING_ITEM(MSG_INFO_BAUDRATE, STRINGIFY(BAUDRATE), SS_CENTER); // Baud: 250000
210
+  PSTRING_ITEM(MSG_INFO_PROTOCOL, PROTOCOL_VERSION, SS_CENTER);    // Protocol: 1.0
211
+  PSTRING_ITEM(MSG_INFO_PSU, PSU_NAME, SS_CENTER);
215
   END_SCREEN();
212
   END_SCREEN();
216
 }
213
 }
217
 
214
 
242
     STATIC_ITEM_P(PSTR(STRING_DISTRIBUTION_DATE));              // YYYY-MM-DD HH:MM
239
     STATIC_ITEM_P(PSTR(STRING_DISTRIBUTION_DATE));              // YYYY-MM-DD HH:MM
243
     STATIC_ITEM_P(PSTR(MACHINE_NAME));                          // My3DPrinter
240
     STATIC_ITEM_P(PSTR(MACHINE_NAME));                          // My3DPrinter
244
     STATIC_ITEM_P(PSTR(WEBSITE_URL));                           // www.my3dprinter.com
241
     STATIC_ITEM_P(PSTR(WEBSITE_URL));                           // www.my3dprinter.com
245
-    VALUE_ITEM_P(MSG_INFO_EXTRUDERS, STRINGIFY(EXTRUDERS), SS_CENTER); // Extruders: 2
242
+    PSTRING_ITEM(MSG_INFO_EXTRUDERS, STRINGIFY(EXTRUDERS), SS_CENTER); // Extruders: 2
246
     #if HAS_LEVELING
243
     #if HAS_LEVELING
247
       STATIC_ITEM(
244
       STATIC_ITEM(
248
         TERN_(AUTO_BED_LEVELING_3POINT, MSG_3POINT_LEVELING)      // 3-Point Leveling
245
         TERN_(AUTO_BED_LEVELING_3POINT, MSG_3POINT_LEVELING)      // 3-Point Leveling

+ 14
- 0
Marlin/src/lcd/menu/menu_item.h View File

328
   NEXT_ITEM();                               \
328
   NEXT_ITEM();                               \
329
 }while(0)
329
 }while(0)
330
 
330
 
331
+// PSTRING_ITEM is like STATIC_ITEM but it takes
332
+// two PSTRs with the style as the last parameter.
333
+
334
+#define PSTRING_ITEM_P(PLABEL, PVAL, STYL) do{ \
335
+  constexpr int m = 20;                        \
336
+  char msg[m+1];                               \
337
+  msg[0] = ':'; msg[1] = ' ';                  \
338
+  strncpy_P(msg+2, PSTR(PVAL), m-2);           \
339
+  if (msg[m-1] & 0x80) msg[m-1] = '\0';        \
340
+  STATIC_ITEM_P(PLABEL, STYL, msg);            \
341
+}while(0)
342
+
343
+#define PSTRING_ITEM(LABEL, V...)                     PSTRING_ITEM_P(GET_TEXT(LABEL), ##V)
344
+
331
 #define STATIC_ITEM(LABEL,      V...)                  STATIC_ITEM_P(GET_TEXT(LABEL), ##V)
345
 #define STATIC_ITEM(LABEL,      V...)                  STATIC_ITEM_P(GET_TEXT(LABEL), ##V)
332
 #define STATIC_ITEM_N(LABEL, N, V...)                STATIC_ITEM_N_P(GET_TEXT(LABEL), ##V)
346
 #define STATIC_ITEM_N(LABEL, N, V...)                STATIC_ITEM_N_P(GET_TEXT(LABEL), ##V)
333
 
347
 

Loading…
Cancel
Save