aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--builtin.cpp4
-rw-r--r--builtin_set_color.cpp195
-rw-r--r--color.cpp12
-rw-r--r--color.h3
-rw-r--r--doc_src/set_color.txt1
-rw-r--r--env.cpp2
-rw-r--r--fish.xcodeproj/project.pbxproj40
-rw-r--r--output.cpp6
-rw-r--r--output.h5
-rw-r--r--reader.cpp12
-rw-r--r--set_color.cpp400
11 files changed, 249 insertions, 431 deletions
diff --git a/builtin.cpp b/builtin.cpp
index e8254533..007adc12 100644
--- a/builtin.cpp
+++ b/builtin.cpp
@@ -167,7 +167,7 @@ static const io_chain_t *real_io;
static int builtin_count_args(wchar_t **argv)
{
int argc = 1;
- while (argv[argc] != 0)
+ while (argv[argc] != NULL)
{
argc++;
}
@@ -390,6 +390,7 @@ static void builtin_missing_argument(parser_t &parser, const wchar_t *cmd, const
#include "builtin_complete.cpp"
#include "builtin_ulimit.cpp"
#include "builtin_jobs.cpp"
+#include "builtin_set_color.cpp"
/* builtin_test lives in builtin_test.cpp */
int builtin_test(parser_t &parser, wchar_t **argv);
@@ -4030,6 +4031,7 @@ static const builtin_data_t builtin_datas[]=
{ L"read", &builtin_read, N_(L"Read a line of input into variables") },
{ L"return", &builtin_return, N_(L"Stop the currently evaluated function") },
{ L"set", &builtin_set, N_(L"Handle environment variables") },
+ { L"set_color", &builtin_set_color, N_(L"Set the terminal color") },
{ L"status", &builtin_status, N_(L"Return status information about fish") },
{ L"switch", &builtin_switch, N_(L"Conditionally execute a block of commands") },
{ L"test", &builtin_test, N_(L"Test a condition") },
diff --git a/builtin_set_color.cpp b/builtin_set_color.cpp
new file mode 100644
index 00000000..afd8da0e
--- /dev/null
+++ b/builtin_set_color.cpp
@@ -0,0 +1,195 @@
+/** \file builtin_set_color.cpp Functions defining the set_color builtin
+
+Functions used for implementing the set_color builtin.
+
+*/
+#include "config.h"
+
+#include "builtin.h"
+#include "color.h"
+#include "output.h"
+
+#if HAVE_TERM_H
+#include <term.h>
+#elif HAVE_NCURSES_TERM_H
+#include <ncurses/term.h>
+#endif
+
+
+/* We know about these buffers */
+extern wcstring stdout_buffer, stderr_buffer;
+
+/**
+ Error message for invalid path operations
+*/
+#define BUILTIN_SET_PATH_ERROR L"%ls: Warning: path component %ls may not be valid in %ls.\n"
+
+/**
+ Hint for invalid path operation with a colon
+*/
+#define BUILTIN_SET_PATH_HINT L"%ls: Did you mean 'set %ls $%ls %ls'?\n"
+
+/**
+ Error for mismatch between index count and elements
+*/
+#define BUILTIN_SET_ARG_COUNT L"%ls: The number of variable indexes does not match the number of values\n"
+
+static void print_colors(void)
+{
+ const wcstring_list_t result = rgb_color_t::named_color_names();
+ size_t i;
+ for (i=0; i < result.size(); i++)
+ {
+ stdout_buffer.append(result.at(i));
+ stdout_buffer.push_back(L'\n');
+ }
+}
+
+/**
+ set_color builtin
+*/
+static int builtin_set_color(parser_t &parser, wchar_t **argv)
+{
+ /** Variables used for parsing the argument list */
+
+ const struct woption long_options[] =
+ {
+ { L"background", required_argument, 0, 'b'},
+ { L"help", no_argument, 0, 'h' },
+ { L"bold", no_argument, 0, 'o' },
+ { L"underline", no_argument, 0, 'u' },
+ { L"version", no_argument, 0, 'v' },
+ { L"print-colors", no_argument, 0, 'c' },
+ { 0, 0, 0, 0 }
+ };
+
+ const wchar_t *short_options = L"b:hvocu";
+
+ int argc = builtin_count_args(argv);
+
+ const wchar_t *bgcolor = NULL;
+ bool bold = false, underline=false;
+
+ /* Parse options to obtain the requested operation and the modifiers */
+ woptind = 0;
+ while (1)
+ {
+ int c = wgetopt_long(argc, argv, short_options, long_options, 0);
+
+ if (c == -1)
+ {
+ break;
+ }
+
+ switch (c)
+ {
+ case 0:
+ break;
+
+ case 'b':
+ bgcolor = woptarg;
+ break;
+
+ case 'h':
+ builtin_print_help(parser, argv[0], stdout_buffer);
+ return STATUS_BUILTIN_OK;
+
+ case 'o':
+ bold = true;
+ break;
+
+ case 'u':
+ underline = true;
+ break;
+
+ case 'c':
+ print_colors();
+ return STATUS_BUILTIN_OK;
+
+ case '?':
+ return STATUS_BUILTIN_ERROR;
+ }
+ }
+
+ /* Remaining argument is foreground color */
+ const wchar_t *fgcolor = NULL;
+ if (woptind < argc)
+ {
+ if (woptind + 1 == argc)
+ {
+ fgcolor = argv[woptind];
+ }
+ else
+ {
+ append_format(stderr_buffer,
+ _(L"%ls: Too many arguments\n"),
+ argv[0]);
+ return STATUS_BUILTIN_ERROR;
+ }
+ }
+
+ if (fgcolor == NULL && bgcolor == NULL && !bold && !underline)
+ {
+ append_format(stderr_buffer,
+ _(L"%ls: Expected an argument\n"),
+ argv[0]);
+ return STATUS_BUILTIN_ERROR;
+ }
+
+ const rgb_color_t fg = rgb_color_t(fgcolor ? fgcolor : L"");
+ if (fgcolor && fg.is_none())
+ {
+ append_format(stderr_buffer, _("%s: Unknown color '%s'\n"), argv[0], fgcolor);
+ return STATUS_BUILTIN_ERROR;
+ }
+
+ const rgb_color_t bg = rgb_color_t(bgcolor ? bgcolor : L"");
+ if (bgcolor && bg.is_none())
+ {
+ append_format(stderr_buffer, _("%s: Unknown color '%s'\n"), argv[0], bgcolor);
+ return STATUS_BUILTIN_ERROR;
+ }
+
+ if (bold)
+ {
+ if (enter_bold_mode)
+ putp(enter_bold_mode);
+ }
+
+ if (underline)
+ {
+ if (enter_underline_mode)
+ putp(enter_underline_mode);
+ }
+
+ if (bgcolor != NULL)
+ {
+ if (bg.is_normal())
+ {
+ write_background_color(0);
+ putp(tparm(exit_attribute_mode));
+ }
+ }
+
+ if (fgcolor != NULL)
+ {
+ if (fg.is_normal())
+ {
+ write_foreground_color(0);
+ putp(tparm(exit_attribute_mode));
+ }
+ else
+ {
+ write_foreground_color(index_for_color(fg));
+ }
+ }
+
+ if (bgcolor != NULL)
+ {
+ if (! bg.is_normal())
+ {
+ write_background_color(index_for_color(bg));
+ }
+ }
+ return STATUS_BUILTIN_OK;
+}
diff --git a/color.cpp b/color.cpp
index d4dd9453..884410d6 100644
--- a/color.cpp
+++ b/color.cpp
@@ -170,6 +170,18 @@ static const named_color_t named_colors[11] =
{L"normal", 8, {0xFF, 0xFF, 0XFF}}
};
+wcstring_list_t rgb_color_t::named_color_names(void)
+{
+ size_t count = sizeof named_colors / sizeof *named_colors;
+ wcstring_list_t result;
+ result.reserve(count);
+ for (size_t i=0; i < count; i++)
+ {
+ result.push_back(named_colors[i].name);
+ }
+ return result;
+}
+
bool rgb_color_t::try_parse_named(const wcstring &str)
{
bzero(&data, sizeof data);
diff --git a/color.h b/color.h
index 0694d693..6e22aaed 100644
--- a/color.h
+++ b/color.h
@@ -169,6 +169,9 @@ public:
{
return !(*this == other);
}
+
+ /** Returns the names of all named colors */
+ static wcstring_list_t named_color_names(void);
};
#endif
diff --git a/doc_src/set_color.txt b/doc_src/set_color.txt
index ccd2d244..08196d19 100644
--- a/doc_src/set_color.txt
+++ b/doc_src/set_color.txt
@@ -18,7 +18,6 @@ as A0FF33 or f2f. fish will choose the closest supported color.
- \c -h, \c --help Display help message and exit
- \c -o, \c --bold Set bold or extra bright mode
- \c -u, \c --underline Set underlined mode
-- \c -v, \c --version Display version and exit
Calling <tt>set_color normal</tt> will set the terminal color to
diff --git a/env.cpp b/env.cpp
index 118eeb01..43113990 100644
--- a/env.cpp
+++ b/env.cpp
@@ -1424,7 +1424,7 @@ static void export_func(const std::map<wcstring, wcstring> &envs, std::vector<st
{
const std::string ks = wcs2string(iter->first);
std::string vs = wcs2string(iter->second);
-
+
for (size_t i=0; i < vs.size(); i++)
{
char &vc = vs.at(i);
diff --git a/fish.xcodeproj/project.pbxproj b/fish.xcodeproj/project.pbxproj
index 4e3226bb..3ebdad93 100644
--- a/fish.xcodeproj/project.pbxproj
+++ b/fish.xcodeproj/project.pbxproj
@@ -45,7 +45,7 @@
D0F019F715A977A00034B3B1 /* CopyFiles */,
D0F019FC15A977B40034B3B1 /* CopyFiles */,
D033780F15DC6D2A00A634BA /* CopyFiles */,
- D01A2C9B16964C8200767098 /* Copy Files */,
+ D01A2C9B16964C8200767098 /* Copy Files */,
);
dependencies = (
D0F01A1315AA36280034B3B1 /* PBXTargetDependency */,
@@ -61,8 +61,8 @@
/* End PBXAggregateTarget section */
/* Begin PBXBuildFile section */
- D01A2D24169B736200767098 /* man1 in Copy Files */ = {isa = PBXBuildFile; fileRef = D01A2D23169B730A00767098 /* man1 */; };
- D01A2D25169B737700767098 /* man1 in CopyFiles */ = {isa = PBXBuildFile; fileRef = D01A2D23169B730A00767098 /* man1 */; };
+ D01A2D24169B736200767098 /* man1 in Copy Files */ = {isa = PBXBuildFile; fileRef = D01A2D23169B730A00767098 /* man1 */; };
+ D01A2D25169B737700767098 /* man1 in CopyFiles */ = {isa = PBXBuildFile; fileRef = D01A2D23169B730A00767098 /* man1 */; };
D031890C15E36E4600D9CC39 /* base in Resources */ = {isa = PBXBuildFile; fileRef = D031890915E36D9800D9CC39 /* base */; };
D033781115DC6D4C00A634BA /* completions in CopyFiles */ = {isa = PBXBuildFile; fileRef = D025C02715D1FEA100B9DB63 /* completions */; };
D033781215DC6D5200A634BA /* functions in CopyFiles */ = {isa = PBXBuildFile; fileRef = D025C02815D1FEA100B9DB63 /* functions */; };
@@ -74,7 +74,7 @@
D07D266D15E33B86009E43F6 /* functions in Copy Files */ = {isa = PBXBuildFile; fileRef = D025C02815D1FEA100B9DB63 /* functions */; };
D07D266E15E33B86009E43F6 /* tools in Copy Files */ = {isa = PBXBuildFile; fileRef = D025C02915D1FEA100B9DB63 /* tools */; };
D07D267215E34171009E43F6 /* config.fish in Copy Files */ = {isa = PBXBuildFile; fileRef = D0CBD580159EE48F0024809C /* config.fish */; };
- D0879AC816BF9AAB00E98E56 /* fish_term_icon.icns in Resources */ = {isa = PBXBuildFile; fileRef = D0879AC616BF9A1A00E98E56 /* fish_term_icon.icns */; };
+ D0879AC816BF9AAB00E98E56 /* fish_term_icon.icns in Resources */ = {isa = PBXBuildFile; fileRef = D0879AC616BF9A1A00E98E56 /* fish_term_icon.icns */; };
D0A564FE168D23D800AF6161 /* man in CopyFiles */ = {isa = PBXBuildFile; fileRef = D0A564F1168D0BAB00AF6161 /* man */; };
D0A56501168D258300AF6161 /* man in Copy Files */ = {isa = PBXBuildFile; fileRef = D0A564F1168D0BAB00AF6161 /* man */; };
D0CBD587159EF0E10024809C /* launch_fish.scpt in Resources */ = {isa = PBXBuildFile; fileRef = D0CBD586159EF0E10024809C /* launch_fish.scpt */; };
@@ -257,24 +257,24 @@
/* End PBXContainerItemProxy section */
/* Begin PBXCopyFilesBuildPhase section */
- D01A2C9B16964C8200767098 /* Copy Files */ = {
+ D01A2C9B16964C8200767098 /* Copy Files */ = {
isa = PBXCopyFilesBuildPhase;
buildActionMask = 2147483647;
- dstPath = base/share/man;
+ dstPath = base/share/man;
dstSubfolderSpec = 1;
files = (
- D01A2D24169B736200767098 /* man1 in Copy Files */,
+ D01A2D24169B736200767098 /* man1 in Copy Files */,
);
- name = "Copy Files";
+ name = "Copy Files";
runOnlyForDeploymentPostprocessing = 0;
};
D01A2CA716965ADD00767098 /* CopyFiles */ = {
isa = PBXCopyFilesBuildPhase;
buildActionMask = 8;
- dstPath = "${INSTALL_PATH}/share/man/";
+ dstPath = "${INSTALL_PATH}/share/man/";
dstSubfolderSpec = 0;
files = (
- D01A2D25169B737700767098 /* man1 in CopyFiles */,
+ D01A2D25169B737700767098 /* man1 in CopyFiles */,
);
runOnlyForDeploymentPostprocessing = 1;
};
@@ -353,7 +353,7 @@
/* End PBXCopyFilesBuildPhase section */
/* Begin PBXFileReference section */
- D01A2D23169B730A00767098 /* man1 */ = {isa = PBXFileReference; lastKnownFileType = text; name = man1; path = pages_for_manpath/man1; sourceTree = BUILT_PRODUCTS_DIR; };
+ D01A2D23169B730A00767098 /* man1 */ = {isa = PBXFileReference; lastKnownFileType = text; name = man1; path = pages_for_manpath/man1; sourceTree = BUILT_PRODUCTS_DIR; };
D025C02715D1FEA100B9DB63 /* completions */ = {isa = PBXFileReference; lastKnownFileType = folder; name = completions; path = share/completions; sourceTree = "<group>"; };
D025C02815D1FEA100B9DB63 /* functions */ = {isa = PBXFileReference; lastKnownFileType = folder; name = functions; path = share/functions; sourceTree = "<group>"; };
D025C02915D1FEA100B9DB63 /* tools */ = {isa = PBXFileReference; lastKnownFileType = folder; name = tools; path = share/tools; sourceTree = "<group>"; };
@@ -361,7 +361,7 @@
D03EE83814DF88B200FC7150 /* lru.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = lru.h; sourceTree = "<group>"; };
D07B247215BCC15700D4ADB4 /* add-shell */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.script.sh; name = "add-shell"; path = "build_tools/osx_package_scripts/add-shell"; sourceTree = "<group>"; };
D07B247515BCC4BE00D4ADB4 /* install.sh */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.script.sh; name = install.sh; path = osx/install.sh; sourceTree = "<group>"; };
- D0879AC616BF9A1A00E98E56 /* fish_term_icon.icns */ = {isa = PBXFileReference; lastKnownFileType = image.icns; name = fish_term_icon.icns; path = osx/fish_term_icon.icns; sourceTree = "<group>"; };
+ D0879AC616BF9A1A00E98E56 /* fish_term_icon.icns */ = {isa = PBXFileReference; lastKnownFileType = image.icns; name = fish_term_icon.icns; path = osx/fish_term_icon.icns; sourceTree = "<group>"; };
D09B1C1914FC7B5B00F91077 /* postfork.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = postfork.cpp; sourceTree = "<group>"; };
D09B1C1A14FC7B5B00F91077 /* postfork.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = postfork.h; sourceTree = "<group>"; };
D0A0850313B3ACEE0099B651 /* builtin.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = builtin.h; sourceTree = "<group>"; };
@@ -469,6 +469,7 @@
D0C4FD9415A7D7EE00212EF1 /* config.fish */ = {isa = PBXFileReference; lastKnownFileType = text; name = config.fish; path = etc/config.fish; sourceTree = "<group>"; };
D0C6FCC914CFA4B0004CE8AD /* autoload.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = autoload.cpp; sourceTree = "<group>"; };
D0C6FCCB14CFA4B7004CE8AD /* autoload.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = autoload.h; sourceTree = "<group>"; };
+ D0C861EA16CC7054003B5A04 /* builtin_set_color.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = builtin_set_color.cpp; sourceTree = "<group>"; };
D0CBD580159EE48F0024809C /* config.fish */ = {isa = PBXFileReference; lastKnownFileType = text; name = config.fish; path = share/config.fish; sourceTree = "<group>"; };
D0CBD583159EEE010024809C /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = System/Library/Frameworks/Foundation.framework; sourceTree = SDKROOT; };
D0CBD586159EF0E10024809C /* launch_fish.scpt */ = {isa = PBXFileReference; lastKnownFileType = file; name = launch_fish.scpt; path = osx/launch_fish.scpt; sourceTree = "<group>"; };
@@ -543,12 +544,12 @@
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
- D01A2C9C16964CF600767098 /* pages_for_manpath */ = {
+ D01A2C9C16964CF600767098 /* pages_for_manpath */ = {
isa = PBXGroup;
children = (
- D01A2D23169B730A00767098 /* man1 */,
+ D01A2D23169B730A00767098 /* man1 */,
);
- name = pages_for_manpath;
+ name = pages_for_manpath;
sourceTree = "<group>";
};
D031890A15E36DB500D9CC39 /* Other Build Products */ = {
@@ -592,6 +593,7 @@
D0A0853113B3ACEE0099B651 /* builtin_complete.cpp */,
D0A0853213B3ACEE0099B651 /* builtin_jobs.cpp */,
D0A0853313B3ACEE0099B651 /* builtin_set.cpp */,
+ D0C861EA16CC7054003B5A04 /* builtin_set_color.cpp */,
D0A0853413B3ACEE0099B651 /* builtin_ulimit.cpp */,
D0F3373A1506DE3C00ECEFC0 /* builtin_test.cpp */,
D0A0853513B3ACEE0099B651 /* builtin.cpp */,
@@ -697,7 +699,7 @@
D0D02AAB15985C14008E62BD /* Resources */ = {
isa = PBXGroup;
children = (
- D0879AC616BF9A1A00E98E56 /* fish_term_icon.icns */,
+ D0879AC616BF9A1A00E98E56 /* fish_term_icon.icns */,
D07B247215BCC15700D4ADB4 /* add-shell */,
D0CBD586159EF0E10024809C /* launch_fish.scpt */,
D0CBD580159EE48F0024809C /* config.fish */,
@@ -705,7 +707,7 @@
D07B247515BCC4BE00D4ADB4 /* install.sh */,
D0D02AA915985C0C008E62BD /* Info.plist */,
D0A564F2168D1F2000AF6161 /* build_documentation.sh */,
- D01A2C9C16964CF600767098 /* pages_for_manpath */,
+ D01A2C9C16964CF600767098 /* pages_for_manpath */,
D0A564F1168D0BAB00AF6161 /* man */,
D025C02715D1FEA100B9DB63 /* completions */,
D025C02815D1FEA100B9DB63 /* functions */,
@@ -903,7 +905,7 @@
files = (
D031890C15E36E4600D9CC39 /* base in Resources */,
D0CBD587159EF0E10024809C /* launch_fish.scpt in Resources */,
- D0879AC816BF9AAB00E98E56 /* fish_term_icon.icns in Resources */,
+ D0879AC816BF9AAB00E98E56 /* fish_term_icon.icns in Resources */,
D07B247315BCC15700D4ADB4 /* add-shell in Resources */,
D07B247615BCC4BE00D4ADB4 /* install.sh in Resources */,
);
@@ -1065,7 +1067,7 @@
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
- shellScript = "cd \"${SRCROOT}\" ;\n# Run build_documentation.sh\n# Do this in a subshell so that we keep going even if it calls exit\n( . \"./build_tools/build_documentation.sh\" \"./Doxyfile.help\" \"./doc_src\" \"$BUILT_PRODUCTS_DIR\" )\n\n# Copy certain files into man1, destined for share/man/man1 (instead of share/fish/man/man1)\n# These copies will fail of the documentation did not build; that's OK\n# We want to create the directory even if the documentation did not build, so that the Xcode build can still succeed\nmanpathdir=\"${BUILT_PRODUCTS_DIR}/pages_for_manpath/man1\"\necho \"Copying pages destined for manpath into $manpathdir\"\nrm -Rf \"$manpathdir\"\nmkdir -p \"$manpathdir\"\nfor manpage in fish.1 set_color.1 fish_pager.1 fishd.1 fish_indent.1; do\n manpagepath=\"${BUILT_PRODUCTS_DIR}/man/man1/${manpage}\"\n test -f \"$manpagepath\" && cp \"$manpagepath\" \"${BUILT_PRODUCTS_DIR}/pages_for_manpath/man1/\"\ndone\n\n# Always succeed\ntrue\n";
+ shellScript = "cd \"${SRCROOT}\" ;\n# Run build_documentation.sh\n# Do this in a subshell so that we keep going even if it calls exit\n( . \"./build_tools/build_documentation.sh\" \"./Doxyfile.help\" \"./doc_src\" \"$BUILT_PRODUCTS_DIR\" )\n\n# Copy certain files into man1, destined for share/man/man1 (instead of share/fish/man/man1)\n# These copies will fail of the documentation did not build; that's OK\n# We want to create the directory even if the documentation did not build, so that the Xcode build can still succeed\nmanpathdir=\"${BUILT_PRODUCTS_DIR}/pages_for_manpath/man1\"\necho \"Copying pages destined for manpath into $manpathdir\"\nrm -Rf \"$manpathdir\"\nmkdir -p \"$manpathdir\"\nfor manpage in fish.1 set_color.1 fish_pager.1 fishd.1 fish_indent.1; do\n manpagepath=\"${BUILT_PRODUCTS_DIR}/man/man1/${manpage}\"\n test -f \"$manpagepath\" && cp \"$manpagepath\" \"${BUILT_PRODUCTS_DIR}/pages_for_manpath/man1/\"\ndone\n\n# Always succeed\ntrue\n";
};
/* End PBXShellScriptBuildPhase section */
diff --git a/output.cpp b/output.cpp
index 69b7c181..3b5f9d4b 100644
--- a/output.cpp
+++ b/output.cpp
@@ -146,7 +146,7 @@ void output_set_supports_term256(bool val)
support_term256 = val;
}
-static unsigned char index_for_color(rgb_color_t c)
+unsigned char index_for_color(rgb_color_t c)
{
if (c.is_named() || ! output_get_supports_term256())
{
@@ -192,7 +192,7 @@ static bool write_color(char *todo, unsigned char idx, bool is_fg)
return result;
}
-static bool write_foreground_color(unsigned char idx)
+bool write_foreground_color(unsigned char idx)
{
if (set_a_foreground && set_a_foreground[0])
{
@@ -208,7 +208,7 @@ static bool write_foreground_color(unsigned char idx)
}
}
-static bool write_background_color(unsigned char idx)
+bool write_background_color(unsigned char idx)
{
if (set_a_background && set_a_background[0])
{
diff --git a/output.h b/output.h
index 0dafcfc0..2d05c3d0 100644
--- a/output.h
+++ b/output.h
@@ -163,4 +163,9 @@ const wchar_t *output_get_term();
bool output_get_supports_term256();
void output_set_supports_term256(bool val);
+/* Exported for builtin_set_color's usage only */
+bool write_foreground_color(unsigned char idx);
+bool write_background_color(unsigned char idx);
+unsigned char index_for_color(rgb_color_t c);
+
#endif
diff --git a/reader.cpp b/reader.cpp
index b0523425..f8fe2619 100644
--- a/reader.cpp
+++ b/reader.cpp
@@ -1147,14 +1147,14 @@ static void run_pager(const wcstring &prefix, int is_quoted, const std::vector<c
{
prefix_esc = escape_string(prefix, 1);
}
-
-
+
+
const wcstring pager_path = escaped_fish_pager_path();
const wcstring cmd = format_string(L"%ls -c 3 -r 4 %ls -p %ls",
- // L"valgrind --track-fds=yes --log-file=pager.txt --leak-check=full ./%ls %d %ls",
- pager_path.c_str(),
- is_quoted?L"-q":L"",
- prefix_esc.c_str());
+ // L"valgrind --track-fds=yes --log-file=pager.txt --leak-check=full ./%ls %d %ls",
+ pager_path.c_str(),
+ is_quoted?L"-q":L"",
+ prefix_esc.c_str());
escaped_separator = escape(COMPLETE_SEP_STR, 1);
diff --git a/set_color.cpp b/set_color.cpp
deleted file mode 100644
index eee45206..00000000
--- a/set_color.cpp
+++ /dev/null
@@ -1,400 +0,0 @@
-#include "config.h"
-
-
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-#include <termios.h>
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <unistd.h>
-#include <locale.h>
-
-#if HAVE_NCURSES_H
-#include <ncurses.h>
-#else
-#include <curses.h>
-#endif
-
-#if HAVE_TERMIO_H
-#include <termio.h>
-#endif
-
-#if HAVE_TERM_H
-#include <term.h>
-#elif HAVE_NCURSES_TERM_H
-#include <ncurses/term.h>
-#endif
-
-#include <errno.h>
-
-#ifdef HAVE_GETOPT_H
-#include <getopt.h>
-#endif
-
-#if HAVE_LIBINTL_H
-#include <libintl.h>
-#endif
-
-#include "fallback.h"
-#include "print_help.h"
-#include "color.h"
-
-/*
- Small utility for setting the color.
- Usage: set_color COLOR
- where COLOR is either an integer from 0 to seven or one of the strings in the col array.
-*/
-
-#define COLORS (sizeof(col)/sizeof(char *))
-
-/**
- Program name
-*/
-#define SET_COLOR "set_color"
-
-/**
- Getopt short switches for set_color
-*/
-#define GETOPT_STRING "b:hvocu"
-
-#ifdef _
-#undef _
-#endif
-
-#ifdef USE_GETTEXT
-#define _(string) gettext(string)
-#else
-#define _(string) (string)
-#endif
-
-const char *col[]=
-{
- "black",
- "red",
- "green",
- "brown",
- "yellow",
- "blue",
- "magenta",
- "purple",
- "cyan",
- "white",
- "normal"
-};
-
-const int col_idx[]=
-{
- 0,
- 1,
- 2,
- 3,
- 3,
- 4,
- 5,
- 5,
- 6,
- 7,
- 8
-};
-
-void print_colors()
-{
- size_t i;
- for (i=0; i<COLORS; i++)
- {
- printf("%s\n", col[i]);
- }
-}
-
-static void check_locale_init()
-{
- static int is_init = 0;
- if (is_init)
- return;
-
- is_init = 1;
- setlocale(LC_ALL, "");
- bindtextdomain(PACKAGE_NAME, LOCALEDIR);
- textdomain(PACKAGE_NAME);
-}
-
-/* A lot of this code is taken straight from output.cpp; it sure would be nice to factor these together. */
-
-static bool support_term256;
-static bool output_get_supports_term256(void)
-{
- return support_term256;
-}
-
-static bool term256_support_is_native(void)
-{
- /* Return YES if we think the term256 support is "native" as opposed to forced. */
- return max_colors == 256;
-}
-
-static bool write_color(char *todo, unsigned char idx, bool is_fg)
-{
- bool result = false;
- if (idx < 16 || term256_support_is_native())
- {
- /* Use tparm */
- putp(tparm(todo, idx));
- result = true;
- }
- else
- {
- /* We are attempting to bypass the term here. Generate the ANSI escape sequence ourself. */
- char stridx[128];
- format_long_safe(stridx, (long)idx);
- char buff[128] = "\x1b[";
- strcat(buff, is_fg ? "38;5;" : "48;5;");
- strcat(buff, stridx);
- strcat(buff, "m");
- write_loop(STDOUT_FILENO, buff, strlen(buff));
- result = true;
- }
- return result;
-}
-
-static bool write_foreground_color(unsigned char idx)
-{
- if (set_a_foreground && set_a_foreground[0])
- {
- return write_color(set_a_foreground, idx, true);
- }
- else if (set_foreground && set_foreground[0])
- {
- return write_color(set_foreground, idx, true);
- }
- else
- {
- return false;
- }
-}
-
-static bool write_background_color(unsigned char idx)
-{
- if (set_a_background && set_a_background[0])
- {
- return write_color(set_a_background, idx, false);
- }
- else if (set_background && set_background[0])
- {
- return write_color(set_background, idx, false);
- }
- else
- {
- return false;
- }
-}
-
-static unsigned char index_for_color(rgb_color_t c)
-{
- if (c.is_named() || ! output_get_supports_term256())
- {
- return c.to_name_index();
- }
- else
- {
- return c.to_term256_index();
- }
-}
-
-
-int main(int argc, char **argv)
-{
- /* Some code passes variables to set_color that don't exist, like $fish_user_whatever. As a hack, quietly return failure. */
- if (argc <= 1)
- return EXIT_FAILURE;
-
- char *bgcolor=0;
- char *fgcolor=0;
- bool bold=false;
- bool underline=false;
-
- while (1)
- {
- static struct option
- long_options[] =
- {
- {
- "background", required_argument, 0, 'b'
- }
- ,
- {
- "help", no_argument, 0, 'h'
- }
- ,
- {
- "bold", no_argument, 0, 'o'
- }
- ,
- {
- "underline", no_argument, 0, 'u'
- }
- ,
- {
- "version", no_argument, 0, 'v'
- }
- ,
- {
- "print-colors", no_argument, 0, 'c'
- }
- ,
- {
- 0, 0, 0, 0
- }
- }
- ;
-
- int opt_index = 0;
-
- int opt = getopt_long(argc,
- argv,
- GETOPT_STRING,
- long_options,
- &opt_index);
-
- if (opt == -1)
- break;
-
- switch (opt)
- {
- case 0:
- break;
-
- case 'b':
- bgcolor = optarg;
- break;
- case 'h':
- print_help(argv[0], 1);
- exit(0);
-
- case 'o':
- bold=true;
- break;
-
- case 'u':
- underline=true;
- break;
-
- case 'v':
- check_locale_init();
- fprintf(stderr, _("%s, version %s\n"), SET_COLOR, PACKAGE_VERSION);
- exit(0);
-
- case 'c':
- print_colors();
- exit(0);
-
- case '?':
- return 1;
-
- }
-
- }
-
- switch (argc-optind)
- {
- case 0:
-// printf( "no fg\n" );
- break;
-
- case 1:
- fgcolor=argv[optind];
-// printf( "fg %s\n", fgcolor );
- break;
-
- default:
- check_locale_init();
- printf(_("%s: Too many arguments\n"), SET_COLOR);
- return 1;
- }
-
- /* Infer term256 support */
- char *fish_term256 = getenv("fish_term256");
- if (fish_term256)
- {
- support_term256 = from_string<bool>(fish_term256);
- }
- else
- {
- const char *term = getenv("TERM");
- support_term256 = term && strstr(term, "256color");
- }
-
- if (!fgcolor && !bgcolor && !bold && !underline)
- {
- check_locale_init();
- fprintf(stderr, _("%s: Expected an argument\n"), SET_COLOR);
- print_help(argv[0], 2);
- return 1;
- }
-
- rgb_color_t fg = rgb_color_t(fgcolor ? fgcolor : "");
- if (fgcolor && fg.is_none())
- {
- check_locale_init();
- fprintf(stderr, _("%s: Unknown color '%s'\n"), SET_COLOR, fgcolor);
- return 1;
- }
-
- rgb_color_t bg = rgb_color_t(bgcolor ? bgcolor : "");
- if (bgcolor && bg.is_none())
- {
- check_locale_init();
- fprintf(stderr, _("%s: Unknown color '%s'\n"), SET_COLOR, bgcolor);
- return 1;
- }
-
- setupterm(0, STDOUT_FILENO, 0);
-
- if (bold)
- {
- if (enter_bold_mode)
- putp(enter_bold_mode);
- }
-
- if (underline)
- {
- if (enter_underline_mode)
- putp(enter_underline_mode);
- }
-
- if (bgcolor)
- {
- if (bg.is_normal())
- {
- write_background_color(0);
- putp(tparm(exit_attribute_mode));
- }
- }
-
- if (fgcolor)
- {
- if (fg.is_normal())
- {
- write_foreground_color(0);
- putp(tparm(exit_attribute_mode));
- }
- else
- {
- write_foreground_color(index_for_color(fg));
- }
- }
-
- if (bgcolor)
- {
- if (! bg.is_normal())
- {
- write_background_color(index_for_color(bg));
- }
- }
-
- if (del_curterm(cur_term) == ERR)
- {
- fprintf(stderr, "%s", _("Error while closing terminfo"));
- }
-
-}