2006-10-01 21:22:43 +00:00
|
|
|
/** \file screen.h High level library for handling the terminal screen
|
|
|
|
|
|
|
|
The screen library allows the interactive reader to write its
|
|
|
|
output to screen efficiently by keeping an inetrnal representation
|
|
|
|
of the current screen contents and trying to find the most
|
|
|
|
efficient way for transforming that to the desired screen content.
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
#ifndef FISH_SCREEN_H
|
|
|
|
#define FISH_SCREEN_H
|
|
|
|
|
2006-10-01 21:22:43 +00:00
|
|
|
/**
|
|
|
|
The struct representing the current and desired screen contents.
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2006-10-01 21:22:43 +00:00
|
|
|
/*
|
|
|
|
The internal representation of the desired screen contents.
|
|
|
|
*/
|
|
|
|
array_list_t desired;
|
|
|
|
/**
|
|
|
|
The internal representation of the actual screen contents.
|
|
|
|
*/
|
|
|
|
array_list_t actual;
|
|
|
|
/**
|
|
|
|
The desired cursor position.
|
|
|
|
*/
|
|
|
|
int desired_cursor[2];
|
|
|
|
/**
|
|
|
|
The actual cursor position.
|
|
|
|
*/
|
|
|
|
int actual_cursor[2];
|
|
|
|
/**
|
|
|
|
A stringbuffer containing the prompt which was last printed to
|
|
|
|
the screen.
|
|
|
|
*/
|
|
|
|
string_buffer_t actual_prompt;
|
2006-10-04 21:45:02 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
The actual width of the screen at the time of the last screen
|
|
|
|
write.
|
|
|
|
*/
|
|
|
|
int actual_width;
|
2006-10-04 23:33:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
These status buffers are used to check if any output has occurred
|
|
|
|
other than from fish's main loop, in which case we need to redraw.
|
|
|
|
*/
|
|
|
|
struct stat prev_buff_1, prev_buff_2, post_buff_1, post_buff_2;
|
2006-10-01 16:02:58 +00:00
|
|
|
}
|
|
|
|
screen_t;
|
|
|
|
|
2006-10-01 21:22:43 +00:00
|
|
|
/**
|
|
|
|
A struct representing a single line of a screen. Consists of two
|
|
|
|
array_lists, which must always be of the same length.
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2006-10-01 21:22:43 +00:00
|
|
|
/**
|
2006-10-01 23:21:36 +00:00
|
|
|
The text contents of the line. Each element of the array
|
|
|
|
represents on column of output. Because some characters are two
|
|
|
|
columns wide, it is perfectly possible for some of the comumns
|
|
|
|
to be empty.
|
2006-10-01 21:22:43 +00:00
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
array_list_t text;
|
2006-10-01 21:22:43 +00:00
|
|
|
/**
|
|
|
|
Highlight information for the line
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
array_list_t color;
|
|
|
|
}
|
|
|
|
line_t;
|
|
|
|
|
2006-10-01 21:22:43 +00:00
|
|
|
/**
|
|
|
|
Initialize a new screen struct
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
void s_init( screen_t *s );
|
2006-10-01 21:22:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Free all memory used by the specified screen struct
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
void s_destroy( screen_t *s );
|
|
|
|
|
2006-10-01 21:22:43 +00:00
|
|
|
/**
|
|
|
|
This is the main function for the screen putput library. It is used
|
|
|
|
to define the desired contents of the screen. The screen command
|
|
|
|
will use it's knowlege of the current contents of the screen in
|
|
|
|
order to render the desired output using as few terminal commands
|
|
|
|
as possible.
|
|
|
|
*/
|
2006-10-01 20:54:23 +00:00
|
|
|
void s_write( screen_t *s,
|
|
|
|
wchar_t *prompt,
|
2006-10-01 21:22:43 +00:00
|
|
|
wchar_t *commandline,
|
|
|
|
int *colors,
|
2006-10-07 00:56:25 +00:00
|
|
|
int *indent,
|
2006-10-01 21:22:43 +00:00
|
|
|
int cursor_pos );
|
|
|
|
|
|
|
|
/**
|
|
|
|
This function resets the screen buffers internal knowledge about
|
|
|
|
the contents of the screen. Use this function when some other
|
|
|
|
function than s_write has written to the screen.
|
|
|
|
*/
|
2006-10-01 16:02:58 +00:00
|
|
|
void s_reset( screen_t *s );
|
|
|
|
|
|
|
|
#endif
|