summaryrefslogtreecommitdiffstats
path: root/app/gfx
diff options
context:
space:
mode:
authorakalin@chromium.org <akalin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-16 10:32:04 +0000
committerakalin@chromium.org <akalin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-16 10:32:04 +0000
commitd80033e69d9542605fed21da06601f8201da6618 (patch)
treea38c7f88776664f80679d181baf1c1ad266d857d /app/gfx
parent185046805f294b0294311d09a3fe75f52e4554d8 (diff)
downloadchromium_src-d80033e69d9542605fed21da06601f8201da6618.zip
chromium_src-d80033e69d9542605fed21da06601f8201da6618.tar.gz
chromium_src-d80033e69d9542605fed21da06601f8201da6618.tar.bz2
Made sync code build and pass unit tests on OS X.
Major changes: - Moved sync_setup_{flow,wizard} to sync directory. - Made browser_with_test_window_test compile on non-Windows platform. - Moved localized contents font util functions to app/. BUG=23073 TEST=trybot Committed: http://src.chromium.org/viewvc/chrome?view=rev&revision=29253 Committed: http://src.chromium.org/viewvc/chrome?view=rev&revision=29255 Committed: http://src.chromium.org/viewvc/chrome?view=rev&revision=29258 Review URL: http://codereview.chromium.org/279004 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@29263 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'app/gfx')
-rw-r--r--app/gfx/font_util.cc39
-rw-r--r--app/gfx/font_util.h29
2 files changed, 68 insertions, 0 deletions
diff --git a/app/gfx/font_util.cc b/app/gfx/font_util.cc
new file mode 100644
index 0000000..278677c
--- /dev/null
+++ b/app/gfx/font_util.cc
@@ -0,0 +1,39 @@
+// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "app/gfx/font_util.h"
+
+#include "app/gfx/font.h"
+#include "app/l10n_util.h"
+#include "base/logging.h"
+
+namespace gfx {
+
+int GetLocalizedContentsWidthForFont(int col_resource_id,
+ const gfx::Font& font) {
+ double chars = 0;
+ StringToDouble(WideToUTF8(l10n_util::GetString(col_resource_id)), &chars);
+ int width = font.GetExpectedTextWidth(static_cast<int>(chars));
+ DCHECK(width > 0);
+ return width;
+}
+
+int GetLocalizedContentsHeightForFont(int row_resource_id,
+ const gfx::Font& font) {
+ double lines = 0;
+ StringToDouble(WideToUTF8(l10n_util::GetString(row_resource_id)), &lines);
+ int height = static_cast<int>(font.height() * lines);
+ DCHECK(height > 0);
+ return height;
+}
+
+gfx::Size GetLocalizedContentsSizeForFont(int col_resource_id,
+ int row_resource_id,
+ const gfx::Font& font) {
+ return gfx::Size(GetLocalizedContentsWidthForFont(col_resource_id, font),
+ GetLocalizedContentsHeightForFont(row_resource_id, font));
+}
+
+} // namespace gfx
+
diff --git a/app/gfx/font_util.h b/app/gfx/font_util.h
new file mode 100644
index 0000000..36bc693
--- /dev/null
+++ b/app/gfx/font_util.h
@@ -0,0 +1,29 @@
+// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef APP_GFX_FONT_UTIL_H_
+#define APP_GFX_FONT_UTIL_H_
+
+#include "base/gfx/size.h"
+
+namespace gfx {
+
+class Font;
+
+// Returns the preferred size of the contents view of a window based on
+// its localized size data and the given font. The width in cols is held in a
+// localized string resource identified by |col_resource_id|, the height in the
+// same fashion.
+int GetLocalizedContentsWidthForFont(int col_resource_id,
+ const gfx::Font& font);
+int GetLocalizedContentsHeightForFont(int row_resource_id,
+ const gfx::Font& font);
+gfx::Size GetLocalizedContentsSizeForFont(int col_resource_id,
+ int row_resource_id,
+ const gfx::Font& font);
+
+} // namespace gfx
+
+#endif // APP_GFX_FONT_UTIL_H_
+