Scroll to navigation

libodraw(3) Library Functions Manual libodraw(3)

NAME

libodraw.hLibrary to access optical disc (split) RAW formats

SYNOPSIS

#include <libodraw.h>

Support functions
const char *
libodraw_get_version(void);

int
libodraw_get_access_flags_read(void);

int
libodraw_get_access_flags_read_write(void);

int
libodraw_get_access_flags_write(void);

int
libodraw_get_codepage(int *codepage, libodraw_error_t **error);

int
libodraw_set_codepage(int codepage, libodraw_error_t **error);

Notify functions
void
libodraw_notify_set_verbose(int verbose);

int
libodraw_notify_set_stream(FILE *stream, libodraw_error_t **error);

int
libodraw_notify_stream_open(const char *filename, libodraw_error_t **error);

int
libodraw_notify_stream_close(libodraw_error_t **error);

Error functions
void
libodraw_error_free(libodraw_error_t **error);

int
libodraw_error_fprint(libodraw_error_t *error, FILE *stream);

int
libodraw_error_sprint(libodraw_error_t *error, char *string, size_t size);

int
libodraw_error_backtrace_fprint(libodraw_error_t *error, FILE *stream);

int
libodraw_error_backtrace_sprint(libodraw_error_t *error, char *string, size_t size);

Handle functions
int
libodraw_handle_initialize(libodraw_handle_t **handle, libodraw_error_t **error);

int
libodraw_handle_free(libodraw_handle_t **handle, libodraw_error_t **error);

int
libodraw_handle_signal_abort(libodraw_handle_t *handle, libodraw_error_t **error);

int
libodraw_handle_open(libodraw_handle_t *handle, const char *filename, int access_flags, libodraw_error_t **error);

int
libodraw_handle_open_data_files(libodraw_handle_t *handle, libodraw_error_t **error);

int
libodraw_handle_close(libodraw_handle_t *handle, libodraw_error_t **error);

ssize_t
libodraw_handle_read_buffer(libodraw_handle_t *handle, void *buffer, size_t buffer_size, libodraw_error_t **error);

ssize_t
libodraw_handle_read_buffer_at_offset(libodraw_handle_t *handle, void *buffer, size_t buffer_size, off64_t offset, libodraw_error_t **error);

off64_t
libodraw_handle_seek_offset(libodraw_handle_t *handle, off64_t offset, int whence, libodraw_error_t **error);

int
libodraw_handle_get_offset(libodraw_handle_t *handle, off64_t *offset, libodraw_error_t **error);

int
libodraw_handle_set_maximum_number_of_open_handles(libodraw_handle_t *handle, int maximum_number_of_open_handles, libodraw_error_t **error);

int
libodraw_handle_get_ascii_codepage(libodraw_handle_t *handle, int *ascii_codepage, libodraw_error_t **error);

int
libodraw_handle_set_ascii_codepage(libodraw_handle_t *handle, int ascii_codepage, libodraw_error_t **error);

int
libodraw_handle_get_number_of_data_files(libodraw_handle_t *handle, int *number_of_data_files, libodraw_error_t **error);

int
libodraw_handle_get_data_file(libodraw_handle_t *handle, int index, libodraw_data_file_t **data_file, libodraw_error_t **error);

int
libodraw_handle_append_data_file(libodraw_handle_t *handle, const char *name, size_t name_length, uint8_t type, libodraw_error_t **error);

Available when compiled with wide character string support:
int
libodraw_handle_open_wide(libodraw_handle_t *handle, const wchar_t *filename, int access_flags, libodraw_error_t **error);

int
libodraw_handle_append_data_file_wide(libodraw_handle_t *handle, const wchar_t *name, size_t name_length, uint8_t type, libodraw_error_t **error);

Available when compiled with libbfio support:
int
libodraw_handle_open_handle_io_handle(libodraw_handle_t *handle, libbfio_handle_t *file_io_handle, int access_flags, libodraw_error_t **error);

