mirror of
https://github.com/ksherlock/mpw-shell.git
synced 2025-01-01 04:29:19 +00:00
command stubs
This commit is contained in:
parent
bc2a530355
commit
c0cf403516
80
command.cpp
Normal file
80
command.cpp
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
#include "command.h"
|
||||||
|
#include "phase2-parser.h"
|
||||||
|
#include <stdexcept>
|
||||||
|
|
||||||
|
command::~command()
|
||||||
|
{}
|
||||||
|
|
||||||
|
|
||||||
|
int simple_command::execute() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int or_command::execute() {
|
||||||
|
/*
|
||||||
|
for (const auto &c : children) {
|
||||||
|
if (!c) throw std::runtime_error("corruption in || command.");
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
int rv = 0;
|
||||||
|
for (auto &c : children) {
|
||||||
|
rv = c->execute();
|
||||||
|
if (rv == 0) return rv;
|
||||||
|
}
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
int and_command::execute() {
|
||||||
|
|
||||||
|
int rv = 0;
|
||||||
|
for (auto &c : children) {
|
||||||
|
rv = c->execute();
|
||||||
|
if (rv != 0) return rv;
|
||||||
|
}
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int vector_command::execute() {
|
||||||
|
|
||||||
|
int rv = 0;
|
||||||
|
for (auto &c : children) {
|
||||||
|
|
||||||
|
rv = c->execute();
|
||||||
|
// todo -- env.exit
|
||||||
|
}
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
int begin_command::execute() {
|
||||||
|
// todo -- parse end for redirection.
|
||||||
|
|
||||||
|
int rv = vector_command::execute();
|
||||||
|
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
int if_command::execute() {
|
||||||
|
|
||||||
|
int rv = 0;
|
||||||
|
bool ok = false;
|
||||||
|
// todo -- parse end for redirection.
|
||||||
|
for(auto &c : clauses) {
|
||||||
|
if (ok) continue;
|
||||||
|
ok = c->evaluate();
|
||||||
|
if (!ok) continue;
|
||||||
|
rv = c->execute();
|
||||||
|
}
|
||||||
|
return rv;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
int if_else_clause::execute() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
bool if_else_clause::evaluate() {
|
||||||
|
return false;
|
||||||
|
}
|
32
command.h
32
command.h
@ -4,7 +4,8 @@
|
|||||||
#include <memory>
|
#include <memory>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <array>
|
#include <array>
|
||||||
#include "mpw-shell-grammar.h"
|
#include <string>
|
||||||
|
#include "phase2-parser.h"
|
||||||
|
|
||||||
typedef std::unique_ptr<struct command> command_ptr;
|
typedef std::unique_ptr<struct command> command_ptr;
|
||||||
typedef std::vector<command_ptr> command_ptr_vector;
|
typedef std::vector<command_ptr> command_ptr_vector;
|
||||||
@ -18,7 +19,7 @@ struct command {
|
|||||||
|
|
||||||
int type = 0;
|
int type = 0;
|
||||||
virtual ~command();
|
virtual ~command();
|
||||||
virtual int execute();
|
virtual int execute() = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct simple_command : public command {
|
struct simple_command : public command {
|
||||||
@ -27,6 +28,8 @@ struct simple_command : public command {
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
std::string text;
|
std::string text;
|
||||||
|
|
||||||
|
virtual int execute() final override;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct binary_command : public command {
|
struct binary_command : public command {
|
||||||
@ -36,6 +39,7 @@ struct binary_command : public command {
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
command_ptr_pair children;
|
command_ptr_pair children;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct or_command : public binary_command {
|
struct or_command : public binary_command {
|
||||||
@ -43,19 +47,35 @@ struct or_command : public binary_command {
|
|||||||
binary_command(PIPE_PIPE, std::move(a), std::move(b))
|
binary_command(PIPE_PIPE, std::move(a), std::move(b))
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
virtual int execute() final override;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct and_command : public binary_command {
|
struct and_command : public binary_command {
|
||||||
and_command(command_ptr &&a, command_ptr &&b) :
|
and_command(command_ptr &&a, command_ptr &&b) :
|
||||||
binary_command(AMP_AMP, std::move(a), std::move(b))
|
binary_command(AMP_AMP, std::move(a), std::move(b))
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
virtual int execute() final override;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
struct pipe_command : public binary_command {
|
||||||
|
and_command(command_ptr &&a, command_ptr &&b) :
|
||||||
|
binary_command(PIPE, std::move(a), std::move(b))
|
||||||
|
{}
|
||||||
|
|
||||||
|
virtual int execute() final override;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
struct vector_command : public command {
|
struct vector_command : public command {
|
||||||
vector_command(int t, command_ptr_vector &&v) : command(t), children(std::move(v))
|
vector_command(int t, command_ptr_vector &&v) : command(t), children(std::move(v))
|
||||||
{}
|
{}
|
||||||
|
|
||||||
command_ptr_vector children;
|
command_ptr_vector children;
|
||||||
|
virtual int execute() override;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct begin_command : public vector_command {
|
struct begin_command : public vector_command {
|
||||||
@ -65,11 +85,14 @@ struct begin_command : public vector_command {
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
std::string end;
|
std::string end;
|
||||||
|
|
||||||
|
virtual int execute() final override;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef std::unique_ptr<struct if_else_clause> if_else_clause_ptr;
|
||||||
struct if_command : public command {
|
struct if_command : public command {
|
||||||
|
|
||||||
typedef std::vector<struct if_else_clause> clause_vector_type;
|
typedef std::vector<if_else_clause_ptr> clause_vector_type;
|
||||||
|
|
||||||
template<class S>
|
template<class S>
|
||||||
if_command(clause_vector_type &&v, S &&s) :
|
if_command(clause_vector_type &&v, S &&s) :
|
||||||
@ -79,6 +102,8 @@ struct if_command : public command {
|
|||||||
|
|
||||||
clause_vector_type clauses;
|
clause_vector_type clauses;
|
||||||
std::string end;
|
std::string end;
|
||||||
|
|
||||||
|
virtual int execute() final override;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct if_else_clause : public vector_command {
|
struct if_else_clause : public vector_command {
|
||||||
@ -91,6 +116,7 @@ struct if_else_clause : public vector_command {
|
|||||||
std::string clause;
|
std::string clause;
|
||||||
|
|
||||||
bool evaluate();
|
bool evaluate();
|
||||||
|
//virtual int execute() final override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
Loading…
Reference in New Issue
Block a user