1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
=head1 НАЗВА
guestfs-ocaml — як використовувати libguestfs з OCaml
=head1 КОРОТКИЙ ОПИС
Стиль Module:
let g = Guestfs.create () in
Guestfs.add_drive_opts g ~format:"raw" ~readonly:true "disk.img";
Guestfs.launch g;
Об’єктно-орієнтований стиль:
let g = new Guestfs.guestfs () in
g#add_drive_opts ~format:"raw" ~readonly:true "disk.img";
g#launch ();
ocamlfind opt prog.ml -package guestfs -linkpkg -o prog
or:
ocamlopt -I +guestfs mlguestfs.cmxa prog.ml -o prog
=head1 ОПИС
На цій сторінці підручника наведено документацію щодо викликів libguestfs з
коду мовою програмування OCaml. На сторінці задокументовано відмінності від
програмного інтерфейсу C та подано декілька прикладів. Якщо ви не дуже
знайомі із користуванням libguestfs, вам також слід прочитати підручник з
L<guestfs(3)>.
=head2 СТИЛІ ПРОГРАМУВАННЯ
Існує два різних стилі програмування, підтримку яких передбачено у
прив'язках до OCaml. Ви можете скористатися модульним стилем, де кожну
функцію C буде прив'язано до функції OCaml:
int guestfs_set_verbose (guestfs_h *g, int flag);
перетворюється на:
val Guestfs.set_verbose : Guestfs.t -> bool -> unit
Крім того, ви можете скористатися об'єктно-орієнтованим стилем, викликаючи
методи на класі C<Guestfs.guestfs>:
method set_verbose : bool -> unit
Код у об'єктно-орієнтованому стилі, зазвичай, є коротшим, а незначна втрата
швидкодії є непомітною у загальному потоці виконання функцій libguestfs.
=head2 ЗАКРИТТЯ ДЕСКРИПТОРА
Дескриптор закривається, коли його знищує збирач сміття. Оскільки
дескриптори libguestfs містять багато від стану, їх також можна закривати (і
отже, звільняти) явним чином, викликаючи C<Guestfs.close> або метод
C<#close>.
=head2 ВИНЯТКИ
Помилки функцій libguestfs пов'язуються із виключенням C<Guestfs.Error>. Це
виключення має єдиний параметр, яким є повідомлення щодо помилки (рядок).
Спроба виклику будь-якої функції чи методу для закритого дескриптора
призводить до C<Guestfs.Handle_closed>. Єдиним параметром цього виключення є
назва функції, яку було викликано.
=head1 ПРИКЛАД. СТВОРЕННЯ ОБРАЗУ ДИСКА
@CREATE_DISK@
=head1 ПРИКЛАД. ПЕРЕВІРКА ОБРАЗУ ДИСКА ВІРТУАЛЬНОЇ МАШИНИ
@INSPECT_VM@
=head1 ПРИКЛАД: ВМИКАННЯ ДІАГНОСТИКИ І ЖУРНАЛЮВАННЯ
@DEBUG_LOGGING@
=head1 ТАКОЖ ПЕРЕГЛЯНЬТЕ
L<guestfs(3)>, L<guestfs-examples(3)>, L<guestfs-erlang(3)>,
L<guestfs-gobject(3)>, L<guestfs-golang(3)>, L<guestfs-java(3)>,
L<guestfs-lua(3)>, L<guestfs-perl(3)>, L<guestfs-python(3)>,
L<guestfs-recipes(1)>, L<guestfs-ruby(3)>, L<http://libguestfs.org/>,
L<http://caml.inria.fr/>.
=head1 АВТОРИ
Richard W.M. Jones (C<rjones at redhat dot com>)
=head1 АВТОРСЬКІ ПРАВА
© Red Hat Inc., 2010–2012
|