t4_tx.c File Reference

#include <stdlib.h>
#include <inttypes.h>
#include <limits.h>
#include <stdio.h>
#include <fcntl.h>
#include <unistd.h>
#include <time.h>
#include <memory.h>
#include <string.h>
#include "floating_fudge.h"
#include <tiffio.h>
#include "spandsp/telephony.h"
#include "spandsp/logging.h"
#include "spandsp/bit_operations.h"
#include "spandsp/async.h"
#include "spandsp/timezone.h"
#include "spandsp/t4_rx.h"
#include "spandsp/t4_tx.h"
#include "spandsp/t4_t6_decode.h"
#include "spandsp/t4_t6_encode.h"
#include "spandsp/private/logging.h"
#include "spandsp/private/t4_t6_decode.h"
#include "spandsp/private/t4_t6_encode.h"
#include "spandsp/private/t4_rx.h"
#include "spandsp/private/t4_tx.h"
#include "faxfont.h"

Classes

struct  t4_run_table_entry_t

Defines

#define CM_PER_INCH   2.54f
#define EOLS_TO_END_T4_TX_PAGE   6
#define EOLS_TO_END_T6_TX_PAGE   2
#define STATE_TRACE(...)
#define pixel_is_black(x, bit)   (((x)[(bit) >> 3] << ((bit) & 7)) & 0x80)

Functions

int t4_tx_set_row_read_handler (t4_state_t *s, t4_row_read_handler_t handler, void *user_data)
 Set the row read handler for a T.4 transmit context.
t4_state_tt4_tx_init (t4_state_t *s, const char *file, int start_page, int stop_page)
 Prepare for transmission of a document.
int t4_tx_start_page (t4_state_t *s)
 Prepare to send the next page of the current document.
int t4_tx_next_page_has_different_format (t4_state_t *s)
 Check for the existance of the next page, and whether its format is like the current one. This information can be needed before it is determined that the current page is finished with.
int t4_tx_restart_page (t4_state_t *s)
 Prepare the current page for a resend.
int t4_tx_end_page (t4_state_t *s)
 Complete the sending of a page.
int t4_tx_get_bit (t4_state_t *s)
 Get the next bit of the current document page. The document will be padded for the current minimum scan line time.
int t4_tx_get_byte (t4_state_t *s)
 Get the next byte of the current document page. The document will be padded for the current minimum scan line time.
int t4_tx_get_chunk (t4_state_t *s, uint8_t buf[], int max_len)
 Get the next chunk of the current document page. The document will be padded for the current minimum scan line time.
int t4_tx_check_bit (t4_state_t *s)
 Return the next bit of the current document page, without actually moving forward in the buffer. The document will be padded for the current minimum scan line time.
int t4_tx_release (t4_state_t *s)
 End the transmission of a document. Tidy up and close the file. This should be used to end T.4 transmission started with t4_tx_init.
int t4_tx_free (t4_state_t *s)
 End the transmission of a document. Tidy up, close the file and free the context. This should be used to end T.4 transmission started with t4_tx_init.
void t4_tx_set_tx_encoding (t4_state_t *s, int encoding)
 Set the encoding for the encoded data.
void t4_tx_set_min_bits_per_row (t4_state_t *s, int bits)
 Set the minimum number of encoded bits per row. This allows the makes the encoding process to be set to comply with the minimum row time specified by a remote receiving machine.
void t4_tx_set_local_ident (t4_state_t *s, const char *ident)
 Set the identity of the local machine, for inclusion in page headers.
void t4_tx_set_header_info (t4_state_t *s, const char *info)
 Set the header info.
void t4_tx_set_header_tz (t4_state_t *s, const char *tzstring)
 Set the header timezone.
int t4_tx_get_y_resolution (t4_state_t *s)
 Get the row-to-row (y) resolution of the current page.
int t4_tx_get_x_resolution (t4_state_t *s)
 Get the column-to-column (x) resolution of the current page.
