mirror of
https://github.com/ggerganov/llama.cpp.git
synced 2025-01-15 23:00:46 +01:00
78 lines
3.0 KiB
C
78 lines
3.0 KiB
C
|
#pragma once
|
||
|
|
||
|
#include "common.h"
|
||
|
|
||
|
#include <set>
|
||
|
#include <string>
|
||
|
#include <vector>
|
||
|
|
||
|
//
|
||
|
// CLI argument parsing
|
||
|
//
|
||
|
|
||
|
struct llama_arg {
|
||
|
std::set<enum llama_example> examples = {LLAMA_EXAMPLE_COMMON};
|
||
|
std::vector<const char *> args;
|
||
|
const char * value_hint = nullptr; // help text or example for arg value
|
||
|
const char * value_hint_2 = nullptr; // for second arg value
|
||
|
const char * env = nullptr;
|
||
|
std::string help;
|
||
|
bool is_sparam = false; // is current arg a sampling param?
|
||
|
void (*handler_void) (gpt_params & params) = nullptr;
|
||
|
void (*handler_string) (gpt_params & params, const std::string &) = nullptr;
|
||
|
void (*handler_str_str)(gpt_params & params, const std::string &, const std::string &) = nullptr;
|
||
|
void (*handler_int) (gpt_params & params, int) = nullptr;
|
||
|
|
||
|
llama_arg(
|
||
|
const std::initializer_list<const char *> & args,
|
||
|
const char * value_hint,
|
||
|
const std::string & help,
|
||
|
void (*handler)(gpt_params & params, const std::string &)
|
||
|
) : args(args), value_hint(value_hint), help(help), handler_string(handler) {}
|
||
|
|
||
|
llama_arg(
|
||
|
const std::initializer_list<const char *> & args,
|
||
|
const char * value_hint,
|
||
|
const std::string & help,
|
||
|
void (*handler)(gpt_params & params, int)
|
||
|
) : args(args), value_hint(value_hint), help(help), handler_int(handler) {}
|
||
|
|
||
|
llama_arg(
|
||
|
const std::initializer_list<const char *> & args,
|
||
|
const std::string & help,
|
||
|
void (*handler)(gpt_params & params)
|
||
|
) : args(args), help(help), handler_void(handler) {}
|
||
|
|
||
|
// support 2 values for arg
|
||
|
llama_arg(
|
||
|
const std::initializer_list<const char *> & args,
|
||
|
const char * value_hint,
|
||
|
const char * value_hint_2,
|
||
|
const std::string & help,
|
||
|
void (*handler)(gpt_params & params, const std::string &, const std::string &)
|
||
|
) : args(args), value_hint(value_hint), value_hint_2(value_hint_2), help(help), handler_str_str(handler) {}
|
||
|
|
||
|
llama_arg & set_examples(std::initializer_list<enum llama_example> examples);
|
||
|
llama_arg & set_env(const char * env);
|
||
|
llama_arg & set_sparam();
|
||
|
bool in_example(enum llama_example ex);
|
||
|
bool get_value_from_env(std::string & output);
|
||
|
bool has_value_from_env();
|
||
|
std::string to_string();
|
||
|
};
|
||
|
|
||
|
struct gpt_params_context {
|
||
|
enum llama_example ex = LLAMA_EXAMPLE_COMMON;
|
||
|
gpt_params & params;
|
||
|
std::vector<llama_arg> options;
|
||
|
void(*print_usage)(int, char **) = nullptr;
|
||
|
gpt_params_context(gpt_params & params) : params(params) {}
|
||
|
};
|
||
|
|
||
|
// parse input arguments from CLI
|
||
|
// if one argument has invalid value, it will automatically display usage of the specific argument (and not the full usage message)
|
||
|
bool gpt_params_parse(int argc, char ** argv, gpt_params & params, llama_example ex, void(*print_usage)(int, char **) = nullptr);
|
||
|
|
||
|
// function to be used by test-arg-parser
|
||
|
gpt_params_context gpt_params_parser_init(gpt_params & params, llama_example ex, void(*print_usage)(int, char **) = nullptr);
|