Provided by: libfwsi-dev_20181227-1.2build1_amd64 bug

NAME

     libfwsi.h — Library to access the Windows Shell Item format

LIBRARY

     library “libfwsi”

SYNOPSIS

     #include <libfwsi.h>

     Support functions

     const char *
     libfwsi_get_version(void);

     Error functions

     void
     libfwsi_error_free(libfwsi_error_t **error);

     int
     libfwsi_error_fprint(libfwsi_error_t *error, FILE *stream);

     int
     libfwsi_error_sprint(libfwsi_error_t *error, char *string, size_t size);

     int
     libfwsi_error_backtrace_fprint(libfwsi_error_t *error, FILE *stream);

     int
     libfwsi_error_backtrace_sprint(libfwsi_error_t *error, char *string, size_t size);

     Item list functions

     int
     libfwsi_item_list_initialize(libfwsi_item_list_t **item_list, libfwsi_error_t **error);

     int
     libfwsi_item_list_free(libfwsi_item_list_t **item_list, libfwsi_error_t **error);

     int
     libfwsi_item_list_copy_from_byte_stream(libfwsi_item_list_t *item_list, const uint8_t *byte_stream, size_t byte_stream_size, int ascii_codepage, libfwsi_error_t **error);

     int
     libfwsi_item_list_get_data_size(libfwsi_item_list_t *item_list, size_t *data_size, libfwsi_error_t **error);

     int
     libfwsi_item_list_get_number_of_items(libfwsi_item_list_t *item_list, int *number_of_items, libfwsi_error_t **error);

     int
     libfwsi_item_list_get_item(libfwsi_item_list_t *item_list, int item_index, libfwsi_item_t **item, libfwsi_error_t **error);

     Item functions

     int
     libfwsi_item_initialize(libfwsi_item_t **item, libfwsi_error_t **error);

     int
     libfwsi_item_free(libfwsi_item_t **item, libfwsi_error_t **error);

     int
     libfwsi_item_copy_from_byte_stream(libfwsi_item_t *item, const uint8_t *byte_stream, size_t byte_stream_size, int ascii_codepage, libfwsi_error_t **error);

     int
     libfwsi_item_get_type(libfwsi_item_t *item, int *type, libfwsi_error_t **error);

     int
     libfwsi_item_get_class_type(libfwsi_item_t *item, uint8_t *class_type, libfwsi_error_t **error);

     int
     libfwsi_item_get_signature(libfwsi_item_t *item, uint32_t *signature, libfwsi_error_t **error);

     int
     libfwsi_item_get_data_size(libfwsi_item_t *item, size_t *data_size, libfwsi_error_t **error);

     int
     libfwsi_item_get_number_of_extension_blocks(libfwsi_item_t *item, int *number_of_extension_blocks, libfwsi_error_t **error);

     int
     libfwsi_item_get_extension_block(libfwsi_item_t *item, int extension_block_index, libfwsi_extension_block_t **extension_block, libfwsi_error_t **error);

     Root folder item functions

     int
     libfwsi_root_folder_get_shell_folder_identifier(libfwsi_item_t *root_folder, uint8_t *guid_data, size_t guid_data_size, libfwsi_error_t **error);

     Volume item functions

     int
     libfwsi_volume_get_utf8_name_size(libfwsi_item_t *volume, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_volume_get_utf8_name(libfwsi_item_t *volume, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_volume_get_utf16_name_size(libfwsi_item_t *volume, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_volume_get_utf16_name(libfwsi_item_t *volume, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_volume_get_identifier(libfwsi_item_t *volume, uint8_t *guid_data, size_t guid_data_size, libfwsi_error_t **error);

     int
     libfwsi_volume_get_shell_folder_identifier(libfwsi_item_t *volume, uint8_t *guid_data, size_t guid_data_size, libfwsi_error_t **error);

     File entry item functions

     int
     libfwsi_file_entry_get_file_size(libfwsi_item_t *file_entry, uint32_t *file_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_get_modification_time(libfwsi_item_t *file_entry, uint32_t *fat_date_time, libfwsi_error_t **error);

     int
     libfwsi_file_entry_get_file_attribute_flags(libfwsi_item_t *file_entry, uint32_t *file_attribute_flags, libfwsi_error_t **error);

     int
     libfwsi_file_entry_get_utf8_name_size(libfwsi_item_t *file_entry, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_get_utf8_name(libfwsi_item_t *file_entry, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_get_utf16_name_size(libfwsi_item_t *file_entry, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_get_utf16_name(libfwsi_item_t *file_entry, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     Network location item functions

     int
     libfwsi_network_location_get_utf8_location_size(libfwsi_item_t *network_location, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf8_location(libfwsi_item_t *network_location, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf16_location_size(libfwsi_item_t *network_location, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf16_location(libfwsi_item_t *network_location, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf8_description_size(libfwsi_item_t *network_location, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf8_description(libfwsi_item_t *network_location, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf16_description_size(libfwsi_item_t *network_location, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf16_description(libfwsi_item_t *network_location, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf8_comments_size(libfwsi_item_t *network_location, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf8_comments(libfwsi_item_t *network_location, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf16_comments_size(libfwsi_item_t *network_location, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_network_location_get_utf16_comments(libfwsi_item_t *network_location, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     Extension block functions

     int
     libfwsi_extension_block_free(libfwsi_extension_block_t **extension_block, libfwsi_error_t **error);

     int
     libfwsi_extension_block_get_signature(libfwsi_extension_block_t *extension_block, uint32_t *signature, libfwsi_error_t **error);

     int
     libfwsi_extension_block_get_data_size(libfwsi_extension_block_t *extension_block, size_t *data_size, libfwsi_error_t **error);

     File entry extension functions

     int
     libfwsi_file_entry_extension_get_creation_time(libfwsi_extension_block_t *file_entry_extension, uint32_t *fat_date_time, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_access_time(libfwsi_extension_block_t *file_entry_extension, uint32_t *fat_date_time, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_file_reference(libfwsi_extension_block_t *file_entry_extension, uint64_t *file_reference, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf8_long_name_size(libfwsi_extension_block_t *file_entry_extension, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf8_long_name(libfwsi_extension_block_t *file_entry_extension, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf16_long_name_size(libfwsi_extension_block_t *file_entry_extension, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf16_long_name(libfwsi_extension_block_t *file_entry_extension, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf8_localized_name_size(libfwsi_extension_block_t *file_entry_extension, size_t *utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf8_localized_name(libfwsi_extension_block_t *file_entry_extension, uint8_t *utf8_string, size_t utf8_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf16_localized_name_size(libfwsi_extension_block_t *file_entry_extension, size_t *utf16_string_size, libfwsi_error_t **error);

     int
     libfwsi_file_entry_extension_get_utf16_localized_name(libfwsi_extension_block_t *file_entry_extension, uint16_t *utf16_string, size_t utf16_string_size, libfwsi_error_t **error);

     Shell folder identifier functions

     const char *
     libfwsi_shell_folder_identifier_get_name(const uint8_t *shell_folder_identifier);

DESCRIPTION

     The libfwsi_get_version() function is used to retrieve the library version.

RETURN VALUES

     Most of the functions return NULL or -1 on error, dependent on the return type.  For the
     actual return values see "libfwsi.h".

ENVIRONMENT

     None

FILES

     None

BUGS

     Please report bugs of any kind on the project issue tracker:
     https://github.com/libyal/libfwsi/issues

AUTHOR

     These man pages are generated from "libfwsi.h".

COPYRIGHT

     Copyright (C) 2010-2018, Joachim Metz <joachim.metz@gmail.com>.

     This is free software; see the source for copying conditions.  There is NO warranty; not
     even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

SEE ALSO

     the libfwsi.h include file