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

Side by Side Diff: runtime/bin/stdio_linux.cc

Issue 177863010: Don't report hasTerminal, if term-size is (0,0). (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 9 months 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "platform/globals.h" 5 #include "platform/globals.h"
6 #if defined(TARGET_OS_LINUX) 6 #if defined(TARGET_OS_LINUX)
7 7
8 #include <errno.h> // NOLINT 8 #include <errno.h> // NOLINT
9 #include <sys/ioctl.h> // NOLINT 9 #include <sys/ioctl.h> // NOLINT
10 #include <termios.h> // NOLINT 10 #include <termios.h> // NOLINT
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 } else { 60 } else {
61 term.c_lflag &= ~(ICANON); 61 term.c_lflag &= ~(ICANON);
62 } 62 }
63 tcsetattr(STDIN_FILENO, TCSANOW, &term); 63 tcsetattr(STDIN_FILENO, TCSANOW, &term);
64 } 64 }
65 65
66 66
67 bool Stdout::GetTerminalSize(int size[2]) { 67 bool Stdout::GetTerminalSize(int size[2]) {
68 struct winsize w; 68 struct winsize w;
69 if (TEMP_FAILURE_RETRY_BLOCK_SIGNALS( 69 if (TEMP_FAILURE_RETRY_BLOCK_SIGNALS(
70 ioctl(STDOUT_FILENO, TIOCGWINSZ, &w) != 0)) { 70 ioctl(STDOUT_FILENO, TIOCGWINSZ, &w) == 0) &&
71 return false; 71 (w.ws_col != 0 || w.ws_row != 0)) {
72 size[0] = w.ws_col;
73 size[1] = w.ws_row;
74 return true;
72 } 75 }
73 size[0] = w.ws_col; 76 return false;
74 size[1] = w.ws_row;
75 return true;
76 } 77 }
77 78
78 } // namespace bin 79 } // namespace bin
79 } // namespace dart 80 } // namespace dart
80 81
81 #endif // defined(TARGET_OS_LINUX) 82 #endif // defined(TARGET_OS_LINUX)
82 83
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698