| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "ui/base/ime/win/imm32_manager.h" | 5 #include "ui/base/ime/win/imm32_manager.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <memory> | 9 #include <memory> |
| 10 | 10 |
| (...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 276 void IMM32Manager::CompleteComposition(HWND window_handle, HIMC imm_context) { | 276 void IMM32Manager::CompleteComposition(HWND window_handle, HIMC imm_context) { |
| 277 // We have to confirm there is an ongoing composition before completing it. | 277 // We have to confirm there is an ongoing composition before completing it. |
| 278 // This is for preventing some IMEs from getting confused while completing an | 278 // This is for preventing some IMEs from getting confused while completing an |
| 279 // ongoing composition even if they do not have any ongoing compositions.) | 279 // ongoing composition even if they do not have any ongoing compositions.) |
| 280 if (is_composing_) { | 280 if (is_composing_) { |
| 281 ::ImmNotifyIME(imm_context, NI_COMPOSITIONSTR, CPS_COMPLETE, 0); | 281 ::ImmNotifyIME(imm_context, NI_COMPOSITIONSTR, CPS_COMPLETE, 0); |
| 282 ResetComposition(window_handle); | 282 ResetComposition(window_handle); |
| 283 } | 283 } |
| 284 } | 284 } |
| 285 | 285 |
| 286 void IMM32Manager::GetCompositionInfo(HIMC imm_context, LPARAM lparam, | 286 void IMM32Manager::GetCompositionInfo(HIMC imm_context, |
| 287 CompositionText* composition) { | 287 LPARAM lparam, |
| 288 CompositionText* composition) { |
| 288 // We only care about GCS_COMPATTR, GCS_COMPCLAUSE and GCS_CURSORPOS, and | 289 // We only care about GCS_COMPATTR, GCS_COMPCLAUSE and GCS_CURSORPOS, and |
| 289 // convert them into underlines and selection range respectively. | 290 // convert them into underlines and selection range respectively. |
| 290 composition->underlines.clear(); | 291 composition->underlines.clear(); |
| 291 | 292 |
| 292 int length = static_cast<int>(composition->text.length()); | 293 int length = static_cast<int>(composition->text.length()); |
| 293 | 294 |
| 294 // Find out the range selected by the user. | 295 // Find out the range selected by the user. |
| 295 int target_start = length; | 296 int target_start = length; |
| 296 int target_end = length; | 297 int target_end = length; |
| 297 if (lparam & GCS_COMPATTR) | 298 if (lparam & GCS_COMPATTR) |
| (...skipping 14 matching lines...) Expand all Loading... |
| 312 composition->selection = gfx::Range(0); | 313 composition->selection = gfx::Range(0); |
| 313 } | 314 } |
| 314 | 315 |
| 315 // Retrieve the clause segmentations and convert them to underlines. | 316 // Retrieve the clause segmentations and convert them to underlines. |
| 316 if (lparam & GCS_COMPCLAUSE) { | 317 if (lparam & GCS_COMPCLAUSE) { |
| 317 GetCompositionUnderlines(imm_context, target_start, target_end, | 318 GetCompositionUnderlines(imm_context, target_start, target_end, |
| 318 &composition->underlines); | 319 &composition->underlines); |
| 319 } | 320 } |
| 320 | 321 |
| 321 // Set default underlines in case there is no clause information. | 322 // Set default underlines in case there is no clause information. |
| 322 if (!composition->underlines.size()) { | 323 if (!composition->underlines.empty()) |
| 323 CompositionUnderline underline; | 324 return; |
| 324 underline.color = SK_ColorBLACK; | 325 |
| 325 underline.background_color = SK_ColorTRANSPARENT; | 326 CompositionUnderline underline; |
| 326 if (target_start > 0) { | 327 underline.color = SK_ColorBLACK; |
| 327 underline.start_offset = 0U; | 328 underline.background_color = SK_ColorTRANSPARENT; |
| 328 underline.end_offset = static_cast<uint32_t>(target_start); | 329 if (target_start > 0) { |
| 329 underline.thick = false; | 330 underline.start_offset = 0U; |
| 330 composition->underlines.push_back(underline); | 331 underline.end_offset = static_cast<uint32_t>(target_start); |
| 331 } | 332 underline.thick = false; |
| 332 if (target_end > target_start) { | 333 composition->underlines.push_back(underline); |
| 333 underline.start_offset = static_cast<uint32_t>(target_start); | 334 } |
| 334 underline.end_offset = static_cast<uint32_t>(target_end); | 335 if (target_end > target_start) { |
| 335 underline.thick = true; | 336 underline.start_offset = static_cast<uint32_t>(target_start); |
| 336 composition->underlines.push_back(underline); | 337 underline.end_offset = static_cast<uint32_t>(target_end); |
| 337 } | 338 underline.thick = true; |
| 338 if (target_end < length) { | 339 composition->underlines.push_back(underline); |
| 339 underline.start_offset = static_cast<uint32_t>(target_end); | 340 } |
| 340 underline.end_offset = static_cast<uint32_t>(length); | 341 if (target_end < length) { |
| 341 underline.thick = false; | 342 underline.start_offset = static_cast<uint32_t>(target_end); |
| 342 composition->underlines.push_back(underline); | 343 underline.end_offset = static_cast<uint32_t>(length); |
| 343 } | 344 underline.thick = false; |
| 345 composition->underlines.push_back(underline); |
| 344 } | 346 } |
| 345 } | 347 } |
| 346 | 348 |
| 347 bool IMM32Manager::GetString(HIMC imm_context, | 349 bool IMM32Manager::GetString(HIMC imm_context, |
| 348 WPARAM lparam, | 350 WPARAM lparam, |
| 349 int type, | 351 int type, |
| 350 base::string16* result) { | 352 base::string16* result) { |
| 351 if (!(lparam & type)) | 353 if (!(lparam & type)) |
| 352 return false; | 354 return false; |
| 353 LONG string_size = ::ImmGetCompositionString(imm_context, type, NULL, 0); | 355 LONG string_size = ::ImmGetCompositionString(imm_context, type, NULL, 0); |
| (...skipping 260 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 614 | IME_CMODE_KATAKANA | 616 | IME_CMODE_KATAKANA |
| 615 | IME_CMODE_FULLSHAPE); | 617 | IME_CMODE_FULLSHAPE); |
| 616 break; | 618 break; |
| 617 default: | 619 default: |
| 618 *open = FALSE; | 620 *open = FALSE; |
| 619 break; | 621 break; |
| 620 } | 622 } |
| 621 } | 623 } |
| 622 | 624 |
| 623 } // namespace ui | 625 } // namespace ui |
| OLD | NEW |