#ifndef FTS_LANGUAGE_H
#define FTS_LANGUAGE_H
struct fts_language_list;
enum fts_language_result {
/* Provided sample is too short. */
/* Language is unknown or not in the provided list . */
/* textcat library initialization failed. */
};
struct fts_language {
/* Two-letter language name lowercased, e.g. "en" */
const char *name;
};
/* Used for raw data that is indexed. This data shouldn't go through any
language-specific filters. */
extern const struct fts_language fts_language_data;
/*
Language module API.
*/
void fts_languages_init(void);
void fts_languages_deinit(void);
/* Add a language to the list of supported languages. */
void fts_language_register(const char *name);
/* Find a specified language by name. This finds from the internal list of
supported languages. */
/*
Language list API
*/
int fts_language_list_init(const char *const *settings,
struct fts_language_list **list_r,
const char **error_r);
/* Add a language to the list of wanted languages. */
const struct fts_language *lang);
/* Add wanted languages from a space-separated list of language names.
Duplicates are ignored. Returns TRUE if ok, FALSE and unknown_name if an
unknown language was found from the list. */
const char *names,
const char **unknown_name_r);
/* Return an array of all wanted languages. */
const ARRAY_TYPE(fts_language) *
/* Returns the first wanted language (default language). */
const struct fts_language *
/* If text was detected to be one of the languages in the list,
returns FTS_LANGUAGE_RESULT_OK and (a pointer to) the language (in
the list). */
enum fts_language_result
const struct fts_language **lang_r);
#endif