Skip to content
This repository has been archived by the owner on Apr 2, 2023. It is now read-only.

Latest commit

 

History

History
86 lines (59 loc) · 2.67 KB

README.md

File metadata and controls

86 lines (59 loc) · 2.67 KB

🚩 This project is archived! 🚩

It should still work well (at least for basic use cases), but I encourage someone else to take this code and make it better

zline

IMPORTANT: please note that this is a very WIP project, and probably not even ready for hobby usage. the API will probably change a million times before it's stabilized, so use at your own risk

A simple yet powerful line editor for Zig.

Installation

Since zline is just one file (zline.zig), the simplest installation option is just downloading the file and putting it into your build setup.

A sample build.zig with this approach looks like this:

const Builder = @import("std").build.Builder;

pub fn build(b: *Builder) void {
    const mode = b.standardReleaseOptions();

    const lib = b.addStaticLibrary("zline", "src/main.zig");
    lib.setBuildMode(mode);
    lib.install();

    var main_tests = b.addTest("src/main.zig");
    main_tests.setBuildMode(mode);

    const test_step = b.step("test", "Run library tests");
    test_step.dependOn(&main_tests.step);
}

Usage

After installing, getting up and running is pretty simple:

const std = @import("std");
const zline = @import("zline"); // Or however you have this set up

pub fn main() anyerror!void {
    var arena = std.heap.ArenaAllocator.init();
    defer arena.deinit();

    var alloc = &arena.allocator;

    var rl = zline.Editor(struct {}).init(alloc, null, .{});
    defer rl.deinit(); // Run clean-up code

    while (true) {
        if (rl.readline(">> ")) |line| {
            if (std.mem.eql(u8, line, "quit")) {
                break;
            }
            std.io.getStdOut().writer().print("line: {s}", .{ line });
            // If not using an arena allocator, make sure you call `alloc.free` here
        } else |err| {
            return err;
        }
    }
}

More advanced usage is covered in USAGE.md and the examples. API documentation is in API.md

Why not use linenoise?

Since Zig has easy to use C bindings, why shouldn't you just use linenoise? Off the bat, I'd say linenoise is a wonderful library. It achieves all of it's goals, and I'd take it any day over readline.

However, linenoise does not satisfy many of Zig's goals/best practices, like:

  • Allowing custom memory allocators
  • Using Zig style try/catch error handling

In addition, it's API isn't as clean as a pure Zig API. Besides all these things, I also just wanted to try my hand at writing a line editor.

Prior Work