Compare commits

...

16 Commits

15 changed files with 36 additions and 17 deletions

2
.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
*.inc
libscterm

View File

@ -53,7 +53,7 @@ BIN := $(OUTDIR)/$(PROJ)
SRCS += $(notdir $(wildcard src/*.cpp))
OBJS := $(addprefix $(BUILDDIR)/, $(SRCS:.cpp=.o))
DEPS := $(addprefix $(BUILDDIR)/, $(SRCS:.cpp=.dep))
HDRS ?= $(wildcard src/*.hpp)
HDRS ?= $(filter-out src/precomp.hpp, $(wildcard src/*.hpp))
MANS := $(addprefix $(PREFIX)/, $(wildcard man/man*/*))
# if project supports plugins, link to libdl where needed
@ -126,7 +126,8 @@ else
$(OUTDIR)/$(REALNAME): $(OBJS)
endif
ifeq ($(UNAME_S),Darwin)
$(CXX) -dynamiclib -o $(OUTDIR)/$(REALNAME) -current_version $(MAJOR) -compatibility_version $(MINOR) $(LDFLAGS) $(OBJS) $(LDLIBS)
$(CXX) -dynamiclib -o $(OUTDIR)/$(REALNAME) -install_name $(LIBDIR)/$(REALNAME) \
-current_version $(MAJOR) -compatibility_version $(MINOR) $(LDFLAGS) $(OBJS) $(LDLIBS)
else ifeq ($(UNAME_S),OpenBSD)
$(CXX) -g -shared -Wl,-soname,$(REALNAME) -o $(OUTDIR)/$(REALNAME) $(LDFLAGS) $(OBJS) $(LDLIBS)
else ifeq ($(UNAME_S),Linux)

View File

@ -26,5 +26,9 @@ In progress. For now, please consult the library header at
## Test
Clone, build, and run the [progress](https://git.bobpolis.com/bob/progress/)
tool.
`make test`
will run a tool showcasing most of the possibilities. This tool was formerly a
separate project: `progress`, still [available on this
server](https://git.bobpolis.com/bob/progress/) for its history.

View File

@ -12,7 +12,7 @@ PRODUCT := lib
# Single source of truth for version.
MAJOR := 1
MINOR := 3
MINOR := 6
PATCH := 0
# Specify desired C++ standard for this project.

View File

@ -1 +0,0 @@
const char* commit = "85a398ff3e70ceb2fd735cf40a90e97bdd36badb";

View File

@ -46,6 +46,12 @@ std::ostream& sc::io::show_cursor(std::ostream& out) {
return out;
}
std::ostream& sc::io::clear_screen(std::ostream& out) {
if (should_color(out))
out << "\x1b" << 'c';
return out;
}
std::ostream& sc::io::reset(std::ostream& out) {
if (should_color(out))
out << "\x1b[m";

View File

@ -11,6 +11,7 @@ namespace sc {
std::ostream& hide_cursor(std::ostream& out);
std::ostream& show_cursor(std::ostream& out);
std::ostream& clear_screen(std::ostream& out);
std::ostream& reset(std::ostream& out);
std::ostream& bold(std::ostream& out);

View File

@ -34,6 +34,10 @@ void term::progress(int prefixlen,
double cur,
double total) const
{
progress(prefixlen, prefix, cur / total);
}
void term::progress(int prefixlen, const std::string& prefix, double fraction) const {
if (!_isatty) return;
// use unicode to make nice bar
@ -41,12 +45,12 @@ void term::progress(int prefixlen,
u8"\u258F", u8"\u258E", u8"\u258D", u8"\u258C",
u8"\u258B", u8"\u258A", u8"\u2589", u8"\u2588"
};
if (cur > total) cur = total;
if (fraction > 1) fraction = 1.0;
int perclen = 5;
int barwidth = cols() - perclen - prefixlen - 1;
int maxsteps = barwidth * 8;
int steps = round(cur * maxsteps / total);
int perc = round(100 * cur / total);
int steps = round(fraction * maxsteps);
int perc = round(100 * fraction);
int fill_len = barwidth - steps / 8;
*_out << '\r' << std::setw(prefixlen) << prefix.substr(0, prefixlen) << ' ' << io::grayf(8);
for (int i = 0; i < steps / 8; ++i) {

View File

@ -25,6 +25,10 @@ namespace sc {
double cur,
double total) const;
void progress(int prefixlen,
const std::string& prefix,
double fraction) const;
static bool has_truecolor();
};

View File

@ -1,9 +1,9 @@
#include "version.hpp"
#include "version.inc"
#include "commit.inc"
#include <sstream>
std::string libscterm_version() {
#include "version.inc"
#include "commit.inc"
std::ostringstream oss;
oss << "libscterm version " << version;
#ifdef DEBUG

View File

@ -1,8 +1,8 @@
#ifndef VERSION_H_
#define VERSION_H_
#ifndef _LIBSCTERM_VERSION_H_
#define _LIBSCTERM_VERSION_H_
#include <string>
std::string libscterm_version();
#endif // VERSION_H_
#endif // _LIBSCTERM_VERSION_H_

View File

@ -1 +0,0 @@
const char* version = "1.3.0";

View File

@ -1 +0,0 @@
const char* commit = "85a398ff3e70ceb2fd735cf40a90e97bdd36badb";

View File

@ -145,6 +145,7 @@ void show_truecolor(const sc::term& t) {
int main() {
try {
std::cout << "using " << libscterm_version() << '\n';
sc::term term {STDERR_FILENO};
show_rows_cols(term);
show_grayscale_bar();

View File

@ -1 +0,0 @@
const char* version = "1.3.0";