Files
fil/docs/snippets/zig/api/combining_all_features.md
Henrik Jess Nielsen b4c07d3693
All checks were successful
Deploy fil (kreuzberg) / deploy (push) Successful in 49s
Nomad changes
2026-06-01 23:40:55 +02:00

1.2 KiB

const std = @import("std");
const kreuzberg = @import("kreuzberg");

pub fn main() !void {
    // Configuration is passed across the FFI as a JSON document.
    // This combines OCR, chunking, image extraction, output format, and caching.
    const config_json =
        \\{
        \\  "use_cache": true,
        \\  "enable_quality_processing": true,
        \\  "force_ocr": false,
        \\  "ocr": {
        \\    "backend": "tesseract",
        \\    "language": "eng"
        \\  },
        \\  "chunking": {
        \\    "max_characters": 800,
        \\    "overlap": 100,
        \\    "chunker_type": "markdown",
        \\    "prepend_heading_context": true
        \\  },
        \\  "images": {
        \\    "extract_images": true
        \\  },
        \\  "output_format": "markdown",
        \\  "include_document_structure": true
        \\}
    ;

    const result_json = try kreuzberg.extract_file_sync("report.pdf", null, config_json);
    defer std.heap.c_allocator.free(result_json);

    const stdout = std.io.getStdOut().writer();
    try stdout.print("Result ({d} bytes of JSON):\n{s}\n", .{ result_json.len, result_json });
}