int
libodraw_handle_open_data_files_file_io_pool(libodraw_handle_t *handle, libbfio_pool_t *file_io_pool, libodraw_error_t **error);

Meta data functions
int
libodraw_handle_get_media_size(libodraw_handle_t *handle, size64_t *media_size, libodraw_error_t **error);

int
libodraw_handle_get_bytes_per_sector(libodraw_handle_t *handle, uint32_t *bytes_per_sector, libodraw_error_t **error);

int
libodraw_handle_set_bytes_per_sector(libodraw_handle_t *handle, uint32_t bytes_per_sector, libodraw_error_t **error);

int
libodraw_handle_get_number_of_sectors(libodraw_handle_t *handle, uint64_t *number_of_sectors, libodraw_error_t **error);

int
libodraw_handle_get_number_of_sessions(libodraw_handle_t *handle, int *number_of_sessions, libodraw_error_t **error);

int
libodraw_handle_get_session(libodraw_handle_t *handle, int index, uint64_t *start_sector, uint64_t *number_of_sectors, libodraw_error_t **error);

int
libodraw_handle_append_session(libodraw_handle_t *handle, uint64_t first_sector, uint64_t number_of_sectors, libodraw_error_t **error);

int
libodraw_handle_get_number_of_lead_outs(libodraw_handle_t *handle, int *number_of_lead_outs, libodraw_error_t **error);

int
libodraw_handle_get_lead_out(libodraw_handle_t *handle, int index, uint64_t *start_sector, uint64_t *number_of_sectors, libodraw_error_t **error);

int
libodraw_handle_append_lead_out(libodraw_handle_t *handle, uint64_t first_sector, uint64_t number_of_sectors, libodraw_error_t **error);

int
libodraw_handle_get_number_of_tracks(libodraw_handle_t *handle, int *number_of_tracks, libodraw_error_t **error);

int
libodraw_handle_get_track(libodraw_handle_t *handle, int index, uint64_t *start_sector, uint64_t *number_of_sectors, uint8_t *type, int *data_file_index, uint64_t *data_file_start_sector, libodraw_error_t **error);

int
libodraw_handle_append_track(libodraw_handle_t *handle, uint64_t start_sector, uint64_t number_of_sectors, uint8_t type, int data_file_index, uint64_t data_file_start_sector, libodraw_error_t **error);

Data file functions
int
libodraw_data_file_free(libodraw_data_file_t **data_file, libodraw_error_t **error);

int
libodraw_data_file_get_filename_size(libodraw_data_file_t *data_file, size_t *filename_size, libodraw_error_t **error);

int
libodraw_data_file_get_filename(libodraw_data_file_t *data_file, char *filename, size_t filename_size, libodraw_error_t **error);

int
libodraw_data_file_set_filename(libodraw_data_file_t *data_file, const char *filename, size_t filename_length, libodraw_error_t **error);

int
libodraw_data_file_get_type(libodraw_data_file_t *data_file, uint8_t *type, libodraw_error_t **error);

Available when compiled with wide character string support:
int
libodraw_data_file_get_filename_size_wide(libodraw_data_file_t *data_file, size_t *filename_size, libodraw_error_t **error);

int
libodraw_data_file_get_filename_wide(libodraw_data_file_t *data_file, wchar_t *filename, size_t filename_size, libodraw_error_t **error);

int
libodraw_data_file_set_filename_wide(libodraw_data_file_t *data_file, const wchar_t *filename, size_t filename_length, libodraw_error_t **error);

DESCRIPTION

The () 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 "libodraw.h".

ENVIRONMENT

None

FILES

None

NOTES

libodraw can be compiled with wide character support (wchar_t).

To compile libodraw with wide character support use: ./configure --enable-wide-character-type=yes
or define: _UNICODE
or UNICODE
during compilation.

LIBODRAW_WIDE_CHARACTER_TYPE
in libodraw/features.h can be used to determine if libodraw was compiled with wide character support.

BUGS

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

AUTHOR

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

COPYRIGHT

Copyright (C) 2010-2024, 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 libodraw.h include file

October 3, 2019 libodraw