Skip to content

Commit

Permalink
Added a draw_float function (implemented in C)
Browse files Browse the repository at this point in the history
  • Loading branch information
aviallon committed Jun 6, 2020
1 parent 468b755 commit a6e584f
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 1 deletion.
8 changes: 7 additions & 1 deletion include/knightos/display.h
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,13 @@ void draw_byte(SCREEN *screen, unsigned char x, unsigned char y, unsigned char v
**/
void draw_signed(SCREEN *screen, unsigned char x, unsigned char y, signed short value);

/*.*
/**
* Draws a float at x,y
**/

void draw_float(SCREEN* screen, unsigned char x, unsigned char y, float value);

/**
* Draws a long at x, y
* NYI
**/
Expand Down
34 changes: 34 additions & 0 deletions src/knightos/display.c
Original file line number Diff line number Diff line change
Expand Up @@ -340,6 +340,40 @@ void draw_signed(SCREEN* screen, unsigned char x, unsigned char y, signed short
return;
}

void draw_float(SCREEN* screen, unsigned char x, unsigned char y, float value){
/* Implementation is weird and slow because of non-working snprintf. Indeed, %f format strings are not yet implemented */
unsigned int integer_part;
unsigned int frac_part;
unsigned int integer_part_len;
bool sgn = (value < 0);


value = sgn ? -value : value;

integer_part = (unsigned int)value;
frac_part = ((value - (float)integer_part)*10000);

#define __log10u(x) ((x >= 10000000u) ? 7 : (x >= 1000000u) ? 6 : \
(x >= 100000u) ? 5 : (x >= 10000u) ? 4 : \
(x >= 1000u) ? 3 : (x >= 100u) ? 2 : (x >= 10u) ? 1u : 0u)

integer_part_len = (__log10u(integer_part)) + 1;

if(sgn){
draw_char(screen, x, y, '-');
x += 4;
}

draw_short(screen, x, y, integer_part);
x += integer_part_len*4;
draw_char(screen, x, y, '.');

x += 4;
draw_short(screen, x, y, frac_part);

return;
}

void invert_pixel(SCREEN *screen, char x, char y) {
__asm
POP BC ; return
Expand Down

0 comments on commit a6e584f

Please sign in to comment.