|
|
View previous topic :: View next topic |
Author |
Message |
Gabriel
Joined: 03 Aug 2009 Posts: 1067 Location: Panama
|
Printf is too long? Complex? |
Posted: Tue Jun 11, 2019 9:02 pm |
|
|
Hi All,
I got this error:
Quote: | Line 148(24,31): Expression too complex |
Its on a print statement that's printing 14 floats and 9 ints but these are elements in an array of structs.
I do get this is a long print and that i might be pushing it.
Ive solved it by printing in 2 stages but since all, except for the "Index" which is not part of the struct, this is exactly 64 bytes or half a page... so i would really like to do this in one print.
Is this error normal?
Version 5.013 since 5.078 still gives me the endif error and this code is a spin off from that particular code from one of my last posts.
Code: | fprintf(lcd_putc,"EEPROM LOG#%u: %3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%3.2f,%u,%u,%u-%u-%u/%u:%u:%u\r\n",
Temp_Index,
Log_Buffer[Temp_Index].DP_Value1,
Log_Buffer[Temp_Index].DP_Value2,
Log_Buffer[Temp_Index].DP_Value3,
Log_Buffer[Temp_Index].DP_Value4,
Log_Buffer[Temp_Index].DP_Value5,
Log_Buffer[Temp_Index].DP_Value6,
Log_Buffer[Temp_Index].DP_Value7,
Log_Buffer[Temp_Index].DP_Value8,
Log_Buffer[Temp_Index].DP_Value9,
Log_Buffer[Temp_Index].DP_Value10,
Log_Buffer[Temp_Index].DP_Value11,
Log_Buffer[Temp_Index].DP_Value12,
Log_Buffer[Temp_Index].DP_Value13,
Log_Buffer[Temp_Index].DP_Money,
Log_Buffer[Temp_Index].DP_STATUS_BYTE,
Log_Buffer[Temp_Index].DP_BLANK,
Log_Buffer[Temp_Index].DP_YEAR,
Log_Buffer[Temp_Index].DP_MONTH,
Log_Buffer[Temp_Index].DP_DAY,
Log_Buffer[Temp_Index].DP_HOUR,
Log_Buffer[Temp_Index].DP_MINUTES,
Log_Buffer[Temp_Index].DP_SECONDS); |
_________________ CCS PCM 5.078 & CCS PCH 5.093 |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Wed Jun 12, 2019 12:30 am |
|
|
Honestly, why not have the DP.values as an array?.
There is no disadvantage at all in using multiple printf's, rather than one,
and it'd be more efficient in code size, and handling to just use:
Code: |
fprintf(lcd_putc,"EEPROM LOG#%u: ", Temp_Index);
for (count=1;count<14;count++)
fprintf(lcd_putc,"%3.2f,", Log_Buffer[Temp_Index].DP_Value[count]);
|
This will be about 1/10th the actual size in terms of the code, to the
single printf.
You could also cheat if you don't want to re-declare the variable, by using
#locate, to put a second array variable into the same memory location.
There is a limit in printf, on the maximum length of the format string. I think
if I remember correctly, it is somewhere just over 100 bytes. This is what
you are hitting. |
|
|
Gabriel
Joined: 03 Aug 2009 Posts: 1067 Location: Panama
|
|
Posted: Wed Jun 12, 2019 7:42 am |
|
|
Thanks for the Array idea!
I could extend that to the other ints too.
So an array of structs, with each struct containing 2 arrays, 1 for 14 floats and the other 8 ints.
I like it... now ill have to see how this configuration affects the rest of the code.
but i do like it!
Thanks for this unexpected sugestion! _________________ CCS PCM 5.078 & CCS PCH 5.093 |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9295 Location: Greensville,Ontario
|
|
Posted: Wed Jun 12, 2019 8:19 am |
|
|
Yes, there is a limit, I found that out years ago....I use multiple lines, easier to keep track of individual items and easy to edit the 'format' of them as well.
Jay |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|