Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(547)

Unified Diff: runtime/bin/stdio_android.cc

Issue 102123010: Add getter for hasTerminal, terminalColumns and terminalLines on stdout. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Add include of thread.h and fix io_patch. Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « runtime/bin/stdio.cc ('k') | runtime/bin/stdio_linux.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/bin/stdio_android.cc
diff --git a/runtime/bin/stdin_android.cc b/runtime/bin/stdio_android.cc
similarity index 61%
rename from runtime/bin/stdin_android.cc
rename to runtime/bin/stdio_android.cc
index a1a4d63fda307c699e5950d36c9e303cc5b352b3..b14dad823f7e3e5b42aa71d1468d5bb64395f5b8 100644
--- a/runtime/bin/stdin_android.cc
+++ b/runtime/bin/stdio_android.cc
@@ -5,61 +5,76 @@
#include "platform/globals.h"
#if defined(TARGET_OS_ANDROID)
+#include <errno.h> // NOLINT
+#include <sys/ioctl.h> // NOLINT
#include <termios.h> // NOLINT
-#include "bin/stdin.h"
+#include "bin/stdio.h"
#include "bin/fdutils.h"
+#include "bin/signal_blocker.h"
namespace dart {
namespace bin {
int Stdin::ReadByte() {
- FDUtils::SetBlocking(fileno(stdin));
+ FDUtils::SetBlocking(STDIN_FILENO);
int c = getchar();
if (c == EOF) {
c = -1;
}
- FDUtils::SetNonBlocking(fileno(stdin));
+ FDUtils::SetNonBlocking(STDIN_FILENO);
return c;
}
bool Stdin::GetEchoMode() {
struct termios term;
- tcgetattr(fileno(stdin), &term);
+ tcgetattr(STDIN_FILENO, &term);
return (term.c_lflag & ECHO) != 0;
}
void Stdin::SetEchoMode(bool enabled) {
struct termios term;
- tcgetattr(fileno(stdin), &term);
+ tcgetattr(STDIN_FILENO, &term);
if (enabled) {
term.c_lflag |= ECHO|ECHONL;
} else {
term.c_lflag &= ~(ECHO|ECHONL);
}
- tcsetattr(fileno(stdin), TCSANOW, &term);
+ tcsetattr(STDIN_FILENO, TCSANOW, &term);
}
bool Stdin::GetLineMode() {
struct termios term;
- tcgetattr(fileno(stdin), &term);
+ tcgetattr(STDIN_FILENO, &term);
return (term.c_lflag & ICANON) != 0;
}
void Stdin::SetLineMode(bool enabled) {
struct termios term;
- tcgetattr(fileno(stdin), &term);
+ tcgetattr(STDIN_FILENO, &term);
if (enabled) {
term.c_lflag |= ICANON;
} else {
term.c_lflag &= ~(ICANON);
}
- tcsetattr(fileno(stdin), TCSANOW, &term);
+ tcsetattr(STDIN_FILENO, TCSANOW, &term);
+}
+
+
+bool Stdout::GetTerminalSize(int size[2]) {
+ struct winsize w;
+ if (TEMP_FAILURE_RETRY_BLOCK_SIGNALS(
+ ioctl(STDOUT_FILENO, TIOCGWINSZ, &w) != 0)) {
+ return false;
+ }
+ size[0] = w.ws_col;
+ size[1] = w.ws_row;
+ return true;
}
} // namespace bin
« no previous file with comments | « runtime/bin/stdio.cc ('k') | runtime/bin/stdio_linux.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698