Home | History | Annotate | Download | only in views
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #include "ui/views/debug_utils.h"
      6 
      7 #include <ostream>
      8 
      9 #include "base/logging.h"
     10 #include "base/strings/utf_string_conversions.h"
     11 #include "ui/views/view.h"
     12 
     13 namespace views {
     14 namespace {
     15 void PrintViewHierarchyImp(const View* view,
     16                            int indent,
     17                            std::wostringstream* out) {
     18   int ind = indent;
     19   while (ind-- > 0)
     20     *out << L' ';
     21   *out << base::UTF8ToWide(view->GetClassName());
     22   *out << L' ';
     23   *out << view->id();
     24   *out << L' ';
     25   *out << view->x() << L"," << view->y() << L",";
     26   *out << view->bounds().right() << L"," << view->bounds().bottom();
     27   *out << L' ';
     28   *out << view;
     29   *out << L'\n';
     30 
     31   for (int i = 0, count = view->child_count(); i < count; ++i)
     32     PrintViewHierarchyImp(view->child_at(i), indent + 2, out);
     33 }
     34 
     35 void PrintFocusHierarchyImp(const View* view,
     36                             int indent,
     37                             std::wostringstream* out) {
     38   int ind = indent;
     39   while (ind-- > 0)
     40     *out << L' ';
     41   *out << base::UTF8ToWide(view->GetClassName());
     42   *out << L' ';
     43   *out << view->id();
     44   *out << L' ';
     45   *out << view->GetClassName();
     46   *out << L' ';
     47   *out << view;
     48   *out << L'\n';
     49 
     50   if (view->child_count() > 0)
     51     PrintFocusHierarchyImp(view->child_at(0), indent + 2, out);
     52 
     53   const View* next_focusable = view->GetNextFocusableView();
     54   if (next_focusable)
     55     PrintFocusHierarchyImp(next_focusable, indent, out);
     56 }
     57 }  // namespace
     58 
     59 void PrintViewHierarchy(const View* view) {
     60   std::wostringstream out;
     61   out << L"View hierarchy:\n";
     62   PrintViewHierarchyImp(view, 0, &out);
     63   // Error so users in the field can generate and upload logs.
     64   LOG(ERROR) << out.str();
     65 }
     66 
     67 void PrintFocusHierarchy(const View* view) {
     68   std::wostringstream out;
     69   out << L"Focus hierarchy:\n";
     70   PrintFocusHierarchyImp(view, 0, &out);
     71   // Error so users in the field can generate and upload logs.
     72   LOG(ERROR) << out.str();
     73 }
     74 
     75 }  // namespace views
     76