Freeciv21
Develop your civilization from humble roots to a global empire
fciconv.h File Reference
#include "support.h"
#include <stdio.h>
+ Include dependency graph for fciconv.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define FC_DEFAULT_DATA_ENCODING   "UTF-8"
 
#define fc_printf(...)   fc_fprintf(stdout, __VA_ARGS__)
 

Functions

void init_character_encodings (const char *internal_encoding, bool use_transliteration)
 Must be called during the initialization phase of server and client to initialize the character encodings to be used. More...
 
const char * get_internal_encoding ()
 Return the internal encoding. More...
 
char * data_to_internal_string_malloc (const char *text)
 
char * internal_to_data_string_malloc (const char *text)
 
char * internal_to_local_string_malloc (const char *text)
 
char * local_to_internal_string_malloc (const char *text)
 
char * local_to_internal_string_buffer (const char *text, char *buf, size_t bufsz)
 
void fc_fprintf (FILE *stream, const char *format,...) fc__attribute((__format__(__printf__
 
void size_t get_internal_string_length (const char *text)
 Return the length, in characters, of the string. More...
 

Macro Definition Documentation

◆ FC_DEFAULT_DATA_ENCODING

#define FC_DEFAULT_DATA_ENCODING   "UTF-8"

Definition at line 69 of file fciconv.h.

◆ fc_printf

#define fc_printf (   ...)    fc_fprintf(stdout, __VA_ARGS__)

Definition at line 84 of file fciconv.h.

Function Documentation

◆ data_to_internal_string_malloc()

char* data_to_internal_string_malloc ( const char *  text)

Definition at line 92 of file fciconv.cpp.

Referenced by get_conv().

◆ fc_fprintf()

void fc_fprintf ( FILE *  stream,
const char *  format,
  ... 
)

◆ get_internal_encoding()

const char* get_internal_encoding ( )

Return the internal encoding.

This depends on the server or GUI being used.

Definition at line 90 of file fciconv.cpp.

Referenced by client_main(), main(), and srv_init().

◆ get_internal_string_length()

void size_t get_internal_string_length ( const char *  text)

Return the length, in characters, of the string.

This can be used in place of qstrlen in some places because it returns the number of characters not the number of bytes (with multi-byte characters in UTF-8, the two may not be the same).

Use of this function outside of GUI layout code is probably a hack. For instance the demographics code uses it, but this should instead pass the data directly to the GUI library for formatting.

Definition at line 153 of file fciconv.cpp.

Referenced by dem_line_item(), helptext_extra(), insert_generated_text(), insert_veteran_help(), and report_demographics().

◆ init_character_encodings()

void init_character_encodings ( const char *  my_internal_encoding,
bool  my_use_transliteration 
)

Must be called during the initialization phase of server and client to initialize the character encodings to be used.

Pass an internal encoding of nullptr to use the local encoding internally.

Definition at line 39 of file fciconv.cpp.

Referenced by client_main(), fcmp_init(), main(), and srv_init().

◆ internal_to_data_string_malloc()

char* internal_to_data_string_malloc ( const char *  text)

Definition at line 99 of file fciconv.cpp.

Referenced by put_conv().

◆ internal_to_local_string_malloc()

char* internal_to_local_string_malloc ( const char *  text)

Definition at line 106 of file fciconv.cpp.

Referenced by fc_fopen(), fc_remove(), fc_stat(), and generic_generator().

◆ local_to_internal_string_buffer()

char* local_to_internal_string_buffer ( const char *  text,
char *  buf,
size_t  bufsz 
)

Definition at line 120 of file fciconv.cpp.

Referenced by big_int_to_text(), and fc_strerror().

◆ local_to_internal_string_malloc()

char* local_to_internal_string_malloc ( const char *  text)

Definition at line 113 of file fciconv.cpp.

Referenced by generic_generator(), and freeciv::server::input_on_stdin().