Files
fil/docs/snippets/zig/config/advanced_config.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.6 KiB

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

pub fn main() !void {
    var gpa = std.heap.GeneralPurposeAllocator(.{}){};
    defer _ = gpa.deinit();
    const allocator = gpa.allocator();

    const config_json =
        \\{
        \\  "use_cache": true,
        \\  "enable_quality_processing": true,
        \\  "ocr": {
        \\    "backend": "tesseract",
        \\    "language": "eng"
        \\  },
        \\  "chunking": {
        \\    "max_characters": 1000,
        \\    "overlap": 200,
        \\    "embedding": {
        \\      "model": {"type": "preset", "name": "balanced"},
        \\      "batch_size": 32,
        \\      "normalize": true
        \\    }
        \\  },
        \\  "language_detection": {
        \\    "enabled": true,
        \\    "min_confidence": 0.8,
        \\    "detect_multiple": false
        \\  },
        \\  "keywords": {
        \\    "algorithm": "yake",
        \\    "max_keywords": 10,
        \\    "min_score": 0.1,
        \\    "ngram_range": [1, 3],
        \\    "language": "en"
        \\  },
        \\  "token_reduction": {
        \\    "mode": "moderate",
        \\    "preserve_important_words": true
        \\  },
        \\  "postprocessor": {
        \\    "enabled": true
        \\  }
        \\}
    ;

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

    const owned = try allocator.dupe(u8, result_json);
    defer allocator.free(owned);

    const stdout = std.io.getStdOut().writer();
    try stdout.print("{s}\n", .{owned});
}