OLD | NEW |
| (Empty) |
1 // Copyright 2013 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 "chrome/browser/chromeos/extensions/file_manager/mime_util.h" | |
6 | |
7 #include <utility> | |
8 #include "base/files/file_path.h" | |
9 #include "base/strings/string_util.h" | |
10 #include "net/base/mime_util.h" | |
11 | |
12 namespace file_manager { | |
13 namespace util { | |
14 | |
15 std::string GetMimeTypeForPath(const base::FilePath& file_path) { | |
16 const base::FilePath::StringType file_extension = | |
17 StringToLowerASCII(file_path.Extension()); | |
18 | |
19 // TODO(thorogood): Rearchitect this call so it can run on the File thread; | |
20 // GetMimeTypeFromFile requires this on Linux. Right now, we use | |
21 // Chrome-level knowledge only. | |
22 std::string mime_type; | |
23 if (file_extension.empty() || | |
24 !net::GetWellKnownMimeTypeFromExtension(file_extension.substr(1), | |
25 &mime_type)) { | |
26 // If the file doesn't have an extension or its mime-type cannot be | |
27 // determined, then indicate that it has the empty mime-type. This will | |
28 // only be matched if the Web Intents accepts "*" or "*/*". | |
29 return ""; | |
30 } else { | |
31 return mime_type; | |
32 } | |
33 } | |
34 | |
35 } // namespace util | |
36 } // namespace file_manager | |
OLD | NEW |