int t4_tx_get_image_width (t4_state_t *s)
 Get the width of the current page, in pixel columns.
int t4_tx_get_pages_in_file (t4_state_t *s)
 Get the number of pages in the file.
int t4_tx_get_current_page_in_file (t4_state_t *s)
 Get the currnet page number in the file.
void t4_tx_get_transfer_statistics (t4_state_t *s, t4_stats_t *t)
 Get the current transfer statistics.

Detailed Description


Define Documentation

#define CM_PER_INCH   2.54f

The number of centimetres in one inch

#define EOLS_TO_END_T4_TX_PAGE   6

The number of EOLs to be sent at the end of a T.4 page

Referenced by t4_tx_start_page().

#define EOLS_TO_END_T6_TX_PAGE   2

The number of EOLs to be sent at the end of a T.6 page

Referenced by t4_tx_start_page().


Function Documentation

int t4_tx_check_bit ( t4_state_t s  ) 

Return the next bit of the current document page, without actually moving forward in the buffer. The document will be padded for the current minimum scan line time.

Parameters:
s The T.4 context.
Returns:
The next bit (i.e. 0 or 1). For the last bit of data, bit 1 is set (i.e. the returned value is 2 or 3).

References SIG_STATUS_END_OF_DATA.

int t4_tx_end_page ( t4_state_t s  ) 

Complete the sending of a page.

Parameters:
s The T.4 context.
Returns:
zero for success, -1 for failure.

int t4_tx_free ( t4_state_t s  ) 

End the transmission of a document. Tidy up, close the file and free the context. This should be used to end T.4 transmission started with t4_tx_init.

Parameters:
s The T.4 context.
Returns:
0 for success, otherwise -1.

References t4_tx_release().

int t4_tx_get_bit ( t4_state_t s  ) 

Get the next bit of the current document page. The document will be padded for the current minimum scan line time.

Parameters:
s The T.4 context.
Returns:
The next bit (i.e. 0 or 1). For the last bit of data, bit 1 is set (i.e. the returned value is 2 or 3).

References SIG_STATUS_END_OF_DATA.

int t4_tx_get_byte ( t4_state_t s  ) 

Get the next byte of the current document page. The document will be padded for the current minimum scan line time.

Parameters:
s The T.4 context.
Returns:
The next byte. For the last byte of data, bit 8 is set. In this case, one or more bits of the byte may be padded with zeros, to complete the byte.

Referenced by t30_non_ecm_get_byte().

int t4_tx_get_chunk ( t4_state_t s,
uint8_t  buf[],
int  max_len 
)

Get the next chunk of the current document page. The document will be padded for the current minimum scan line time.

Parameters:
s The T.4 context.
buf The buffer into which the chunk is to written.
max_len The maximum length of the chunk.
Returns:
The actual length of the chunk. If this is less than max_len it indicates that the end of the document has been reached.

Referenced by t30_non_ecm_get_chunk().

int t4_tx_get_current_page_in_file ( t4_state_t s  ) 

Get the currnet page number in the file.

Parameters:
s The T.4 context.
Returns:
The page number, or -1 if there is an error.

int t4_tx_get_image_width ( t4_state_t s  ) 

Get the width of the current page, in pixel columns.

Parameters:
s The T.4 context.
Returns:
The number of columns.

int t4_tx_get_pages_in_file ( t4_state_t s  ) 

Get the number of pages in the file.

Parameters:
s The T.4 context.
Returns:
The number of pages, or -1 if there is an error.

void t4_tx_get_transfer_statistics ( t4_state_t s,
t4_stats_t t 
)

Get the current transfer statistics.

Get the current image transfer statistics.

Parameters:
s The T.4 context.
t A pointer to a statistics structure.

Referenced by t30_get_transfer_statistics().

int t4_tx_get_x_resolution ( t4_state_t s  ) 

