You are here

function search_expand_cjk in Drupal 4

Same name and namespace in other branches
  1. 8 core/modules/search/search.module \search_expand_cjk()
  2. 5 modules/search/search.module \search_expand_cjk()
  3. 6 modules/search/search.module \search_expand_cjk()
  4. 7 modules/search/search.module \search_expand_cjk()
  5. 9 core/modules/search/search.module \search_expand_cjk()

Basic CJK tokenizer. Simply splits a string into consecutive, overlapping sequences of characters ('minimum_word_size' long).

1 string reference to 'search_expand_cjk'
search_simplify in modules/search.module
Simplifies a string according to indexing rules.

File

modules/search.module, line 370
Enables site-wide keyword searching.

Code

function search_expand_cjk($matches) {
  $min = variable_get('minimum_word_size', 3);
  $str = $matches[0];
  $l = drupal_strlen($str);

  // Passthrough short words
  if ($l <= $min) {
    return ' ' . $str . ' ';
  }
  $tokens = ' ';

  // FIFO queue of characters
  $chars = array();

  // Begin loop
  for ($i = 0; $i < $l; ++$i) {

    // Grab next character
    $current = drupal_substr($str, 0, 1);
    $str = substr($str, strlen($current));
    $chars[] = $current;
    if ($i >= $min - 1) {
      $tokens .= implode('', $chars) . ' ';
      array_shift($chars);
    }
  }
  return $tokens;
}