Get the column-to-column (x) resolution of the current page.

Parameters:
s The T.4 context.
Returns:
The resolution, in pixels per metre.

int t4_tx_get_y_resolution ( t4_state_t s  ) 

Get the row-to-row (y) resolution of the current page.

Parameters:
s The T.4 context.
Returns:
The resolution, in pixels per metre.

t4_state_t* t4_tx_init ( t4_state_t s,
const char *  file,
int  start_page,
int  stop_page 
)

Prepare for transmission of a document.

Parameters:
s The T.4 context.
file The name of the file to be sent.
start_page The first page to send. -1 for no restriction.
stop_page The last page to send. -1 for no restriction.
Returns:
A pointer to the context, or NULL if there was a problem.

References span_log().

int t4_tx_next_page_has_different_format ( t4_state_t s  ) 

Check for the existance of the next page, and whether its format is like the current one. This information can be needed before it is determined that the current page is finished with.

Parameters:
s The T.4 context.
Returns:
0 for next page found with the same format as the current page. 1 for next page found with different format from the current page. -1 for no page found, or file failure.

References span_log().

int t4_tx_release ( t4_state_t s  ) 

End the transmission of a document. Tidy up and close the file. This should be used to end T.4 transmission started with t4_tx_init.

Parameters:
s The T.4 context.
Returns:
0 for success, otherwise -1.

Referenced by t4_tx_free().

int t4_tx_restart_page ( t4_state_t s  ) 

Prepare the current page for a resend.

Parameters:
s The T.4 context.
Returns:
zero for success, -1 for failure.

void t4_tx_set_header_info ( t4_state_t s,
const char *  info 
)

Set the header info.

Set the info field, included in the header line included in each page of an encoded FAX. This is a string of up to 50 characters. Other information (date, local ident, etc.) are automatically included in the header. If the header info is set to NULL or a zero length string, no header lines will be added to the encoded FAX.

Parameters:
s The T.4 context.
info A string, of up to 50 bytes, which will form the info field.

Referenced by t30_set_tx_page_header_info().

void t4_tx_set_header_tz ( t4_state_t s,
const char *  tzstring 
)

Set the header timezone.

Set the time zone for the time stamp in page header lines. If this function is not used the current time zone of the program's environment is used.

Parameters:
s The T.4 context.
info A POSIX timezone description string.

Referenced by t30_set_tx_page_header_tz().

void t4_tx_set_local_ident ( t4_state_t s,
const char *  ident 
)

Set the identity of the local machine, for inclusion in page headers.

Parameters:
s The T.4 context.
ident The identity string.

Referenced by t30_set_tx_ident().

void t4_tx_set_min_bits_per_row ( t4_state_t s,
int  bits 
)

Set the minimum number of encoded bits per row. This allows the makes the encoding process to be set to comply with the minimum row time specified by a remote receiving machine.

Parameters:
s The T.4 context.
bits The minimum number of bits per row.

int t4_tx_set_row_read_handler ( t4_state_t s,
t4_row_read_handler_t  handler,
void *  user_data 
)

Set the row read handler for a T.4 transmit context.

Parameters:
s The T.4 transmit context.
handler A pointer to the handler routine.
user_data An opaque pointer passed to the handler routine.
Returns:
0 for success, otherwise -1.

void t4_tx_set_tx_encoding ( t4_state_t s,
int  encoding 
)

Set the encoding for the encoded data.

Parameters:
s The T.4 context.
encoding The encoding.

int t4_tx_start_page ( t4_state_t s  ) 

Prepare to send the next page of the current document.

Parameters:
s The T.4 context.
Returns:
zero for success, -1 for failure.

References EOLS_TO_END_T4_TX_PAGE, EOLS_TO_END_T6_TX_PAGE, span_log(), and T4_COMPRESSION_ITU_T6.


Generated on Thu Dec 9 21:11:53 2010 for spandsp by  doxygen 1.5.9