⌈⌋ ⎇ branch:  Bitrhythm


Hex Artifact Content

Artifact 67d7a4b5a4580555f316a9e92b2d8476e4e58c57433bb3533244bfa6b59e9bb9:


0000: 2f 2a 0a 20 2a 20 73 65 61 72 63 68 74 6f 6f 6c  /*. * searchtool
0010: 73 2e 6a 73 0a 20 2a 20 7e 7e 7e 7e 7e 7e 7e 7e  s.js. * ~~~~~~~~
0020: 7e 7e 7e 7e 7e 7e 7e 7e 0a 20 2a 0a 20 2a 20 53  ~~~~~~~~. *. * S
0030: 70 68 69 6e 78 20 4a 61 76 61 53 63 72 69 70 74  phinx JavaScript
0040: 20 75 74 69 6c 69 74 69 65 73 20 66 6f 72 20 74   utilities for t
0050: 68 65 20 66 75 6c 6c 2d 74 65 78 74 20 73 65 61  he full-text sea
0060: 72 63 68 2e 0a 20 2a 0a 20 2a 20 3a 63 6f 70 79  rch.. *. * :copy
0070: 72 69 67 68 74 3a 20 43 6f 70 79 72 69 67 68 74  right: Copyright
0080: 20 32 30 30 37 2d 32 30 32 31 20 62 79 20 74 68   2007-2021 by th
0090: 65 20 53 70 68 69 6e 78 20 74 65 61 6d 2c 20 73  e Sphinx team, s
00a0: 65 65 20 41 55 54 48 4f 52 53 2e 0a 20 2a 20 3a  ee AUTHORS.. * :
00b0: 6c 69 63 65 6e 73 65 3a 20 42 53 44 2c 20 73 65  license: BSD, se
00c0: 65 20 4c 49 43 45 4e 53 45 20 66 6f 72 20 64 65  e LICENSE for de
00d0: 74 61 69 6c 73 2e 0a 20 2a 0a 20 2a 2f 0a 0a 69  tails.. *. */..i
00e0: 66 20 28 21 53 63 6f 72 65 72 29 20 7b 0a 20 20  f (!Scorer) {.  
00f0: 2f 2a 2a 0a 20 20 20 2a 20 53 69 6d 70 6c 65 20  /**.   * Simple 
0100: 72 65 73 75 6c 74 20 73 63 6f 72 69 6e 67 20 63  result scoring c
0110: 6f 64 65 2e 0a 20 20 20 2a 2f 0a 20 20 76 61 72  ode..   */.  var
0120: 20 53 63 6f 72 65 72 20 3d 20 7b 0a 20 20 20 20   Scorer = {.    
0130: 2f 2f 20 49 6d 70 6c 65 6d 65 6e 74 20 74 68 65  // Implement the
0140: 20 66 6f 6c 6c 6f 77 69 6e 67 20 66 75 6e 63 74   following funct
0150: 69 6f 6e 20 74 6f 20 66 75 72 74 68 65 72 20 74  ion to further t
0160: 77 65 61 6b 20 74 68 65 20 73 63 6f 72 65 20 66  weak the score f
0170: 6f 72 20 65 61 63 68 20 72 65 73 75 6c 74 0a 20  or each result. 
0180: 20 20 20 2f 2f 20 54 68 65 20 66 75 6e 63 74 69     // The functi
0190: 6f 6e 20 74 61 6b 65 73 20 61 20 72 65 73 75 6c  on takes a resul
01a0: 74 20 61 72 72 61 79 20 5b 66 69 6c 65 6e 61 6d  t array [filenam
01b0: 65 2c 20 74 69 74 6c 65 2c 20 61 6e 63 68 6f 72  e, title, anchor
01c0: 2c 20 64 65 73 63 72 2c 20 73 63 6f 72 65 5d 0a  , descr, score].
01d0: 20 20 20 20 2f 2f 20 61 6e 64 20 72 65 74 75 72      // and retur
01e0: 6e 73 20 74 68 65 20 6e 65 77 20 73 63 6f 72 65  ns the new score
01f0: 2e 0a 20 20 20 20 2f 2a 0a 20 20 20 20 73 63 6f  ..    /*.    sco
0200: 72 65 3a 20 66 75 6e 63 74 69 6f 6e 28 72 65 73  re: function(res
0210: 75 6c 74 29 20 7b 0a 20 20 20 20 20 20 72 65 74  ult) {.      ret
0220: 75 72 6e 20 72 65 73 75 6c 74 5b 34 5d 3b 0a 20  urn result[4];. 
0230: 20 20 20 7d 2c 0a 20 20 20 20 2a 2f 0a 0a 20 20     },.    */..  
0240: 20 20 2f 2f 20 71 75 65 72 79 20 6d 61 74 63 68    // query match
0250: 65 73 20 74 68 65 20 66 75 6c 6c 20 6e 61 6d 65  es the full name
0260: 20 6f 66 20 61 6e 20 6f 62 6a 65 63 74 0a 20 20   of an object.  
0270: 20 20 6f 62 6a 4e 61 6d 65 4d 61 74 63 68 3a 20    objNameMatch: 
0280: 31 31 2c 0a 20 20 20 20 2f 2f 20 6f 72 20 6d 61  11,.    // or ma
0290: 74 63 68 65 73 20 69 6e 20 74 68 65 20 6c 61 73  tches in the las
02a0: 74 20 64 6f 74 74 65 64 20 70 61 72 74 20 6f 66  t dotted part of
02b0: 20 74 68 65 20 6f 62 6a 65 63 74 20 6e 61 6d 65   the object name
02c0: 0a 20 20 20 20 6f 62 6a 50 61 72 74 69 61 6c 4d  .    objPartialM
02d0: 61 74 63 68 3a 20 36 2c 0a 20 20 20 20 2f 2f 20  atch: 6,.    // 
02e0: 41 64 64 69 74 69 76 65 20 73 63 6f 72 65 73 20  Additive scores 
02f0: 64 65 70 65 6e 64 69 6e 67 20 6f 6e 20 74 68 65  depending on the
0300: 20 70 72 69 6f 72 69 74 79 20 6f 66 20 74 68 65   priority of the
0310: 20 6f 62 6a 65 63 74 0a 20 20 20 20 6f 62 6a 50   object.    objP
0320: 72 69 6f 3a 20 7b 30 3a 20 20 31 35 2c 20 20 20  rio: {0:  15,   
0330: 2f 2f 20 75 73 65 64 20 74 6f 20 62 65 20 69 6d  // used to be im
0340: 70 6f 72 74 61 6e 74 52 65 73 75 6c 74 73 0a 20  portantResults. 
0350: 20 20 20 20 20 20 20 20 20 20 20 20 20 31 3a 20               1: 
0360: 20 35 2c 20 20 20 2f 2f 20 75 73 65 64 20 74 6f   5,   // used to
0370: 20 62 65 20 6f 62 6a 65 63 74 52 65 73 75 6c 74   be objectResult
0380: 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  s.              
0390: 32 3a 20 2d 35 7d 2c 20 20 2f 2f 20 75 73 65 64  2: -5},  // used
03a0: 20 74 6f 20 62 65 20 75 6e 69 6d 70 6f 72 74 61   to be unimporta
03b0: 6e 74 52 65 73 75 6c 74 73 0a 20 20 20 20 2f 2f  ntResults.    //
03c0: 20 20 55 73 65 64 20 77 68 65 6e 20 74 68 65 20    Used when the 
03d0: 70 72 69 6f 72 69 74 79 20 69 73 20 6e 6f 74 20  priority is not 
03e0: 69 6e 20 74 68 65 20 6d 61 70 70 69 6e 67 2e 0a  in the mapping..
03f0: 20 20 20 20 6f 62 6a 50 72 69 6f 44 65 66 61 75      objPrioDefau
0400: 6c 74 3a 20 30 2c 0a 0a 20 20 20 20 2f 2f 20 71  lt: 0,..    // q
0410: 75 65 72 79 20 66 6f 75 6e 64 20 69 6e 20 74 69  uery found in ti
0420: 74 6c 65 0a 20 20 20 20 74 69 74 6c 65 3a 20 31  tle.    title: 1
0430: 35 2c 0a 20 20 20 20 70 61 72 74 69 61 6c 54 69  5,.    partialTi
0440: 74 6c 65 3a 20 37 2c 0a 20 20 20 20 2f 2f 20 71  tle: 7,.    // q
0450: 75 65 72 79 20 66 6f 75 6e 64 20 69 6e 20 74 65  uery found in te
0460: 72 6d 73 0a 20 20 20 20 74 65 72 6d 3a 20 35 2c  rms.    term: 5,
0470: 0a 20 20 20 20 70 61 72 74 69 61 6c 54 65 72 6d  .    partialTerm
0480: 3a 20 32 0a 20 20 7d 3b 0a 7d 0a 0a 69 66 20 28  : 2.  };.}..if (
0490: 21 73 70 6c 69 74 51 75 65 72 79 29 20 7b 0a 20  !splitQuery) {. 
04a0: 20 66 75 6e 63 74 69 6f 6e 20 73 70 6c 69 74 51   function splitQ
04b0: 75 65 72 79 28 71 75 65 72 79 29 20 7b 0a 20 20  uery(query) {.  
04c0: 20 20 72 65 74 75 72 6e 20 71 75 65 72 79 2e 73    return query.s
04d0: 70 6c 69 74 28 2f 5c 73 2b 2f 29 3b 0a 20 20 7d  plit(/\s+/);.  }
04e0: 0a 7d 0a 0a 2f 2a 2a 0a 20 2a 20 53 65 61 72 63  .}../**. * Searc
04f0: 68 20 4d 6f 64 75 6c 65 0a 20 2a 2f 0a 76 61 72  h Module. */.var
0500: 20 53 65 61 72 63 68 20 3d 20 7b 0a 0a 20 20 5f   Search = {..  _
0510: 69 6e 64 65 78 20 3a 20 6e 75 6c 6c 2c 0a 20 20  index : null,.  
0520: 5f 71 75 65 75 65 64 5f 71 75 65 72 79 20 3a 20  _queued_query : 
0530: 6e 75 6c 6c 2c 0a 20 20 5f 70 75 6c 73 65 5f 73  null,.  _pulse_s
0540: 74 61 74 75 73 20 3a 20 2d 31 2c 0a 0a 20 20 68  tatus : -1,..  h
0550: 74 6d 6c 54 6f 54 65 78 74 20 3a 20 66 75 6e 63  tmlToText : func
0560: 74 69 6f 6e 28 68 74 6d 6c 53 74 72 69 6e 67 29  tion(htmlString)
0570: 20 7b 0a 20 20 20 20 20 20 76 61 72 20 76 69 72   {.      var vir
0580: 74 75 61 6c 44 6f 63 75 6d 65 6e 74 20 3d 20 64  tualDocument = d
0590: 6f 63 75 6d 65 6e 74 2e 69 6d 70 6c 65 6d 65 6e  ocument.implemen
05a0: 74 61 74 69 6f 6e 2e 63 72 65 61 74 65 48 54 4d  tation.createHTM
05b0: 4c 44 6f 63 75 6d 65 6e 74 28 27 76 69 72 74 75  LDocument('virtu
05c0: 61 6c 27 29 3b 0a 20 20 20 20 20 20 76 61 72 20  al');.      var 
05d0: 68 74 6d 6c 45 6c 65 6d 65 6e 74 20 3d 20 24 28  htmlElement = $(
05e0: 68 74 6d 6c 53 74 72 69 6e 67 2c 20 76 69 72 74  htmlString, virt
05f0: 75 61 6c 44 6f 63 75 6d 65 6e 74 29 3b 0a 20 20  ualDocument);.  
0600: 20 20 20 20 68 74 6d 6c 45 6c 65 6d 65 6e 74 2e      htmlElement.
0610: 66 69 6e 64 28 27 2e 68 65 61 64 65 72 6c 69 6e  find('.headerlin
0620: 6b 27 29 2e 72 65 6d 6f 76 65 28 29 3b 0a 20 20  k').remove();.  
0630: 20 20 20 20 64 6f 63 43 6f 6e 74 65 6e 74 20 3d      docContent =
0640: 20 68 74 6d 6c 45 6c 65 6d 65 6e 74 2e 66 69 6e   htmlElement.fin
0650: 64 28 27 5b 72 6f 6c 65 3d 6d 61 69 6e 5d 27 29  d('[role=main]')
0660: 5b 30 5d 3b 0a 20 20 20 20 20 20 69 66 28 64 6f  [0];.      if(do
0670: 63 43 6f 6e 74 65 6e 74 20 3d 3d 3d 20 75 6e 64  cContent === und
0680: 65 66 69 6e 65 64 29 20 7b 0a 20 20 20 20 20 20  efined) {.      
0690: 20 20 20 20 63 6f 6e 73 6f 6c 65 2e 77 61 72 6e      console.warn
06a0: 28 22 43 6f 6e 74 65 6e 74 20 62 6c 6f 63 6b 20  ("Content block 
06b0: 6e 6f 74 20 66 6f 75 6e 64 2e 20 53 70 68 69 6e  not found. Sphin
06c0: 78 20 73 65 61 72 63 68 20 74 72 69 65 73 20 74  x search tries t
06d0: 6f 20 6f 62 74 61 69 6e 20 69 74 20 22 20 2b 0a  o obtain it " +.
06e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
06f0: 20 20 20 20 20 20 20 22 76 69 61 20 27 5b 72 6f         "via '[ro
0700: 6c 65 3d 6d 61 69 6e 5d 27 2e 20 43 6f 75 6c 64  le=main]'. Could
0710: 20 79 6f 75 20 63 68 65 63 6b 20 79 6f 75 72 20   you check your 
0720: 74 68 65 6d 65 20 6f 72 20 74 65 6d 70 6c 61 74  theme or templat
0730: 65 2e 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20  e.");.          
0740: 72 65 74 75 72 6e 20 22 22 3b 0a 20 20 20 20 20  return "";.     
0750: 20 7d 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20   }.      return 
0760: 64 6f 63 43 6f 6e 74 65 6e 74 2e 74 65 78 74 43  docContent.textC
0770: 6f 6e 74 65 6e 74 20 7c 7c 20 64 6f 63 43 6f 6e  ontent || docCon
0780: 74 65 6e 74 2e 69 6e 6e 65 72 54 65 78 74 3b 0a  tent.innerText;.
0790: 20 20 7d 2c 0a 0a 20 20 69 6e 69 74 20 3a 20 66    },..  init : f
07a0: 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20  unction() {.    
07b0: 20 20 76 61 72 20 70 61 72 61 6d 73 20 3d 20 24    var params = $
07c0: 2e 67 65 74 51 75 65 72 79 50 61 72 61 6d 65 74  .getQueryParamet
07d0: 65 72 73 28 29 3b 0a 20 20 20 20 20 20 69 66 20  ers();.      if 
07e0: 28 70 61 72 61 6d 73 2e 71 29 20 7b 0a 20 20 20  (params.q) {.   
07f0: 20 20 20 20 20 20 20 76 61 72 20 71 75 65 72 79         var query
0800: 20 3d 20 70 61 72 61 6d 73 2e 71 5b 30 5d 3b 0a   = params.q[0];.
0810: 20 20 20 20 20 20 20 20 20 20 24 28 27 69 6e 70            $('inp
0820: 75 74 5b 6e 61 6d 65 3d 22 71 22 5d 27 29 5b 30  ut[name="q"]')[0
0830: 5d 2e 76 61 6c 75 65 20 3d 20 71 75 65 72 79 3b  ].value = query;
0840: 0a 20 20 20 20 20 20 20 20 20 20 74 68 69 73 2e  .          this.
0850: 70 65 72 66 6f 72 6d 53 65 61 72 63 68 28 71 75  performSearch(qu
0860: 65 72 79 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  ery);.      }.  
0870: 7d 2c 0a 0a 20 20 6c 6f 61 64 49 6e 64 65 78 20  },..  loadIndex 
0880: 3a 20 66 75 6e 63 74 69 6f 6e 28 75 72 6c 29 20  : function(url) 
0890: 7b 0a 20 20 20 20 24 2e 61 6a 61 78 28 7b 74 79  {.    $.ajax({ty
08a0: 70 65 3a 20 22 47 45 54 22 2c 20 75 72 6c 3a 20  pe: "GET", url: 
08b0: 75 72 6c 2c 20 64 61 74 61 3a 20 6e 75 6c 6c 2c  url, data: null,
08c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 64 61 74  .            dat
08d0: 61 54 79 70 65 3a 20 22 73 63 72 69 70 74 22 2c  aType: "script",
08e0: 20 63 61 63 68 65 3a 20 74 72 75 65 2c 0a 20 20   cache: true,.  
08f0: 20 20 20 20 20 20 20 20 20 20 63 6f 6d 70 6c 65            comple
0900: 74 65 3a 20 66 75 6e 63 74 69 6f 6e 28 6a 71 78  te: function(jqx
0910: 68 72 2c 20 74 65 78 74 73 74 61 74 75 73 29 20  hr, textstatus) 
0920: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
0930: 69 66 20 28 74 65 78 74 73 74 61 74 75 73 20 21  if (textstatus !
0940: 3d 20 22 73 75 63 63 65 73 73 22 29 20 7b 0a 20  = "success") {. 
0950: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64                 d
0960: 6f 63 75 6d 65 6e 74 2e 67 65 74 45 6c 65 6d 65  ocument.getEleme
0970: 6e 74 42 79 49 64 28 22 73 65 61 72 63 68 69 6e  ntById("searchin
0980: 64 65 78 6c 6f 61 64 65 72 22 29 2e 73 72 63 20  dexloader").src 
0990: 3d 20 75 72 6c 3b 0a 20 20 20 20 20 20 20 20 20  = url;.         
09a0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
09b0: 20 20 20 7d 7d 29 3b 0a 20 20 7d 2c 0a 0a 20 20     }});.  },..  
09c0: 73 65 74 49 6e 64 65 78 20 3a 20 66 75 6e 63 74  setIndex : funct
09d0: 69 6f 6e 28 69 6e 64 65 78 29 20 7b 0a 20 20 20  ion(index) {.   
09e0: 20 76 61 72 20 71 3b 0a 20 20 20 20 74 68 69 73   var q;.    this
09f0: 2e 5f 69 6e 64 65 78 20 3d 20 69 6e 64 65 78 3b  ._index = index;
0a00: 0a 20 20 20 20 69 66 20 28 28 71 20 3d 20 74 68  .    if ((q = th
0a10: 69 73 2e 5f 71 75 65 75 65 64 5f 71 75 65 72 79  is._queued_query
0a20: 29 20 21 3d 3d 20 6e 75 6c 6c 29 20 7b 0a 20 20  ) !== null) {.  
0a30: 20 20 20 20 74 68 69 73 2e 5f 71 75 65 75 65 64      this._queued
0a40: 5f 71 75 65 72 79 20 3d 20 6e 75 6c 6c 3b 0a 20  _query = null;. 
0a50: 20 20 20 20 20 53 65 61 72 63 68 2e 71 75 65 72       Search.quer
0a60: 79 28 71 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 2c  y(q);.    }.  },
0a70: 0a 0a 20 20 68 61 73 49 6e 64 65 78 20 3a 20 66  ..  hasIndex : f
0a80: 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20  unction() {.    
0a90: 20 20 72 65 74 75 72 6e 20 74 68 69 73 2e 5f 69    return this._i
0aa0: 6e 64 65 78 20 21 3d 3d 20 6e 75 6c 6c 3b 0a 20  ndex !== null;. 
0ab0: 20 7d 2c 0a 0a 20 20 64 65 66 65 72 51 75 65 72   },..  deferQuer
0ac0: 79 20 3a 20 66 75 6e 63 74 69 6f 6e 28 71 75 65  y : function(que
0ad0: 72 79 29 20 7b 0a 20 20 20 20 20 20 74 68 69 73  ry) {.      this
0ae0: 2e 5f 71 75 65 75 65 64 5f 71 75 65 72 79 20 3d  ._queued_query =
0af0: 20 71 75 65 72 79 3b 0a 20 20 7d 2c 0a 0a 20 20   query;.  },..  
0b00: 73 74 6f 70 50 75 6c 73 65 20 3a 20 66 75 6e 63  stopPulse : func
0b10: 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20 20 20 74  tion() {.      t
0b20: 68 69 73 2e 5f 70 75 6c 73 65 5f 73 74 61 74 75  his._pulse_statu
0b30: 73 20 3d 20 30 3b 0a 20 20 7d 2c 0a 0a 20 20 73  s = 0;.  },..  s
0b40: 74 61 72 74 50 75 6c 73 65 20 3a 20 66 75 6e 63  tartPulse : func
0b50: 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20 69 66 20  tion() {.    if 
0b60: 28 74 68 69 73 2e 5f 70 75 6c 73 65 5f 73 74 61  (this._pulse_sta
0b70: 74 75 73 20 3e 3d 20 30 29 0a 20 20 20 20 20 20  tus >= 0).      
0b80: 20 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 66 75    return;.    fu
0b90: 6e 63 74 69 6f 6e 20 70 75 6c 73 65 28 29 20 7b  nction pulse() {
0ba0: 0a 20 20 20 20 20 20 76 61 72 20 69 3b 0a 20 20  .      var i;.  
0bb0: 20 20 20 20 53 65 61 72 63 68 2e 5f 70 75 6c 73      Search._puls
0bc0: 65 5f 73 74 61 74 75 73 20 3d 20 28 53 65 61 72  e_status = (Sear
0bd0: 63 68 2e 5f 70 75 6c 73 65 5f 73 74 61 74 75 73  ch._pulse_status
0be0: 20 2b 20 31 29 20 25 20 34 3b 0a 20 20 20 20 20   + 1) % 4;.     
0bf0: 20 76 61 72 20 64 6f 74 53 74 72 69 6e 67 20 3d   var dotString =
0c00: 20 27 27 3b 0a 20 20 20 20 20 20 66 6f 72 20 28   '';.      for (
0c10: 69 20 3d 20 30 3b 20 69 20 3c 20 53 65 61 72 63  i = 0; i < Searc
0c20: 68 2e 5f 70 75 6c 73 65 5f 73 74 61 74 75 73 3b  h._pulse_status;
0c30: 20 69 2b 2b 29 0a 20 20 20 20 20 20 20 20 64 6f   i++).        do
0c40: 74 53 74 72 69 6e 67 20 2b 3d 20 27 2e 27 3b 0a  tString += '.';.
0c50: 20 20 20 20 20 20 53 65 61 72 63 68 2e 64 6f 74        Search.dot
0c60: 73 2e 74 65 78 74 28 64 6f 74 53 74 72 69 6e 67  s.text(dotString
0c70: 29 3b 0a 20 20 20 20 20 20 69 66 20 28 53 65 61  );.      if (Sea
0c80: 72 63 68 2e 5f 70 75 6c 73 65 5f 73 74 61 74 75  rch._pulse_statu
0c90: 73 20 3e 20 2d 31 29 0a 20 20 20 20 20 20 20 20  s > -1).        
0ca0: 77 69 6e 64 6f 77 2e 73 65 74 54 69 6d 65 6f 75  window.setTimeou
0cb0: 74 28 70 75 6c 73 65 2c 20 35 30 30 29 3b 0a 20  t(pulse, 500);. 
0cc0: 20 20 20 7d 0a 20 20 20 20 70 75 6c 73 65 28 29     }.    pulse()
0cd0: 3b 0a 20 20 7d 2c 0a 0a 20 20 2f 2a 2a 0a 20 20  ;.  },..  /**.  
0ce0: 20 2a 20 70 65 72 66 6f 72 6d 20 61 20 73 65 61   * perform a sea
0cf0: 72 63 68 20 66 6f 72 20 73 6f 6d 65 74 68 69 6e  rch for somethin
0d00: 67 20 28 6f 72 20 77 61 69 74 20 75 6e 74 69 6c  g (or wait until
0d10: 20 69 6e 64 65 78 20 69 73 20 6c 6f 61 64 65 64   index is loaded
0d20: 29 0a 20 20 20 2a 2f 0a 20 20 70 65 72 66 6f 72  ).   */.  perfor
0d30: 6d 53 65 61 72 63 68 20 3a 20 66 75 6e 63 74 69  mSearch : functi
0d40: 6f 6e 28 71 75 65 72 79 29 20 7b 0a 20 20 20 20  on(query) {.    
0d50: 2f 2f 20 63 72 65 61 74 65 20 74 68 65 20 72 65  // create the re
0d60: 71 75 69 72 65 64 20 69 6e 74 65 72 66 61 63 65  quired interface
0d70: 20 65 6c 65 6d 65 6e 74 73 0a 20 20 20 20 74 68   elements.    th
0d80: 69 73 2e 6f 75 74 20 3d 20 24 28 27 23 73 65 61  is.out = $('#sea
0d90: 72 63 68 2d 72 65 73 75 6c 74 73 27 29 3b 0a 20  rch-results');. 
0da0: 20 20 20 74 68 69 73 2e 74 69 74 6c 65 20 3d 20     this.title = 
0db0: 24 28 27 3c 68 32 3e 27 20 2b 20 5f 28 27 53 65  $('<h2>' + _('Se
0dc0: 61 72 63 68 69 6e 67 27 29 20 2b 20 27 3c 2f 68  arching') + '</h
0dd0: 32 3e 27 29 2e 61 70 70 65 6e 64 54 6f 28 74 68  2>').appendTo(th
0de0: 69 73 2e 6f 75 74 29 3b 0a 20 20 20 20 74 68 69  is.out);.    thi
0df0: 73 2e 64 6f 74 73 20 3d 20 24 28 27 3c 73 70 61  s.dots = $('<spa
0e00: 6e 3e 3c 2f 73 70 61 6e 3e 27 29 2e 61 70 70 65  n></span>').appe
0e10: 6e 64 54 6f 28 74 68 69 73 2e 74 69 74 6c 65 29  ndTo(this.title)
0e20: 3b 0a 20 20 20 20 74 68 69 73 2e 73 74 61 74 75  ;.    this.statu
0e30: 73 20 3d 20 24 28 27 3c 70 20 63 6c 61 73 73 3d  s = $('<p class=
0e40: 22 73 65 61 72 63 68 2d 73 75 6d 6d 61 72 79 22  "search-summary"
0e50: 3e 26 6e 62 73 70 3b 3c 2f 70 3e 27 29 2e 61 70  >&nbsp;</p>').ap
0e60: 70 65 6e 64 54 6f 28 74 68 69 73 2e 6f 75 74 29  pendTo(this.out)
0e70: 3b 0a 20 20 20 20 74 68 69 73 2e 6f 75 74 70 75  ;.    this.outpu
0e80: 74 20 3d 20 24 28 27 3c 75 6c 20 63 6c 61 73 73  t = $('<ul class
0e90: 3d 22 73 65 61 72 63 68 22 2f 3e 27 29 2e 61 70  ="search"/>').ap
0ea0: 70 65 6e 64 54 6f 28 74 68 69 73 2e 6f 75 74 29  pendTo(this.out)
0eb0: 3b 0a 0a 20 20 20 20 24 28 27 23 73 65 61 72 63  ;..    $('#searc
0ec0: 68 2d 70 72 6f 67 72 65 73 73 27 29 2e 74 65 78  h-progress').tex
0ed0: 74 28 5f 28 27 50 72 65 70 61 72 69 6e 67 20 73  t(_('Preparing s
0ee0: 65 61 72 63 68 2e 2e 2e 27 29 29 3b 0a 20 20 20  earch...'));.   
0ef0: 20 74 68 69 73 2e 73 74 61 72 74 50 75 6c 73 65   this.startPulse
0f00: 28 29 3b 0a 0a 20 20 20 20 2f 2f 20 69 6e 64 65  ();..    // inde
0f10: 78 20 61 6c 72 65 61 64 79 20 6c 6f 61 64 65 64  x already loaded
0f20: 2c 20 74 68 65 20 62 72 6f 77 73 65 72 20 77 61  , the browser wa
0f30: 73 20 71 75 69 63 6b 21 0a 20 20 20 20 69 66 20  s quick!.    if 
0f40: 28 74 68 69 73 2e 68 61 73 49 6e 64 65 78 28 29  (this.hasIndex()
0f50: 29 0a 20 20 20 20 20 20 74 68 69 73 2e 71 75 65  ).      this.que
0f60: 72 79 28 71 75 65 72 79 29 3b 0a 20 20 20 20 65  ry(query);.    e
0f70: 6c 73 65 0a 20 20 20 20 20 20 74 68 69 73 2e 64  lse.      this.d
0f80: 65 66 65 72 51 75 65 72 79 28 71 75 65 72 79 29  eferQuery(query)
0f90: 3b 0a 20 20 7d 2c 0a 0a 20 20 2f 2a 2a 0a 20 20  ;.  },..  /**.  
0fa0: 20 2a 20 65 78 65 63 75 74 65 20 73 65 61 72 63   * execute searc
0fb0: 68 20 28 72 65 71 75 69 72 65 73 20 73 65 61 72  h (requires sear
0fc0: 63 68 20 69 6e 64 65 78 20 74 6f 20 62 65 20 6c  ch index to be l
0fd0: 6f 61 64 65 64 29 0a 20 20 20 2a 2f 0a 20 20 71  oaded).   */.  q
0fe0: 75 65 72 79 20 3a 20 66 75 6e 63 74 69 6f 6e 28  uery : function(
0ff0: 71 75 65 72 79 29 20 7b 0a 20 20 20 20 76 61 72  query) {.    var
1000: 20 69 3b 0a 0a 20 20 20 20 2f 2f 20 73 74 65 6d   i;..    // stem
1010: 20 74 68 65 20 73 65 61 72 63 68 74 65 72 6d 73   the searchterms
1020: 20 61 6e 64 20 61 64 64 20 74 68 65 6d 20 74 6f   and add them to
1030: 20 74 68 65 20 63 6f 72 72 65 63 74 20 6c 69 73   the correct lis
1040: 74 0a 20 20 20 20 76 61 72 20 73 74 65 6d 6d 65  t.    var stemme
1050: 72 20 3d 20 6e 65 77 20 53 74 65 6d 6d 65 72 28  r = new Stemmer(
1060: 29 3b 0a 20 20 20 20 76 61 72 20 73 65 61 72 63  );.    var searc
1070: 68 74 65 72 6d 73 20 3d 20 5b 5d 3b 0a 20 20 20  hterms = [];.   
1080: 20 76 61 72 20 65 78 63 6c 75 64 65 64 20 3d 20   var excluded = 
1090: 5b 5d 3b 0a 20 20 20 20 76 61 72 20 68 6c 74 65  [];.    var hlte
10a0: 72 6d 73 20 3d 20 5b 5d 3b 0a 20 20 20 20 76 61  rms = [];.    va
10b0: 72 20 74 6d 70 20 3d 20 73 70 6c 69 74 51 75 65  r tmp = splitQue
10c0: 72 79 28 71 75 65 72 79 29 3b 0a 20 20 20 20 76  ry(query);.    v
10d0: 61 72 20 6f 62 6a 65 63 74 74 65 72 6d 73 20 3d  ar objectterms =
10e0: 20 5b 5d 3b 0a 20 20 20 20 66 6f 72 20 28 69 20   [];.    for (i 
10f0: 3d 20 30 3b 20 69 20 3c 20 74 6d 70 2e 6c 65 6e  = 0; i < tmp.len
1100: 67 74 68 3b 20 69 2b 2b 29 20 7b 0a 20 20 20 20  gth; i++) {.    
1110: 20 20 69 66 20 28 74 6d 70 5b 69 5d 20 21 3d 3d    if (tmp[i] !==
1120: 20 22 22 29 20 7b 0a 20 20 20 20 20 20 20 20 20   "") {.         
1130: 20 6f 62 6a 65 63 74 74 65 72 6d 73 2e 70 75 73   objectterms.pus
1140: 68 28 74 6d 70 5b 69 5d 2e 74 6f 4c 6f 77 65 72  h(tmp[i].toLower
1150: 43 61 73 65 28 29 29 3b 0a 20 20 20 20 20 20 7d  Case());.      }
1160: 0a 0a 20 20 20 20 20 20 69 66 20 28 24 75 2e 69  ..      if ($u.i
1170: 6e 64 65 78 4f 66 28 73 74 6f 70 77 6f 72 64 73  ndexOf(stopwords
1180: 2c 20 74 6d 70 5b 69 5d 2e 74 6f 4c 6f 77 65 72  , tmp[i].toLower
1190: 43 61 73 65 28 29 29 20 21 3d 20 2d 31 20 7c 7c  Case()) != -1 ||
11a0: 20 74 6d 70 5b 69 5d 20 3d 3d 3d 20 22 22 29 20   tmp[i] === "") 
11b0: 7b 0a 20 20 20 20 20 20 20 20 2f 2f 20 73 6b 69  {.        // ski
11c0: 70 20 74 68 69 73 20 22 77 6f 72 64 22 0a 20 20  p this "word".  
11d0: 20 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a        continue;.
11e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 2f 2f        }.      //
11f0: 20 73 74 65 6d 20 74 68 65 20 77 6f 72 64 0a 20   stem the word. 
1200: 20 20 20 20 20 76 61 72 20 77 6f 72 64 20 3d 20       var word = 
1210: 73 74 65 6d 6d 65 72 2e 73 74 65 6d 57 6f 72 64  stemmer.stemWord
1220: 28 74 6d 70 5b 69 5d 2e 74 6f 4c 6f 77 65 72 43  (tmp[i].toLowerC
1230: 61 73 65 28 29 29 3b 0a 20 20 20 20 20 20 2f 2f  ase());.      //
1240: 20 70 72 65 76 65 6e 74 20 73 74 65 6d 6d 65 72   prevent stemmer
1250: 20 66 72 6f 6d 20 63 75 74 74 69 6e 67 20 77 6f   from cutting wo
1260: 72 64 20 73 6d 61 6c 6c 65 72 20 74 68 61 6e 20  rd smaller than 
1270: 74 77 6f 20 63 68 61 72 73 0a 20 20 20 20 20 20  two chars.      
1280: 69 66 28 77 6f 72 64 2e 6c 65 6e 67 74 68 20 3c  if(word.length <
1290: 20 33 20 26 26 20 74 6d 70 5b 69 5d 2e 6c 65 6e   3 && tmp[i].len
12a0: 67 74 68 20 3e 3d 20 33 29 20 7b 0a 20 20 20 20  gth >= 3) {.    
12b0: 20 20 20 20 77 6f 72 64 20 3d 20 74 6d 70 5b 69      word = tmp[i
12c0: 5d 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  ];.      }.     
12d0: 20 76 61 72 20 74 6f 41 70 70 65 6e 64 3b 0a 20   var toAppend;. 
12e0: 20 20 20 20 20 2f 2f 20 73 65 6c 65 63 74 20 74       // select t
12f0: 68 65 20 63 6f 72 72 65 63 74 20 6c 69 73 74 0a  he correct list.
1300: 20 20 20 20 20 20 69 66 20 28 77 6f 72 64 5b 30        if (word[0
1310: 5d 20 3d 3d 20 27 2d 27 29 20 7b 0a 20 20 20 20  ] == '-') {.    
1320: 20 20 20 20 74 6f 41 70 70 65 6e 64 20 3d 20 65      toAppend = e
1330: 78 63 6c 75 64 65 64 3b 0a 20 20 20 20 20 20 20  xcluded;.       
1340: 20 77 6f 72 64 20 3d 20 77 6f 72 64 2e 73 75 62   word = word.sub
1350: 73 74 72 28 31 29 3b 0a 20 20 20 20 20 20 7d 0a  str(1);.      }.
1360: 20 20 20 20 20 20 65 6c 73 65 20 7b 0a 20 20 20        else {.   
1370: 20 20 20 20 20 74 6f 41 70 70 65 6e 64 20 3d 20       toAppend = 
1380: 73 65 61 72 63 68 74 65 72 6d 73 3b 0a 20 20 20  searchterms;.   
1390: 20 20 20 20 20 68 6c 74 65 72 6d 73 2e 70 75 73       hlterms.pus
13a0: 68 28 74 6d 70 5b 69 5d 2e 74 6f 4c 6f 77 65 72  h(tmp[i].toLower
13b0: 43 61 73 65 28 29 29 3b 0a 20 20 20 20 20 20 7d  Case());.      }
13c0: 0a 20 20 20 20 20 20 2f 2f 20 6f 6e 6c 79 20 61  .      // only a
13d0: 64 64 20 69 66 20 6e 6f 74 20 61 6c 72 65 61 64  dd if not alread
13e0: 79 20 69 6e 20 74 68 65 20 6c 69 73 74 0a 20 20  y in the list.  
13f0: 20 20 20 20 69 66 20 28 21 24 75 2e 63 6f 6e 74      if (!$u.cont
1400: 61 69 6e 73 28 74 6f 41 70 70 65 6e 64 2c 20 77  ains(toAppend, w
1410: 6f 72 64 29 29 0a 20 20 20 20 20 20 20 20 74 6f  ord)).        to
1420: 41 70 70 65 6e 64 2e 70 75 73 68 28 77 6f 72 64  Append.push(word
1430: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 76 61 72  );.    }.    var
1440: 20 68 69 67 68 6c 69 67 68 74 73 74 72 69 6e 67   highlightstring
1450: 20 3d 20 27 3f 68 69 67 68 6c 69 67 68 74 3d 27   = '?highlight='
1460: 20 2b 20 24 2e 75 72 6c 65 6e 63 6f 64 65 28 68   + $.urlencode(h
1470: 6c 74 65 72 6d 73 2e 6a 6f 69 6e 28 22 20 22 29  lterms.join(" ")
1480: 29 3b 0a 0a 20 20 20 20 2f 2f 20 63 6f 6e 73 6f  );..    // conso
1490: 6c 65 2e 64 65 62 75 67 28 27 53 45 41 52 43 48  le.debug('SEARCH
14a0: 3a 20 73 65 61 72 63 68 69 6e 67 20 66 6f 72 3a  : searching for:
14b0: 27 29 3b 0a 20 20 20 20 2f 2f 20 63 6f 6e 73 6f  ');.    // conso
14c0: 6c 65 2e 69 6e 66 6f 28 27 72 65 71 75 69 72 65  le.info('require
14d0: 64 3a 20 27 2c 20 73 65 61 72 63 68 74 65 72 6d  d: ', searchterm
14e0: 73 29 3b 0a 20 20 20 20 2f 2f 20 63 6f 6e 73 6f  s);.    // conso
14f0: 6c 65 2e 69 6e 66 6f 28 27 65 78 63 6c 75 64 65  le.info('exclude
1500: 64 3a 20 27 2c 20 65 78 63 6c 75 64 65 64 29 3b  d: ', excluded);
1510: 0a 0a 20 20 20 20 2f 2f 20 70 72 65 70 61 72 65  ..    // prepare
1520: 20 73 65 61 72 63 68 0a 20 20 20 20 76 61 72 20   search.    var 
1530: 74 65 72 6d 73 20 3d 20 74 68 69 73 2e 5f 69 6e  terms = this._in
1540: 64 65 78 2e 74 65 72 6d 73 3b 0a 20 20 20 20 76  dex.terms;.    v
1550: 61 72 20 74 69 74 6c 65 74 65 72 6d 73 20 3d 20  ar titleterms = 
1560: 74 68 69 73 2e 5f 69 6e 64 65 78 2e 74 69 74 6c  this._index.titl
1570: 65 74 65 72 6d 73 3b 0a 0a 20 20 20 20 2f 2f 20  eterms;..    // 
1580: 61 72 72 61 79 20 6f 66 20 5b 66 69 6c 65 6e 61  array of [filena
1590: 6d 65 2c 20 74 69 74 6c 65 2c 20 61 6e 63 68 6f  me, title, ancho
15a0: 72 2c 20 64 65 73 63 72 2c 20 73 63 6f 72 65 5d  r, descr, score]
15b0: 0a 20 20 20 20 76 61 72 20 72 65 73 75 6c 74 73  .    var results
15c0: 20 3d 20 5b 5d 3b 0a 20 20 20 20 24 28 27 23 73   = [];.    $('#s
15d0: 65 61 72 63 68 2d 70 72 6f 67 72 65 73 73 27 29  earch-progress')
15e0: 2e 65 6d 70 74 79 28 29 3b 0a 0a 20 20 20 20 2f  .empty();..    /
15f0: 2f 20 6c 6f 6f 6b 75 70 20 61 73 20 6f 62 6a 65  / lookup as obje
1600: 63 74 0a 20 20 20 20 66 6f 72 20 28 69 20 3d 20  ct.    for (i = 
1610: 30 3b 20 69 20 3c 20 6f 62 6a 65 63 74 74 65 72  0; i < objectter
1620: 6d 73 2e 6c 65 6e 67 74 68 3b 20 69 2b 2b 29 20  ms.length; i++) 
1630: 7b 0a 20 20 20 20 20 20 76 61 72 20 6f 74 68 65  {.      var othe
1640: 72 73 20 3d 20 5b 5d 2e 63 6f 6e 63 61 74 28 6f  rs = [].concat(o
1650: 62 6a 65 63 74 74 65 72 6d 73 2e 73 6c 69 63 65  bjectterms.slice
1660: 28 30 2c 20 69 29 2c 0a 20 20 20 20 20 20 20 20  (0, i),.        
1670: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1680: 20 20 20 20 20 6f 62 6a 65 63 74 74 65 72 6d 73       objectterms
1690: 2e 73 6c 69 63 65 28 69 2b 31 2c 20 6f 62 6a 65  .slice(i+1, obje
16a0: 63 74 74 65 72 6d 73 2e 6c 65 6e 67 74 68 29 29  ctterms.length))
16b0: 3b 0a 20 20 20 20 20 20 72 65 73 75 6c 74 73 20  ;.      results 
16c0: 3d 20 72 65 73 75 6c 74 73 2e 63 6f 6e 63 61 74  = results.concat
16d0: 28 74 68 69 73 2e 70 65 72 66 6f 72 6d 4f 62 6a  (this.performObj
16e0: 65 63 74 53 65 61 72 63 68 28 6f 62 6a 65 63 74  ectSearch(object
16f0: 74 65 72 6d 73 5b 69 5d 2c 20 6f 74 68 65 72 73  terms[i], others
1700: 29 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  ));.    }..    /
1710: 2f 20 6c 6f 6f 6b 75 70 20 61 73 20 73 65 61 72  / lookup as sear
1720: 63 68 20 74 65 72 6d 73 20 69 6e 20 66 75 6c 6c  ch terms in full
1730: 74 65 78 74 0a 20 20 20 20 72 65 73 75 6c 74 73  text.    results
1740: 20 3d 20 72 65 73 75 6c 74 73 2e 63 6f 6e 63 61   = results.conca
1750: 74 28 74 68 69 73 2e 70 65 72 66 6f 72 6d 54 65  t(this.performTe
1760: 72 6d 73 53 65 61 72 63 68 28 73 65 61 72 63 68  rmsSearch(search
1770: 74 65 72 6d 73 2c 20 65 78 63 6c 75 64 65 64 2c  terms, excluded,
1780: 20 74 65 72 6d 73 2c 20 74 69 74 6c 65 74 65 72   terms, titleter
1790: 6d 73 29 29 3b 0a 0a 20 20 20 20 2f 2f 20 6c 65  ms));..    // le
17a0: 74 20 74 68 65 20 73 63 6f 72 65 72 20 6f 76 65  t the scorer ove
17b0: 72 72 69 64 65 20 73 63 6f 72 65 73 20 77 69 74  rride scores wit
17c0: 68 20 61 20 63 75 73 74 6f 6d 20 73 63 6f 72 69  h a custom scori
17d0: 6e 67 20 66 75 6e 63 74 69 6f 6e 0a 20 20 20 20  ng function.    
17e0: 69 66 20 28 53 63 6f 72 65 72 2e 73 63 6f 72 65  if (Scorer.score
17f0: 29 20 7b 0a 20 20 20 20 20 20 66 6f 72 20 28 69  ) {.      for (i
1800: 20 3d 20 30 3b 20 69 20 3c 20 72 65 73 75 6c 74   = 0; i < result
1810: 73 2e 6c 65 6e 67 74 68 3b 20 69 2b 2b 29 0a 20  s.length; i++). 
1820: 20 20 20 20 20 20 20 72 65 73 75 6c 74 73 5b 69         results[i
1830: 5d 5b 34 5d 20 3d 20 53 63 6f 72 65 72 2e 73 63  ][4] = Scorer.sc
1840: 6f 72 65 28 72 65 73 75 6c 74 73 5b 69 5d 29 3b  ore(results[i]);
1850: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2f 20 6e  .    }..    // n
1860: 6f 77 20 73 6f 72 74 20 74 68 65 20 72 65 73 75  ow sort the resu
1870: 6c 74 73 20 62 79 20 73 63 6f 72 65 20 28 69 6e  lts by score (in
1880: 20 6f 70 70 6f 73 69 74 65 20 6f 72 64 65 72 20   opposite order 
1890: 6f 66 20 61 70 70 65 61 72 61 6e 63 65 2c 20 73  of appearance, s
18a0: 69 6e 63 65 20 74 68 65 0a 20 20 20 20 2f 2f 20  ince the.    // 
18b0: 64 69 73 70 6c 61 79 20 66 75 6e 63 74 69 6f 6e  display function
18c0: 20 62 65 6c 6f 77 20 75 73 65 73 20 70 6f 70 28   below uses pop(
18d0: 29 20 74 6f 20 72 65 74 72 69 65 76 65 20 69 74  ) to retrieve it
18e0: 65 6d 73 29 20 61 6e 64 20 74 68 65 6e 0a 20 20  ems) and then.  
18f0: 20 20 2f 2f 20 61 6c 70 68 61 62 65 74 69 63 61    // alphabetica
1900: 6c 6c 79 0a 20 20 20 20 72 65 73 75 6c 74 73 2e  lly.    results.
1910: 73 6f 72 74 28 66 75 6e 63 74 69 6f 6e 28 61 2c  sort(function(a,
1920: 20 62 29 20 7b 0a 20 20 20 20 20 20 76 61 72 20   b) {.      var 
1930: 6c 65 66 74 20 3d 20 61 5b 34 5d 3b 0a 20 20 20  left = a[4];.   
1940: 20 20 20 76 61 72 20 72 69 67 68 74 20 3d 20 62     var right = b
1950: 5b 34 5d 3b 0a 20 20 20 20 20 20 69 66 20 28 6c  [4];.      if (l
1960: 65 66 74 20 3e 20 72 69 67 68 74 29 20 7b 0a 20  eft > right) {. 
1970: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 31 3b         return 1;
1980: 0a 20 20 20 20 20 20 7d 20 65 6c 73 65 20 69 66  .      } else if
1990: 20 28 6c 65 66 74 20 3c 20 72 69 67 68 74 29 20   (left < right) 
19a0: 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e  {.        return
19b0: 20 2d 31 3b 0a 20 20 20 20 20 20 7d 20 65 6c 73   -1;.      } els
19c0: 65 20 7b 0a 20 20 20 20 20 20 20 20 2f 2f 20 73  e {.        // s
19d0: 61 6d 65 20 73 63 6f 72 65 3a 20 73 6f 72 74 20  ame score: sort 
19e0: 61 6c 70 68 61 62 65 74 69 63 61 6c 6c 79 0a 20  alphabetically. 
19f0: 20 20 20 20 20 20 20 6c 65 66 74 20 3d 20 61 5b         left = a[
1a00: 31 5d 2e 74 6f 4c 6f 77 65 72 43 61 73 65 28 29  1].toLowerCase()
1a10: 3b 0a 20 20 20 20 20 20 20 20 72 69 67 68 74 20  ;.        right 
1a20: 3d 20 62 5b 31 5d 2e 74 6f 4c 6f 77 65 72 43 61  = b[1].toLowerCa
1a30: 73 65 28 29 3b 0a 20 20 20 20 20 20 20 20 72 65  se();.        re
1a40: 74 75 72 6e 20 28 6c 65 66 74 20 3e 20 72 69 67  turn (left > rig
1a50: 68 74 29 20 3f 20 2d 31 20 3a 20 28 28 6c 65 66  ht) ? -1 : ((lef
1a60: 74 20 3c 20 72 69 67 68 74 29 20 3f 20 31 20 3a  t < right) ? 1 :
1a70: 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20   0);.      }.   
1a80: 20 7d 29 3b 0a 0a 20 20 20 20 2f 2f 20 66 6f 72   });..    // for
1a90: 20 64 65 62 75 67 67 69 6e 67 0a 20 20 20 20 2f   debugging.    /
1aa0: 2f 53 65 61 72 63 68 2e 6c 61 73 74 72 65 73 75  /Search.lastresu
1ab0: 6c 74 73 20 3d 20 72 65 73 75 6c 74 73 2e 73 6c  lts = results.sl
1ac0: 69 63 65 28 29 3b 20 20 2f 2f 20 61 20 63 6f 70  ice();  // a cop
1ad0: 79 0a 20 20 20 20 2f 2f 63 6f 6e 73 6f 6c 65 2e  y.    //console.
1ae0: 69 6e 66 6f 28 27 73 65 61 72 63 68 20 72 65 73  info('search res
1af0: 75 6c 74 73 3a 27 2c 20 53 65 61 72 63 68 2e 6c  ults:', Search.l
1b00: 61 73 74 72 65 73 75 6c 74 73 29 3b 0a 0a 20 20  astresults);..  
1b10: 20 20 2f 2f 20 70 72 69 6e 74 20 74 68 65 20 72    // print the r
1b20: 65 73 75 6c 74 73 0a 20 20 20 20 76 61 72 20 72  esults.    var r
1b30: 65 73 75 6c 74 43 6f 75 6e 74 20 3d 20 72 65 73  esultCount = res
1b40: 75 6c 74 73 2e 6c 65 6e 67 74 68 3b 0a 20 20 20  ults.length;.   
1b50: 20 66 75 6e 63 74 69 6f 6e 20 64 69 73 70 6c 61   function displa
1b60: 79 4e 65 78 74 49 74 65 6d 28 29 20 7b 0a 20 20  yNextItem() {.  
1b70: 20 20 20 20 2f 2f 20 72 65 73 75 6c 74 73 20 6c      // results l
1b80: 65 66 74 2c 20 6c 6f 61 64 20 74 68 65 20 73 75  eft, load the su
1b90: 6d 6d 61 72 79 20 61 6e 64 20 64 69 73 70 6c 61  mmary and displa
1ba0: 79 20 69 74 0a 20 20 20 20 20 20 69 66 20 28 72  y it.      if (r
1bb0: 65 73 75 6c 74 73 2e 6c 65 6e 67 74 68 29 20 7b  esults.length) {
1bc0: 0a 20 20 20 20 20 20 20 20 76 61 72 20 69 74 65  .        var ite
1bd0: 6d 20 3d 20 72 65 73 75 6c 74 73 2e 70 6f 70 28  m = results.pop(
1be0: 29 3b 0a 20 20 20 20 20 20 20 20 76 61 72 20 6c  );.        var l
1bf0: 69 73 74 49 74 65 6d 20 3d 20 24 28 27 3c 6c 69  istItem = $('<li
1c00: 3e 3c 2f 6c 69 3e 27 29 3b 0a 20 20 20 20 20 20  ></li>');.      
1c10: 20 20 76 61 72 20 72 65 71 75 65 73 74 55 72 6c    var requestUrl
1c20: 20 3d 20 22 22 3b 0a 20 20 20 20 20 20 20 20 76   = "";.        v
1c30: 61 72 20 6c 69 6e 6b 55 72 6c 20 3d 20 22 22 3b  ar linkUrl = "";
1c40: 0a 20 20 20 20 20 20 20 20 69 66 20 28 44 4f 43  .        if (DOC
1c50: 55 4d 45 4e 54 41 54 49 4f 4e 5f 4f 50 54 49 4f  UMENTATION_OPTIO
1c60: 4e 53 2e 42 55 49 4c 44 45 52 20 3d 3d 3d 20 27  NS.BUILDER === '
1c70: 64 69 72 68 74 6d 6c 27 29 20 7b 0a 20 20 20 20  dirhtml') {.    
1c80: 20 20 20 20 20 20 2f 2f 20 64 69 72 68 74 6d 6c        // dirhtml
1c90: 20 62 75 69 6c 64 65 72 0a 20 20 20 20 20 20 20   builder.       
1ca0: 20 20 20 76 61 72 20 64 69 72 6e 61 6d 65 20 3d     var dirname =
1cb0: 20 69 74 65 6d 5b 30 5d 20 2b 20 27 2f 27 3b 0a   item[0] + '/';.
1cc0: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 64 69            if (di
1cd0: 72 6e 61 6d 65 2e 6d 61 74 63 68 28 2f 5c 2f 69  rname.match(/\/i
1ce0: 6e 64 65 78 5c 2f 24 2f 29 29 20 7b 0a 20 20 20  ndex\/$/)) {.   
1cf0: 20 20 20 20 20 20 20 20 20 64 69 72 6e 61 6d 65           dirname
1d00: 20 3d 20 64 69 72 6e 61 6d 65 2e 73 75 62 73 74   = dirname.subst
1d10: 72 69 6e 67 28 30 2c 20 64 69 72 6e 61 6d 65 2e  ring(0, dirname.
1d20: 6c 65 6e 67 74 68 2d 36 29 3b 0a 20 20 20 20 20  length-6);.     
1d30: 20 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28       } else if (
1d40: 64 69 72 6e 61 6d 65 20 3d 3d 20 27 69 6e 64 65  dirname == 'inde
1d50: 78 2f 27 29 20 7b 0a 20 20 20 20 20 20 20 20 20  x/') {.         
1d60: 20 20 20 64 69 72 6e 61 6d 65 20 3d 20 27 27 3b     dirname = '';
1d70: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
1d80: 20 20 20 20 20 20 20 72 65 71 75 65 73 74 55 72         requestUr
1d90: 6c 20 3d 20 44 4f 43 55 4d 45 4e 54 41 54 49 4f  l = DOCUMENTATIO
1da0: 4e 5f 4f 50 54 49 4f 4e 53 2e 55 52 4c 5f 52 4f  N_OPTIONS.URL_RO
1db0: 4f 54 20 2b 20 64 69 72 6e 61 6d 65 3b 0a 20 20  OT + dirname;.  
1dc0: 20 20 20 20 20 20 20 20 6c 69 6e 6b 55 72 6c 20          linkUrl 
1dd0: 3d 20 72 65 71 75 65 73 74 55 72 6c 3b 0a 0a 20  = requestUrl;.. 
1de0: 20 20 20 20 20 20 20 7d 20 65 6c 73 65 20 7b 0a         } else {.
1df0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 6e 6f 72            // nor
1e00: 6d 61 6c 20 68 74 6d 6c 20 62 75 69 6c 64 65 72  mal html builder
1e10: 73 0a 20 20 20 20 20 20 20 20 20 20 72 65 71 75  s.          requ
1e20: 65 73 74 55 72 6c 20 3d 20 44 4f 43 55 4d 45 4e  estUrl = DOCUMEN
1e30: 54 41 54 49 4f 4e 5f 4f 50 54 49 4f 4e 53 2e 55  TATION_OPTIONS.U
1e40: 52 4c 5f 52 4f 4f 54 20 2b 20 69 74 65 6d 5b 30  RL_ROOT + item[0
1e50: 5d 20 2b 20 44 4f 43 55 4d 45 4e 54 41 54 49 4f  ] + DOCUMENTATIO
1e60: 4e 5f 4f 50 54 49 4f 4e 53 2e 46 49 4c 45 5f 53  N_OPTIONS.FILE_S
1e70: 55 46 46 49 58 3b 0a 20 20 20 20 20 20 20 20 20  UFFIX;.         
1e80: 20 6c 69 6e 6b 55 72 6c 20 3d 20 69 74 65 6d 5b   linkUrl = item[
1e90: 30 5d 20 2b 20 44 4f 43 55 4d 45 4e 54 41 54 49  0] + DOCUMENTATI
1ea0: 4f 4e 5f 4f 50 54 49 4f 4e 53 2e 4c 49 4e 4b 5f  ON_OPTIONS.LINK_
1eb0: 53 55 46 46 49 58 3b 0a 20 20 20 20 20 20 20 20  SUFFIX;.        
1ec0: 7d 0a 20 20 20 20 20 20 20 20 6c 69 73 74 49 74  }.        listIt
1ed0: 65 6d 2e 61 70 70 65 6e 64 28 24 28 27 3c 61 2f  em.append($('<a/
1ee0: 3e 27 29 2e 61 74 74 72 28 27 68 72 65 66 27 2c  >').attr('href',
1ef0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6c 69 6e  .            lin
1f00: 6b 55 72 6c 20 2b 0a 20 20 20 20 20 20 20 20 20  kUrl +.         
1f10: 20 20 20 68 69 67 68 6c 69 67 68 74 73 74 72 69     highlightstri
1f20: 6e 67 20 2b 20 69 74 65 6d 5b 32 5d 29 2e 68 74  ng + item[2]).ht
1f30: 6d 6c 28 69 74 65 6d 5b 31 5d 29 29 3b 0a 20 20  ml(item[1]));.  
1f40: 20 20 20 20 20 20 69 66 20 28 69 74 65 6d 5b 33        if (item[3
1f50: 5d 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 6c  ]) {.          l
1f60: 69 73 74 49 74 65 6d 2e 61 70 70 65 6e 64 28 24  istItem.append($
1f70: 28 27 3c 73 70 61 6e 3e 20 28 27 20 2b 20 69 74  ('<span> (' + it
1f80: 65 6d 5b 33 5d 20 2b 20 27 29 3c 2f 73 70 61 6e  em[3] + ')</span
1f90: 3e 27 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20  >'));.          
1fa0: 53 65 61 72 63 68 2e 6f 75 74 70 75 74 2e 61 70  Search.output.ap
1fb0: 70 65 6e 64 28 6c 69 73 74 49 74 65 6d 29 3b 0a  pend(listItem);.
1fc0: 20 20 20 20 20 20 20 20 20 20 73 65 74 54 69 6d            setTim
1fd0: 65 6f 75 74 28 66 75 6e 63 74 69 6f 6e 28 29 20  eout(function() 
1fe0: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 64 69  {.            di
1ff0: 73 70 6c 61 79 4e 65 78 74 49 74 65 6d 28 29 3b  splayNextItem();
2000: 0a 20 20 20 20 20 20 20 20 20 20 7d 2c 20 35 29  .          }, 5)
2010: 3b 0a 20 20 20 20 20 20 20 20 7d 20 65 6c 73 65  ;.        } else
2020: 20 69 66 20 28 44 4f 43 55 4d 45 4e 54 41 54 49   if (DOCUMENTATI
2030: 4f 4e 5f 4f 50 54 49 4f 4e 53 2e 48 41 53 5f 53  ON_OPTIONS.HAS_S
2040: 4f 55 52 43 45 29 20 7b 0a 20 20 20 20 20 20 20  OURCE) {.       
2050: 20 20 20 24 2e 61 6a 61 78 28 7b 75 72 6c 3a 20     $.ajax({url: 
2060: 72 65 71 75 65 73 74 55 72 6c 2c 0a 20 20 20 20  requestUrl,.    
2070: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64 61                da
2080: 74 61 54 79 70 65 3a 20 22 74 65 78 74 22 2c 0a  taType: "text",.
2090: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
20a0: 20 20 63 6f 6d 70 6c 65 74 65 3a 20 66 75 6e 63    complete: func
20b0: 74 69 6f 6e 28 6a 71 78 68 72 2c 20 74 65 78 74  tion(jqxhr, text
20c0: 73 74 61 74 75 73 29 20 7b 0a 20 20 20 20 20 20  status) {.      
20d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 76 61                va
20e0: 72 20 64 61 74 61 20 3d 20 6a 71 78 68 72 2e 72  r data = jqxhr.r
20f0: 65 73 70 6f 6e 73 65 54 65 78 74 3b 0a 20 20 20  esponseText;.   
2100: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2110: 20 69 66 20 28 64 61 74 61 20 21 3d 3d 20 27 27   if (data !== ''
2120: 20 26 26 20 64 61 74 61 20 21 3d 3d 20 75 6e 64   && data !== und
2130: 65 66 69 6e 65 64 29 20 7b 0a 20 20 20 20 20 20  efined) {.      
2140: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2150: 6c 69 73 74 49 74 65 6d 2e 61 70 70 65 6e 64 28  listItem.append(
2160: 53 65 61 72 63 68 2e 6d 61 6b 65 53 65 61 72 63  Search.makeSearc
2170: 68 53 75 6d 6d 61 72 79 28 64 61 74 61 2c 20 73  hSummary(data, s
2180: 65 61 72 63 68 74 65 72 6d 73 2c 20 68 6c 74 65  earchterms, hlte
2190: 72 6d 73 29 29 3b 0a 20 20 20 20 20 20 20 20 20  rms));.         
21a0: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
21b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
21c0: 20 53 65 61 72 63 68 2e 6f 75 74 70 75 74 2e 61   Search.output.a
21d0: 70 70 65 6e 64 28 6c 69 73 74 49 74 65 6d 29 3b  ppend(listItem);
21e0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
21f0: 20 20 20 20 20 73 65 74 54 69 6d 65 6f 75 74 28       setTimeout(
2200: 66 75 6e 63 74 69 6f 6e 28 29 20 7b 0a 20 20 20  function() {.   
2210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2220: 20 20 20 64 69 73 70 6c 61 79 4e 65 78 74 49 74     displayNextIt
2230: 65 6d 28 29 3b 0a 20 20 20 20 20 20 20 20 20 20  em();.          
2240: 20 20 20 20 20 20 20 20 20 20 7d 2c 20 35 29 3b            }, 5);
2250: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2260: 20 20 20 7d 7d 29 3b 0a 20 20 20 20 20 20 20 20     }});.        
2270: 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20 20 20 20  } else {.       
2280: 20 20 20 2f 2f 20 6e 6f 20 73 6f 75 72 63 65 20     // no source 
2290: 61 76 61 69 6c 61 62 6c 65 2c 20 6a 75 73 74 20  available, just 
22a0: 64 69 73 70 6c 61 79 20 74 69 74 6c 65 0a 20 20  display title.  
22b0: 20 20 20 20 20 20 20 20 53 65 61 72 63 68 2e 6f          Search.o
22c0: 75 74 70 75 74 2e 61 70 70 65 6e 64 28 6c 69 73  utput.append(lis
22d0: 74 49 74 65 6d 29 3b 0a 20 20 20 20 20 20 20 20  tItem);.        
22e0: 20 20 73 65 74 54 69 6d 65 6f 75 74 28 66 75 6e    setTimeout(fun
22f0: 63 74 69 6f 6e 28 29 20 7b 0a 20 20 20 20 20 20  ction() {.      
2300: 20 20 20 20 20 20 64 69 73 70 6c 61 79 4e 65 78        displayNex
2310: 74 49 74 65 6d 28 29 3b 0a 20 20 20 20 20 20 20  tItem();.       
2320: 20 20 20 7d 2c 20 35 29 3b 0a 20 20 20 20 20 20     }, 5);.      
2330: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20    }.      }.    
2340: 20 20 2f 2f 20 73 65 61 72 63 68 20 66 69 6e 69    // search fini
2350: 73 68 65 64 2c 20 75 70 64 61 74 65 20 74 69 74  shed, update tit
2360: 6c 65 20 61 6e 64 20 73 74 61 74 75 73 20 6d 65  le and status me
2370: 73 73 61 67 65 0a 20 20 20 20 20 20 65 6c 73 65  ssage.      else
2380: 20 7b 0a 20 20 20 20 20 20 20 20 53 65 61 72 63   {.        Searc
2390: 68 2e 73 74 6f 70 50 75 6c 73 65 28 29 3b 0a 20  h.stopPulse();. 
23a0: 20 20 20 20 20 20 20 53 65 61 72 63 68 2e 74 69         Search.ti
23b0: 74 6c 65 2e 74 65 78 74 28 5f 28 27 53 65 61 72  tle.text(_('Sear
23c0: 63 68 20 52 65 73 75 6c 74 73 27 29 29 3b 0a 20  ch Results'));. 
23d0: 20 20 20 20 20 20 20 69 66 20 28 21 72 65 73 75         if (!resu
23e0: 6c 74 43 6f 75 6e 74 29 0a 20 20 20 20 20 20 20  ltCount).       
23f0: 20 20 20 53 65 61 72 63 68 2e 73 74 61 74 75 73     Search.status
2400: 2e 74 65 78 74 28 5f 28 27 59 6f 75 72 20 73 65  .text(_('Your se
2410: 61 72 63 68 20 64 69 64 20 6e 6f 74 20 6d 61 74  arch did not mat
2420: 63 68 20 61 6e 79 20 64 6f 63 75 6d 65 6e 74 73  ch any documents
2430: 2e 20 50 6c 65 61 73 65 20 6d 61 6b 65 20 73 75  . Please make su
2440: 72 65 20 74 68 61 74 20 61 6c 6c 20 77 6f 72 64  re that all word
2450: 73 20 61 72 65 20 73 70 65 6c 6c 65 64 20 63 6f  s are spelled co
2460: 72 72 65 63 74 6c 79 20 61 6e 64 20 74 68 61 74  rrectly and that
2470: 20 79 6f 75 5c 27 76 65 20 73 65 6c 65 63 74 65   you\'ve selecte
2480: 64 20 65 6e 6f 75 67 68 20 63 61 74 65 67 6f 72  d enough categor
2490: 69 65 73 2e 27 29 29 3b 0a 20 20 20 20 20 20 20  ies.'));.       
24a0: 20 65 6c 73 65 0a 20 20 20 20 20 20 20 20 20 20   else.          
24b0: 20 20 53 65 61 72 63 68 2e 73 74 61 74 75 73 2e    Search.status.
24c0: 74 65 78 74 28 5f 28 27 53 65 61 72 63 68 20 66  text(_('Search f
24d0: 69 6e 69 73 68 65 64 2c 20 66 6f 75 6e 64 20 25  inished, found %
24e0: 73 20 70 61 67 65 28 73 29 20 6d 61 74 63 68 69  s page(s) matchi
24f0: 6e 67 20 74 68 65 20 73 65 61 72 63 68 20 71 75  ng the search qu
2500: 65 72 79 2e 27 29 2e 72 65 70 6c 61 63 65 28 27  ery.').replace('
2510: 25 73 27 2c 20 72 65 73 75 6c 74 43 6f 75 6e 74  %s', resultCount
2520: 29 29 3b 0a 20 20 20 20 20 20 20 20 53 65 61 72  ));.        Sear
2530: 63 68 2e 73 74 61 74 75 73 2e 66 61 64 65 49 6e  ch.status.fadeIn
2540: 28 35 30 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20  (500);.      }. 
2550: 20 20 20 7d 0a 20 20 20 20 64 69 73 70 6c 61 79     }.    display
2560: 4e 65 78 74 49 74 65 6d 28 29 3b 0a 20 20 7d 2c  NextItem();.  },
2570: 0a 0a 20 20 2f 2a 2a 0a 20 20 20 2a 20 73 65 61  ..  /**.   * sea
2580: 72 63 68 20 66 6f 72 20 6f 62 6a 65 63 74 20 6e  rch for object n
2590: 61 6d 65 73 0a 20 20 20 2a 2f 0a 20 20 70 65 72  ames.   */.  per
25a0: 66 6f 72 6d 4f 62 6a 65 63 74 53 65 61 72 63 68  formObjectSearch
25b0: 20 3a 20 66 75 6e 63 74 69 6f 6e 28 6f 62 6a 65   : function(obje
25c0: 63 74 2c 20 6f 74 68 65 72 74 65 72 6d 73 29 20  ct, otherterms) 
25d0: 7b 0a 20 20 20 20 76 61 72 20 66 69 6c 65 6e 61  {.    var filena
25e0: 6d 65 73 20 3d 20 74 68 69 73 2e 5f 69 6e 64 65  mes = this._inde
25f0: 78 2e 66 69 6c 65 6e 61 6d 65 73 3b 0a 20 20 20  x.filenames;.   
2600: 20 76 61 72 20 64 6f 63 6e 61 6d 65 73 20 3d 20   var docnames = 
2610: 74 68 69 73 2e 5f 69 6e 64 65 78 2e 64 6f 63 6e  this._index.docn
2620: 61 6d 65 73 3b 0a 20 20 20 20 76 61 72 20 6f 62  ames;.    var ob
2630: 6a 65 63 74 73 20 3d 20 74 68 69 73 2e 5f 69 6e  jects = this._in
2640: 64 65 78 2e 6f 62 6a 65 63 74 73 3b 0a 20 20 20  dex.objects;.   
2650: 20 76 61 72 20 6f 62 6a 6e 61 6d 65 73 20 3d 20   var objnames = 
2660: 74 68 69 73 2e 5f 69 6e 64 65 78 2e 6f 62 6a 6e  this._index.objn
2670: 61 6d 65 73 3b 0a 20 20 20 20 76 61 72 20 74 69  ames;.    var ti
2680: 74 6c 65 73 20 3d 20 74 68 69 73 2e 5f 69 6e 64  tles = this._ind
2690: 65 78 2e 74 69 74 6c 65 73 3b 0a 0a 20 20 20 20  ex.titles;..    
26a0: 76 61 72 20 69 3b 0a 20 20 20 20 76 61 72 20 72  var i;.    var r
26b0: 65 73 75 6c 74 73 20 3d 20 5b 5d 3b 0a 0a 20 20  esults = [];..  
26c0: 20 20 66 6f 72 20 28 76 61 72 20 70 72 65 66 69    for (var prefi
26d0: 78 20 69 6e 20 6f 62 6a 65 63 74 73 29 20 7b 0a  x in objects) {.
26e0: 20 20 20 20 20 20 66 6f 72 20 28 76 61 72 20 6e        for (var n
26f0: 61 6d 65 20 69 6e 20 6f 62 6a 65 63 74 73 5b 70  ame in objects[p
2700: 72 65 66 69 78 5d 29 20 7b 0a 20 20 20 20 20 20  refix]) {.      
2710: 20 20 76 61 72 20 66 75 6c 6c 6e 61 6d 65 20 3d    var fullname =
2720: 20 28 70 72 65 66 69 78 20 3f 20 70 72 65 66 69   (prefix ? prefi
2730: 78 20 2b 20 27 2e 27 20 3a 20 27 27 29 20 2b 20  x + '.' : '') + 
2740: 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 76 61  name;.        va
2750: 72 20 66 75 6c 6c 6e 61 6d 65 4c 6f 77 65 72 20  r fullnameLower 
2760: 3d 20 66 75 6c 6c 6e 61 6d 65 2e 74 6f 4c 6f 77  = fullname.toLow
2770: 65 72 43 61 73 65 28 29 0a 20 20 20 20 20 20 20  erCase().       
2780: 20 69 66 20 28 66 75 6c 6c 6e 61 6d 65 4c 6f 77   if (fullnameLow
2790: 65 72 2e 69 6e 64 65 78 4f 66 28 6f 62 6a 65 63  er.indexOf(objec
27a0: 74 29 20 3e 20 2d 31 29 20 7b 0a 20 20 20 20 20  t) > -1) {.     
27b0: 20 20 20 20 20 76 61 72 20 73 63 6f 72 65 20 3d       var score =
27c0: 20 30 3b 0a 20 20 20 20 20 20 20 20 20 20 76 61   0;.          va
27d0: 72 20 70 61 72 74 73 20 3d 20 66 75 6c 6c 6e 61  r parts = fullna
27e0: 6d 65 4c 6f 77 65 72 2e 73 70 6c 69 74 28 27 2e  meLower.split('.
27f0: 27 29 3b 0a 20 20 20 20 20 20 20 20 20 20 2f 2f  ');.          //
2800: 20 63 68 65 63 6b 20 66 6f 72 20 64 69 66 66 65   check for diffe
2810: 72 65 6e 74 20 6d 61 74 63 68 20 74 79 70 65 73  rent match types
2820: 3a 20 65 78 61 63 74 20 6d 61 74 63 68 65 73 20  : exact matches 
2830: 6f 66 20 66 75 6c 6c 20 6e 61 6d 65 20 6f 72 0a  of full name or.
2840: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 22 6c 61            // "la
2850: 73 74 20 6e 61 6d 65 22 20 28 69 2e 65 2e 20 6c  st name" (i.e. l
2860: 61 73 74 20 64 6f 74 74 65 64 20 70 61 72 74 29  ast dotted part)
2870: 0a 20 20 20 20 20 20 20 20 20 20 69 66 20 28 66  .          if (f
2880: 75 6c 6c 6e 61 6d 65 4c 6f 77 65 72 20 3d 3d 20  ullnameLower == 
2890: 6f 62 6a 65 63 74 20 7c 7c 20 70 61 72 74 73 5b  object || parts[
28a0: 70 61 72 74 73 2e 6c 65 6e 67 74 68 20 2d 20 31  parts.length - 1
28b0: 5d 20 3d 3d 20 6f 62 6a 65 63 74 29 20 7b 0a 20  ] == object) {. 
28c0: 20 20 20 20 20 20 20 20 20 20 20 73 63 6f 72 65             score
28d0: 20 2b 3d 20 53 63 6f 72 65 72 2e 6f 62 6a 4e 61   += Scorer.objNa
28e0: 6d 65 4d 61 74 63 68 3b 0a 20 20 20 20 20 20 20  meMatch;.       
28f0: 20 20 20 2f 2f 20 6d 61 74 63 68 65 73 20 69 6e     // matches in
2900: 20 6c 61 73 74 20 6e 61 6d 65 0a 20 20 20 20 20   last name.     
2910: 20 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28       } else if (
2920: 70 61 72 74 73 5b 70 61 72 74 73 2e 6c 65 6e 67  parts[parts.leng
2930: 74 68 20 2d 20 31 5d 2e 69 6e 64 65 78 4f 66 28  th - 1].indexOf(
2940: 6f 62 6a 65 63 74 29 20 3e 20 2d 31 29 20 7b 0a  object) > -1) {.
2950: 20 20 20 20 20 20 20 20 20 20 20 20 73 63 6f 72              scor
2960: 65 20 2b 3d 20 53 63 6f 72 65 72 2e 6f 62 6a 50  e += Scorer.objP
2970: 61 72 74 69 61 6c 4d 61 74 63 68 3b 0a 20 20 20  artialMatch;.   
2980: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
2990: 20 20 20 76 61 72 20 6d 61 74 63 68 20 3d 20 6f     var match = o
29a0: 62 6a 65 63 74 73 5b 70 72 65 66 69 78 5d 5b 6e  bjects[prefix][n
29b0: 61 6d 65 5d 3b 0a 20 20 20 20 20 20 20 20 20 20  ame];.          
29c0: 76 61 72 20 6f 62 6a 6e 61 6d 65 20 3d 20 6f 62  var objname = ob
29d0: 6a 6e 61 6d 65 73 5b 6d 61 74 63 68 5b 31 5d 5d  jnames[match[1]]
29e0: 5b 32 5d 3b 0a 20 20 20 20 20 20 20 20 20 20 76  [2];.          v
29f0: 61 72 20 74 69 74 6c 65 20 3d 20 74 69 74 6c 65  ar title = title
2a00: 73 5b 6d 61 74 63 68 5b 30 5d 5d 3b 0a 20 20 20  s[match[0]];.   
2a10: 20 20 20 20 20 20 20 2f 2f 20 49 66 20 6d 6f 72         // If mor
2a20: 65 20 74 68 61 6e 20 6f 6e 65 20 74 65 72 6d 20  e than one term 
2a30: 73 65 61 72 63 68 65 64 20 66 6f 72 2c 20 77 65  searched for, we
2a40: 20 72 65 71 75 69 72 65 20 6f 74 68 65 72 20 77   require other w
2a50: 6f 72 64 73 20 74 6f 20 62 65 0a 20 20 20 20 20  ords to be.     
2a60: 20 20 20 20 20 2f 2f 20 66 6f 75 6e 64 20 69 6e       // found in
2a70: 20 74 68 65 20 6e 61 6d 65 2f 74 69 74 6c 65 2f   the name/title/
2a80: 64 65 73 63 72 69 70 74 69 6f 6e 0a 20 20 20 20  description.    
2a90: 20 20 20 20 20 20 69 66 20 28 6f 74 68 65 72 74        if (othert
2aa0: 65 72 6d 73 2e 6c 65 6e 67 74 68 20 3e 20 30 29  erms.length > 0)
2ab0: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 76   {.            v
2ac0: 61 72 20 68 61 79 73 74 61 63 6b 20 3d 20 28 70  ar haystack = (p
2ad0: 72 65 66 69 78 20 2b 20 27 20 27 20 2b 20 6e 61  refix + ' ' + na
2ae0: 6d 65 20 2b 20 27 20 27 20 2b 0a 20 20 20 20 20  me + ' ' +.     
2af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2b00: 20 20 20 20 20 20 20 6f 62 6a 6e 61 6d 65 20 2b         objname +
2b10: 20 27 20 27 20 2b 20 74 69 74 6c 65 29 2e 74 6f   ' ' + title).to
2b20: 4c 6f 77 65 72 43 61 73 65 28 29 3b 0a 20 20 20  LowerCase();.   
2b30: 20 20 20 20 20 20 20 20 20 76 61 72 20 61 6c 6c           var all
2b40: 66 6f 75 6e 64 20 3d 20 74 72 75 65 3b 0a 20 20  found = true;.  
2b50: 20 20 20 20 20 20 20 20 20 20 66 6f 72 20 28 69            for (i
2b60: 20 3d 20 30 3b 20 69 20 3c 20 6f 74 68 65 72 74   = 0; i < othert
2b70: 65 72 6d 73 2e 6c 65 6e 67 74 68 3b 20 69 2b 2b  erms.length; i++
2b80: 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ) {.            
2b90: 20 20 69 66 20 28 68 61 79 73 74 61 63 6b 2e 69    if (haystack.i
2ba0: 6e 64 65 78 4f 66 28 6f 74 68 65 72 74 65 72 6d  ndexOf(otherterm
2bb0: 73 5b 69 5d 29 20 3d 3d 20 2d 31 29 20 7b 0a 20  s[i]) == -1) {. 
2bc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61                 a
2bd0: 6c 6c 66 6f 75 6e 64 20 3d 20 66 61 6c 73 65 3b  llfound = false;
2be0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
2bf0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20   break;.        
2c00: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
2c10: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
2c20: 20 20 69 66 20 28 21 61 6c 6c 66 6f 75 6e 64 29    if (!allfound)
2c30: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
2c40: 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20   continue;.     
2c50: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
2c60: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 76     }.          v
2c70: 61 72 20 64 65 73 63 72 20 3d 20 6f 62 6a 6e 61  ar descr = objna
2c80: 6d 65 20 2b 20 5f 28 27 2c 20 69 6e 20 27 29 20  me + _(', in ') 
2c90: 2b 20 74 69 74 6c 65 3b 0a 0a 20 20 20 20 20 20  + title;..      
2ca0: 20 20 20 20 76 61 72 20 61 6e 63 68 6f 72 20 3d      var anchor =
2cb0: 20 6d 61 74 63 68 5b 33 5d 3b 0a 20 20 20 20 20   match[3];.     
2cc0: 20 20 20 20 20 69 66 20 28 61 6e 63 68 6f 72 20       if (anchor 
2cd0: 3d 3d 3d 20 27 27 29 0a 20 20 20 20 20 20 20 20  === '').        
2ce0: 20 20 20 20 61 6e 63 68 6f 72 20 3d 20 66 75 6c      anchor = ful
2cf0: 6c 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 20  lname;.         
2d00: 20 65 6c 73 65 20 69 66 20 28 61 6e 63 68 6f 72   else if (anchor
2d10: 20 3d 3d 20 27 2d 27 29 0a 20 20 20 20 20 20 20   == '-').       
2d20: 20 20 20 20 20 61 6e 63 68 6f 72 20 3d 20 6f 62       anchor = ob
2d30: 6a 6e 61 6d 65 73 5b 6d 61 74 63 68 5b 31 5d 5d  jnames[match[1]]
2d40: 5b 31 5d 20 2b 20 27 2d 27 20 2b 20 66 75 6c 6c  [1] + '-' + full
2d50: 6e 61 6d 65 3b 0a 20 20 20 20 20 20 20 20 20 20  name;.          
2d60: 2f 2f 20 61 64 64 20 63 75 73 74 6f 6d 20 73 63  // add custom sc
2d70: 6f 72 65 20 66 6f 72 20 73 6f 6d 65 20 6f 62 6a  ore for some obj
2d80: 65 63 74 73 20 61 63 63 6f 72 64 69 6e 67 20 74  ects according t
2d90: 6f 20 73 63 6f 72 65 72 0a 20 20 20 20 20 20 20  o scorer.       
2da0: 20 20 20 69 66 20 28 53 63 6f 72 65 72 2e 6f 62     if (Scorer.ob
2db0: 6a 50 72 69 6f 2e 68 61 73 4f 77 6e 50 72 6f 70  jPrio.hasOwnProp
2dc0: 65 72 74 79 28 6d 61 74 63 68 5b 32 5d 29 29 20  erty(match[2])) 
2dd0: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 73 63  {.            sc
2de0: 6f 72 65 20 2b 3d 20 53 63 6f 72 65 72 2e 6f 62  ore += Scorer.ob
2df0: 6a 50 72 69 6f 5b 6d 61 74 63 68 5b 32 5d 5d 3b  jPrio[match[2]];
2e00: 0a 20 20 20 20 20 20 20 20 20 20 7d 20 65 6c 73  .          } els
2e10: 65 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  e {.            
2e20: 73 63 6f 72 65 20 2b 3d 20 53 63 6f 72 65 72 2e  score += Scorer.
2e30: 6f 62 6a 50 72 69 6f 44 65 66 61 75 6c 74 3b 0a  objPrioDefault;.
2e40: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
2e50: 20 20 20 20 20 20 72 65 73 75 6c 74 73 2e 70 75        results.pu
2e60: 73 68 28 5b 64 6f 63 6e 61 6d 65 73 5b 6d 61 74  sh([docnames[mat
2e70: 63 68 5b 30 5d 5d 2c 20 66 75 6c 6c 6e 61 6d 65  ch[0]], fullname
2e80: 2c 20 27 23 27 2b 61 6e 63 68 6f 72 2c 20 64 65  , '#'+anchor, de
2e90: 73 63 72 2c 20 73 63 6f 72 65 2c 20 66 69 6c 65  scr, score, file
2ea0: 6e 61 6d 65 73 5b 6d 61 74 63 68 5b 30 5d 5d 5d  names[match[0]]]
2eb0: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
2ec0: 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20     }.    }..    
2ed0: 72 65 74 75 72 6e 20 72 65 73 75 6c 74 73 3b 0a  return results;.
2ee0: 20 20 7d 2c 0a 0a 20 20 2f 2a 2a 0a 20 20 20 2a    },..  /**.   *
2ef0: 20 53 65 65 20 68 74 74 70 73 3a 2f 2f 64 65 76   See https://dev
2f00: 65 6c 6f 70 65 72 2e 6d 6f 7a 69 6c 6c 61 2e 6f  eloper.mozilla.o
2f10: 72 67 2f 65 6e 2d 55 53 2f 64 6f 63 73 2f 57 65  rg/en-US/docs/We
2f20: 62 2f 4a 61 76 61 53 63 72 69 70 74 2f 47 75 69  b/JavaScript/Gui
2f30: 64 65 2f 52 65 67 75 6c 61 72 5f 45 78 70 72 65  de/Regular_Expre
2f40: 73 73 69 6f 6e 73 0a 20 20 20 2a 2f 0a 20 20 65  ssions.   */.  e
2f50: 73 63 61 70 65 52 65 67 45 78 70 20 3a 20 66 75  scapeRegExp : fu
2f60: 6e 63 74 69 6f 6e 28 73 74 72 69 6e 67 29 20 7b  nction(string) {
2f70: 0a 20 20 20 20 72 65 74 75 72 6e 20 73 74 72 69  .    return stri
2f80: 6e 67 2e 72 65 70 6c 61 63 65 28 2f 5b 2e 2a 2b  ng.replace(/[.*+
2f90: 5c 2d 3f 5e 24 7b 7d 28 29 7c 5b 5c 5d 5c 5c 5d  \-?^${}()|[\]\\]
2fa0: 2f 67 2c 20 27 5c 5c 24 26 27 29 3b 20 2f 2f 20  /g, '\\$&'); // 
2fb0: 24 26 20 6d 65 61 6e 73 20 74 68 65 20 77 68 6f  $& means the who
2fc0: 6c 65 20 6d 61 74 63 68 65 64 20 73 74 72 69 6e  le matched strin
2fd0: 67 0a 20 20 7d 2c 0a 0a 20 20 2f 2a 2a 0a 20 20  g.  },..  /**.  
2fe0: 20 2a 20 73 65 61 72 63 68 20 66 6f 72 20 66 75   * search for fu
2ff0: 6c 6c 2d 74 65 78 74 20 74 65 72 6d 73 20 69 6e  ll-text terms in
3000: 20 74 68 65 20 69 6e 64 65 78 0a 20 20 20 2a 2f   the index.   */
3010: 0a 20 20 70 65 72 66 6f 72 6d 54 65 72 6d 73 53  .  performTermsS
3020: 65 61 72 63 68 20 3a 20 66 75 6e 63 74 69 6f 6e  earch : function
3030: 28 73 65 61 72 63 68 74 65 72 6d 73 2c 20 65 78  (searchterms, ex
3040: 63 6c 75 64 65 64 2c 20 74 65 72 6d 73 2c 20 74  cluded, terms, t
3050: 69 74 6c 65 74 65 72 6d 73 29 20 7b 0a 20 20 20  itleterms) {.   
3060: 20 76 61 72 20 64 6f 63 6e 61 6d 65 73 20 3d 20   var docnames = 
3070: 74 68 69 73 2e 5f 69 6e 64 65 78 2e 64 6f 63 6e  this._index.docn
3080: 61 6d 65 73 3b 0a 20 20 20 20 76 61 72 20 66 69  ames;.    var fi
3090: 6c 65 6e 61 6d 65 73 20 3d 20 74 68 69 73 2e 5f  lenames = this._
30a0: 69 6e 64 65 78 2e 66 69 6c 65 6e 61 6d 65 73 3b  index.filenames;
30b0: 0a 20 20 20 20 76 61 72 20 74 69 74 6c 65 73 20  .    var titles 
30c0: 3d 20 74 68 69 73 2e 5f 69 6e 64 65 78 2e 74 69  = this._index.ti
30d0: 74 6c 65 73 3b 0a 0a 20 20 20 20 76 61 72 20 69  tles;..    var i
30e0: 2c 20 6a 2c 20 66 69 6c 65 3b 0a 20 20 20 20 76  , j, file;.    v
30f0: 61 72 20 66 69 6c 65 4d 61 70 20 3d 20 7b 7d 3b  ar fileMap = {};
3100: 0a 20 20 20 20 76 61 72 20 73 63 6f 72 65 4d 61  .    var scoreMa
3110: 70 20 3d 20 7b 7d 3b 0a 20 20 20 20 76 61 72 20  p = {};.    var 
3120: 72 65 73 75 6c 74 73 20 3d 20 5b 5d 3b 0a 0a 20  results = [];.. 
3130: 20 20 20 2f 2f 20 70 65 72 66 6f 72 6d 20 74 68     // perform th
3140: 65 20 73 65 61 72 63 68 20 6f 6e 20 74 68 65 20  e search on the 
3150: 72 65 71 75 69 72 65 64 20 74 65 72 6d 73 0a 20  required terms. 
3160: 20 20 20 66 6f 72 20 28 69 20 3d 20 30 3b 20 69     for (i = 0; i
3170: 20 3c 20 73 65 61 72 63 68 74 65 72 6d 73 2e 6c   < searchterms.l
3180: 65 6e 67 74 68 3b 20 69 2b 2b 29 20 7b 0a 20 20  ength; i++) {.  
3190: 20 20 20 20 76 61 72 20 77 6f 72 64 20 3d 20 73      var word = s
31a0: 65 61 72 63 68 74 65 72 6d 73 5b 69 5d 3b 0a 20  earchterms[i];. 
31b0: 20 20 20 20 20 76 61 72 20 66 69 6c 65 73 20 3d       var files =
31c0: 20 5b 5d 3b 0a 20 20 20 20 20 20 76 61 72 20 5f   [];.      var _
31d0: 6f 20 3d 20 5b 0a 20 20 20 20 20 20 20 20 7b 66  o = [.        {f
31e0: 69 6c 65 73 3a 20 74 65 72 6d 73 5b 77 6f 72 64  iles: terms[word
31f0: 5d 2c 20 73 63 6f 72 65 3a 20 53 63 6f 72 65 72  ], score: Scorer
3200: 2e 74 65 72 6d 7d 2c 0a 20 20 20 20 20 20 20 20  .term},.        
3210: 7b 66 69 6c 65 73 3a 20 74 69 74 6c 65 74 65 72  {files: titleter
3220: 6d 73 5b 77 6f 72 64 5d 2c 20 73 63 6f 72 65 3a  ms[word], score:
3230: 20 53 63 6f 72 65 72 2e 74 69 74 6c 65 7d 0a 20   Scorer.title}. 
3240: 20 20 20 20 20 5d 3b 0a 20 20 20 20 20 20 2f 2f       ];.      //
3250: 20 61 64 64 20 73 75 70 70 6f 72 74 20 66 6f 72   add support for
3260: 20 70 61 72 74 69 61 6c 20 6d 61 74 63 68 65 73   partial matches
3270: 0a 20 20 20 20 20 20 69 66 20 28 77 6f 72 64 2e  .      if (word.
3280: 6c 65 6e 67 74 68 20 3e 20 32 29 20 7b 0a 20 20  length > 2) {.  
3290: 20 20 20 20 20 20 76 61 72 20 77 6f 72 64 5f 72        var word_r
32a0: 65 67 65 78 20 3d 20 74 68 69 73 2e 65 73 63 61  egex = this.esca
32b0: 70 65 52 65 67 45 78 70 28 77 6f 72 64 29 3b 0a  peRegExp(word);.
32c0: 20 20 20 20 20 20 20 20 66 6f 72 20 28 76 61 72          for (var
32d0: 20 77 20 69 6e 20 74 65 72 6d 73 29 20 7b 0a 20   w in terms) {. 
32e0: 20 20 20 20 20 20 20 20 20 69 66 20 28 77 2e 6d           if (w.m
32f0: 61 74 63 68 28 77 6f 72 64 5f 72 65 67 65 78 29  atch(word_regex)
3300: 20 26 26 20 21 74 65 72 6d 73 5b 77 6f 72 64 5d   && !terms[word]
3310: 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ) {.            
3320: 5f 6f 2e 70 75 73 68 28 7b 66 69 6c 65 73 3a 20  _o.push({files: 
3330: 74 65 72 6d 73 5b 77 5d 2c 20 73 63 6f 72 65 3a  terms[w], score:
3340: 20 53 63 6f 72 65 72 2e 70 61 72 74 69 61 6c 54   Scorer.partialT
3350: 65 72 6d 7d 29 0a 20 20 20 20 20 20 20 20 20 20  erm}).          
3360: 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  }.        }.    
3370: 20 20 20 20 66 6f 72 20 28 76 61 72 20 77 20 69      for (var w i
3380: 6e 20 74 69 74 6c 65 74 65 72 6d 73 29 20 7b 0a  n titleterms) {.
3390: 20 20 20 20 20 20 20 20 20 20 69 66 20 28 77 2e            if (w.
33a0: 6d 61 74 63 68 28 77 6f 72 64 5f 72 65 67 65 78  match(word_regex
33b0: 29 20 26 26 20 21 74 69 74 6c 65 74 65 72 6d 73  ) && !titleterms
33c0: 5b 77 6f 72 64 5d 29 20 7b 0a 20 20 20 20 20 20  [word]) {.      
33d0: 20 20 20 20 20 20 20 20 5f 6f 2e 70 75 73 68 28          _o.push(
33e0: 7b 66 69 6c 65 73 3a 20 74 69 74 6c 65 74 65 72  {files: titleter
33f0: 6d 73 5b 77 5d 2c 20 73 63 6f 72 65 3a 20 53 63  ms[w], score: Sc
3400: 6f 72 65 72 2e 70 61 72 74 69 61 6c 54 69 74 6c  orer.partialTitl
3410: 65 7d 29 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  e}).          }.
3420: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3430: 7d 0a 0a 20 20 20 20 20 20 2f 2f 20 6e 6f 20 6d  }..      // no m
3440: 61 74 63 68 20 62 75 74 20 77 6f 72 64 20 77 61  atch but word wa
3450: 73 20 61 20 72 65 71 75 69 72 65 64 20 6f 6e 65  s a required one
3460: 0a 20 20 20 20 20 20 69 66 20 28 24 75 2e 65 76  .      if ($u.ev
3470: 65 72 79 28 5f 6f 2c 20 66 75 6e 63 74 69 6f 6e  ery(_o, function
3480: 28 6f 29 7b 72 65 74 75 72 6e 20 6f 2e 66 69 6c  (o){return o.fil
3490: 65 73 20 3d 3d 3d 20 75 6e 64 65 66 69 6e 65 64  es === undefined
34a0: 3b 7d 29 29 20 7b 0a 20 20 20 20 20 20 20 20 62  ;})) {.        b
34b0: 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20  reak;.      }.  
34c0: 20 20 20 20 2f 2f 20 66 6f 75 6e 64 20 73 65 61      // found sea
34d0: 72 63 68 20 77 6f 72 64 20 69 6e 20 63 6f 6e 74  rch word in cont
34e0: 65 6e 74 73 0a 20 20 20 20 20 20 24 75 2e 65 61  ents.      $u.ea
34f0: 63 68 28 5f 6f 2c 20 66 75 6e 63 74 69 6f 6e 28  ch(_o, function(
3500: 6f 29 20 7b 0a 20 20 20 20 20 20 20 20 76 61 72  o) {.        var
3510: 20 5f 66 69 6c 65 73 20 3d 20 6f 2e 66 69 6c 65   _files = o.file
3520: 73 3b 0a 20 20 20 20 20 20 20 20 69 66 20 28 5f  s;.        if (_
3530: 66 69 6c 65 73 20 3d 3d 3d 20 75 6e 64 65 66 69  files === undefi
3540: 6e 65 64 29 0a 20 20 20 20 20 20 20 20 20 20 72  ned).          r
3550: 65 74 75 72 6e 0a 0a 20 20 20 20 20 20 20 20 69  eturn..        i
3560: 66 20 28 5f 66 69 6c 65 73 2e 6c 65 6e 67 74 68  f (_files.length
3570: 20 3d 3d 3d 20 75 6e 64 65 66 69 6e 65 64 29 0a   === undefined).
3580: 20 20 20 20 20 20 20 20 20 20 5f 66 69 6c 65 73            _files
3590: 20 3d 20 5b 5f 66 69 6c 65 73 5d 3b 0a 20 20 20   = [_files];.   
35a0: 20 20 20 20 20 66 69 6c 65 73 20 3d 20 66 69 6c       files = fil
35b0: 65 73 2e 63 6f 6e 63 61 74 28 5f 66 69 6c 65 73  es.concat(_files
35c0: 29 3b 0a 0a 20 20 20 20 20 20 20 20 2f 2f 20 73  );..        // s
35d0: 65 74 20 73 63 6f 72 65 20 66 6f 72 20 74 68 65  et score for the
35e0: 20 77 6f 72 64 20 69 6e 20 65 61 63 68 20 66 69   word in each fi
35f0: 6c 65 20 74 6f 20 53 63 6f 72 65 72 2e 74 65 72  le to Scorer.ter
3600: 6d 0a 20 20 20 20 20 20 20 20 66 6f 72 20 28 6a  m.        for (j
3610: 20 3d 20 30 3b 20 6a 20 3c 20 5f 66 69 6c 65 73   = 0; j < _files
3620: 2e 6c 65 6e 67 74 68 3b 20 6a 2b 2b 29 20 7b 0a  .length; j++) {.
3630: 20 20 20 20 20 20 20 20 20 20 66 69 6c 65 20 3d            file =
3640: 20 5f 66 69 6c 65 73 5b 6a 5d 3b 0a 20 20 20 20   _files[j];.    
3650: 20 20 20 20 20 20 69 66 20 28 21 28 66 69 6c 65        if (!(file
3660: 20 69 6e 20 73 63 6f 72 65 4d 61 70 29 29 0a 20   in scoreMap)). 
3670: 20 20 20 20 20 20 20 20 20 20 20 73 63 6f 72 65             score
3680: 4d 61 70 5b 66 69 6c 65 5d 20 3d 20 7b 7d 3b 0a  Map[file] = {};.
3690: 20 20 20 20 20 20 20 20 20 20 73 63 6f 72 65 4d            scoreM
36a0: 61 70 5b 66 69 6c 65 5d 5b 77 6f 72 64 5d 20 3d  ap[file][word] =
36b0: 20 6f 2e 73 63 6f 72 65 3b 0a 20 20 20 20 20 20   o.score;.      
36c0: 20 20 7d 0a 20 20 20 20 20 20 7d 29 3b 0a 0a 20    }.      });.. 
36d0: 20 20 20 20 20 2f 2f 20 63 72 65 61 74 65 20 74       // create t
36e0: 68 65 20 6d 61 70 70 69 6e 67 0a 20 20 20 20 20  he mapping.     
36f0: 20 66 6f 72 20 28 6a 20 3d 20 30 3b 20 6a 20 3c   for (j = 0; j <
3700: 20 66 69 6c 65 73 2e 6c 65 6e 67 74 68 3b 20 6a   files.length; j
3710: 2b 2b 29 20 7b 0a 20 20 20 20 20 20 20 20 66 69  ++) {.        fi
3720: 6c 65 20 3d 20 66 69 6c 65 73 5b 6a 5d 3b 0a 20  le = files[j];. 
3730: 20 20 20 20 20 20 20 69 66 20 28 66 69 6c 65 20         if (file 
3740: 69 6e 20 66 69 6c 65 4d 61 70 20 26 26 20 66 69  in fileMap && fi
3750: 6c 65 4d 61 70 5b 66 69 6c 65 5d 2e 69 6e 64 65  leMap[file].inde
3760: 78 4f 66 28 77 6f 72 64 29 20 3d 3d 3d 20 2d 31  xOf(word) === -1
3770: 29 0a 20 20 20 20 20 20 20 20 20 20 66 69 6c 65  ).          file
3780: 4d 61 70 5b 66 69 6c 65 5d 2e 70 75 73 68 28 77  Map[file].push(w
3790: 6f 72 64 29 3b 0a 20 20 20 20 20 20 20 20 65 6c  ord);.        el
37a0: 73 65 0a 20 20 20 20 20 20 20 20 20 20 66 69 6c  se.          fil
37b0: 65 4d 61 70 5b 66 69 6c 65 5d 20 3d 20 5b 77 6f  eMap[file] = [wo
37c0: 72 64 5d 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  rd];.      }.   
37d0: 20 7d 0a 0a 20 20 20 20 2f 2f 20 6e 6f 77 20 63   }..    // now c
37e0: 68 65 63 6b 20 69 66 20 74 68 65 20 66 69 6c 65  heck if the file
37f0: 73 20 64 6f 6e 27 74 20 63 6f 6e 74 61 69 6e 20  s don't contain 
3800: 65 78 63 6c 75 64 65 64 20 74 65 72 6d 73 0a 20  excluded terms. 
3810: 20 20 20 66 6f 72 20 28 66 69 6c 65 20 69 6e 20     for (file in 
3820: 66 69 6c 65 4d 61 70 29 20 7b 0a 20 20 20 20 20  fileMap) {.     
3830: 20 76 61 72 20 76 61 6c 69 64 20 3d 20 74 72 75   var valid = tru
3840: 65 3b 0a 0a 20 20 20 20 20 20 2f 2f 20 63 68 65  e;..      // che
3850: 63 6b 20 69 66 20 61 6c 6c 20 72 65 71 75 69 72  ck if all requir
3860: 65 6d 65 6e 74 73 20 61 72 65 20 6d 61 74 63 68  ements are match
3870: 65 64 0a 20 20 20 20 20 20 76 61 72 20 66 69 6c  ed.      var fil
3880: 74 65 72 65 64 54 65 72 6d 43 6f 75 6e 74 20 3d  teredTermCount =
3890: 20 2f 2f 20 61 73 20 73 65 61 72 63 68 20 74 65   // as search te
38a0: 72 6d 73 20 77 69 74 68 20 6c 65 6e 67 74 68 20  rms with length 
38b0: 3c 20 33 20 61 72 65 20 64 69 73 63 61 72 64 65  < 3 are discarde
38c0: 64 3a 20 69 67 6e 6f 72 65 0a 20 20 20 20 20 20  d: ignore.      
38d0: 20 20 73 65 61 72 63 68 74 65 72 6d 73 2e 66 69    searchterms.fi
38e0: 6c 74 65 72 28 66 75 6e 63 74 69 6f 6e 28 74 65  lter(function(te
38f0: 72 6d 29 7b 72 65 74 75 72 6e 20 74 65 72 6d 2e  rm){return term.
3900: 6c 65 6e 67 74 68 20 3e 20 32 7d 29 2e 6c 65 6e  length > 2}).len
3910: 67 74 68 0a 20 20 20 20 20 20 69 66 20 28 0a 20  gth.      if (. 
3920: 20 20 20 20 20 20 20 66 69 6c 65 4d 61 70 5b 66         fileMap[f
3930: 69 6c 65 5d 2e 6c 65 6e 67 74 68 20 21 3d 20 73  ile].length != s
3940: 65 61 72 63 68 74 65 72 6d 73 2e 6c 65 6e 67 74  earchterms.lengt
3950: 68 20 26 26 0a 20 20 20 20 20 20 20 20 66 69 6c  h &&.        fil
3960: 65 4d 61 70 5b 66 69 6c 65 5d 2e 6c 65 6e 67 74  eMap[file].lengt
3970: 68 20 21 3d 20 66 69 6c 74 65 72 65 64 54 65 72  h != filteredTer
3980: 6d 43 6f 75 6e 74 0a 20 20 20 20 20 20 29 20 63  mCount.      ) c
3990: 6f 6e 74 69 6e 75 65 3b 0a 0a 20 20 20 20 20 20  ontinue;..      
39a0: 2f 2f 20 65 6e 73 75 72 65 20 74 68 61 74 20 6e  // ensure that n
39b0: 6f 6e 65 20 6f 66 20 74 68 65 20 65 78 63 6c 75  one of the exclu
39c0: 64 65 64 20 74 65 72 6d 73 20 69 73 20 69 6e 20  ded terms is in 
39d0: 74 68 65 20 73 65 61 72 63 68 20 72 65 73 75 6c  the search resul
39e0: 74 0a 20 20 20 20 20 20 66 6f 72 20 28 69 20 3d  t.      for (i =
39f0: 20 30 3b 20 69 20 3c 20 65 78 63 6c 75 64 65 64   0; i < excluded
3a00: 2e 6c 65 6e 67 74 68 3b 20 69 2b 2b 29 20 7b 0a  .length; i++) {.
3a10: 20 20 20 20 20 20 20 20 69 66 20 28 74 65 72 6d          if (term
3a20: 73 5b 65 78 63 6c 75 64 65 64 5b 69 5d 5d 20 3d  s[excluded[i]] =
3a30: 3d 20 66 69 6c 65 20 7c 7c 0a 20 20 20 20 20 20  = file ||.      
3a40: 20 20 20 20 20 20 74 69 74 6c 65 74 65 72 6d 73        titleterms
3a50: 5b 65 78 63 6c 75 64 65 64 5b 69 5d 5d 20 3d 3d  [excluded[i]] ==
3a60: 20 66 69 6c 65 20 7c 7c 0a 20 20 20 20 20 20 20   file ||.       
3a70: 20 20 20 20 20 24 75 2e 63 6f 6e 74 61 69 6e 73       $u.contains
3a80: 28 74 65 72 6d 73 5b 65 78 63 6c 75 64 65 64 5b  (terms[excluded[
3a90: 69 5d 5d 20 7c 7c 20 5b 5d 2c 20 66 69 6c 65 29  i]] || [], file)
3aa0: 20 7c 7c 0a 20 20 20 20 20 20 20 20 20 20 20 20   ||.            
3ab0: 24 75 2e 63 6f 6e 74 61 69 6e 73 28 74 69 74 6c  $u.contains(titl
3ac0: 65 74 65 72 6d 73 5b 65 78 63 6c 75 64 65 64 5b  eterms[excluded[
3ad0: 69 5d 5d 20 7c 7c 20 5b 5d 2c 20 66 69 6c 65 29  i]] || [], file)
3ae0: 29 20 7b 0a 20 20 20 20 20 20 20 20 20 20 76 61  ) {.          va
3af0: 6c 69 64 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20  lid = false;.   
3b00: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
3b10: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a        }.      }.
3b20: 0a 20 20 20 20 20 20 2f 2f 20 69 66 20 77 65 20  .      // if we 
3b30: 68 61 76 65 20 73 74 69 6c 6c 20 61 20 76 61 6c  have still a val
3b40: 69 64 20 72 65 73 75 6c 74 20 77 65 20 63 61 6e  id result we can
3b50: 20 61 64 64 20 69 74 20 74 6f 20 74 68 65 20 72   add it to the r
3b60: 65 73 75 6c 74 20 6c 69 73 74 0a 20 20 20 20 20  esult list.     
3b70: 20 69 66 20 28 76 61 6c 69 64 29 20 7b 0a 20 20   if (valid) {.  
3b80: 20 20 20 20 20 20 2f 2f 20 73 65 6c 65 63 74 20        // select 
3b90: 6f 6e 65 20 28 6d 61 78 29 20 73 63 6f 72 65 20  one (max) score 
3ba0: 66 6f 72 20 74 68 65 20 66 69 6c 65 2e 0a 20 20  for the file..  
3bb0: 20 20 20 20 20 20 2f 2f 20 66 6f 72 20 62 65 74        // for bet
3bc0: 74 65 72 20 72 61 6e 6b 69 6e 67 2c 20 77 65 20  ter ranking, we 
3bd0: 73 68 6f 75 6c 64 20 63 61 6c 63 75 6c 61 74 65  should calculate
3be0: 20 72 61 6e 6b 69 6e 67 20 62 79 20 75 73 69 6e   ranking by usin
3bf0: 67 20 77 6f 72 64 73 20 73 74 61 74 69 73 74 69  g words statisti
3c00: 63 73 20 6c 69 6b 65 20 62 61 73 69 63 20 74 66  cs like basic tf
3c10: 2d 69 64 66 2e 2e 2e 0a 20 20 20 20 20 20 20 20  -idf....        
3c20: 76 61 72 20 73 63 6f 72 65 20 3d 20 24 75 2e 6d  var score = $u.m
3c30: 61 78 28 24 75 2e 6d 61 70 28 66 69 6c 65 4d 61  ax($u.map(fileMa
3c40: 70 5b 66 69 6c 65 5d 2c 20 66 75 6e 63 74 69 6f  p[file], functio
3c50: 6e 28 77 29 7b 72 65 74 75 72 6e 20 73 63 6f 72  n(w){return scor
3c60: 65 4d 61 70 5b 66 69 6c 65 5d 5b 77 5d 7d 29 29  eMap[file][w]}))
3c70: 3b 0a 20 20 20 20 20 20 20 20 72 65 73 75 6c 74  ;.        result
3c80: 73 2e 70 75 73 68 28 5b 64 6f 63 6e 61 6d 65 73  s.push([docnames
3c90: 5b 66 69 6c 65 5d 2c 20 74 69 74 6c 65 73 5b 66  [file], titles[f
3ca0: 69 6c 65 5d 2c 20 27 27 2c 20 6e 75 6c 6c 2c 20  ile], '', null, 
3cb0: 73 63 6f 72 65 2c 20 66 69 6c 65 6e 61 6d 65 73  score, filenames
3cc0: 5b 66 69 6c 65 5d 5d 29 3b 0a 20 20 20 20 20 20  [file]]);.      
3cd0: 7d 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75  }.    }.    retu
3ce0: 72 6e 20 72 65 73 75 6c 74 73 3b 0a 20 20 7d 2c  rn results;.  },
3cf0: 0a 0a 20 20 2f 2a 2a 0a 20 20 20 2a 20 68 65 6c  ..  /**.   * hel
3d00: 70 65 72 20 66 75 6e 63 74 69 6f 6e 20 74 6f 20  per function to 
3d10: 72 65 74 75 72 6e 20 61 20 6e 6f 64 65 20 63 6f  return a node co
3d20: 6e 74 61 69 6e 69 6e 67 20 74 68 65 0a 20 20 20  ntaining the.   
3d30: 2a 20 73 65 61 72 63 68 20 73 75 6d 6d 61 72 79  * search summary
3d40: 20 66 6f 72 20 61 20 67 69 76 65 6e 20 74 65 78   for a given tex
3d50: 74 2e 20 6b 65 79 77 6f 72 64 73 20 69 73 20 61  t. keywords is a
3d60: 20 6c 69 73 74 0a 20 20 20 2a 20 6f 66 20 73 74   list.   * of st
3d70: 65 6d 6d 65 64 20 77 6f 72 64 73 2c 20 68 6c 77  emmed words, hlw
3d80: 6f 72 64 73 20 69 73 20 74 68 65 20 6c 69 73 74  ords is the list
3d90: 20 6f 66 20 6e 6f 72 6d 61 6c 2c 20 75 6e 73 74   of normal, unst
3da0: 65 6d 6d 65 64 0a 20 20 20 2a 20 77 6f 72 64 73  emmed.   * words
3db0: 2e 20 74 68 65 20 66 69 72 73 74 20 6f 6e 65 20  . the first one 
3dc0: 69 73 20 75 73 65 64 20 74 6f 20 66 69 6e 64 20  is used to find 
3dd0: 74 68 65 20 6f 63 63 75 72 72 65 6e 63 65 2c 20  the occurrence, 
3de0: 74 68 65 0a 20 20 20 2a 20 6c 61 74 74 65 72 20  the.   * latter 
3df0: 66 6f 72 20 68 69 67 68 6c 69 67 68 74 69 6e 67  for highlighting
3e00: 20 69 74 2e 0a 20 20 20 2a 2f 0a 20 20 6d 61 6b   it..   */.  mak
3e10: 65 53 65 61 72 63 68 53 75 6d 6d 61 72 79 20 3a  eSearchSummary :
3e20: 20 66 75 6e 63 74 69 6f 6e 28 68 74 6d 6c 54 65   function(htmlTe
3e30: 78 74 2c 20 6b 65 79 77 6f 72 64 73 2c 20 68 6c  xt, keywords, hl
3e40: 77 6f 72 64 73 29 20 7b 0a 20 20 20 20 76 61 72  words) {.    var
3e50: 20 74 65 78 74 20 3d 20 53 65 61 72 63 68 2e 68   text = Search.h
3e60: 74 6d 6c 54 6f 54 65 78 74 28 68 74 6d 6c 54 65  tmlToText(htmlTe
3e70: 78 74 29 3b 0a 20 20 20 20 76 61 72 20 74 65 78  xt);.    var tex
3e80: 74 4c 6f 77 65 72 20 3d 20 74 65 78 74 2e 74 6f  tLower = text.to
3e90: 4c 6f 77 65 72 43 61 73 65 28 29 3b 0a 20 20 20  LowerCase();.   
3ea0: 20 76 61 72 20 73 74 61 72 74 20 3d 20 30 3b 0a   var start = 0;.
3eb0: 20 20 20 20 24 2e 65 61 63 68 28 6b 65 79 77 6f      $.each(keywo
3ec0: 72 64 73 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20  rds, function() 
3ed0: 7b 0a 20 20 20 20 20 20 76 61 72 20 69 20 3d 20  {.      var i = 
3ee0: 74 65 78 74 4c 6f 77 65 72 2e 69 6e 64 65 78 4f  textLower.indexO
3ef0: 66 28 74 68 69 73 2e 74 6f 4c 6f 77 65 72 43 61  f(this.toLowerCa
3f00: 73 65 28 29 29 3b 0a 20 20 20 20 20 20 69 66 20  se());.      if 
3f10: 28 69 20 3e 20 2d 31 29 0a 20 20 20 20 20 20 20  (i > -1).       
3f20: 20 73 74 61 72 74 20 3d 20 69 3b 0a 20 20 20 20   start = i;.    
3f30: 7d 29 3b 0a 20 20 20 20 73 74 61 72 74 20 3d 20  });.    start = 
3f40: 4d 61 74 68 2e 6d 61 78 28 73 74 61 72 74 20 2d  Math.max(start -
3f50: 20 31 32 30 2c 20 30 29 3b 0a 20 20 20 20 76 61   120, 0);.    va
3f60: 72 20 65 78 63 65 72 70 74 20 3d 20 28 28 73 74  r excerpt = ((st
3f70: 61 72 74 20 3e 20 30 29 20 3f 20 27 2e 2e 2e 27  art > 0) ? '...'
3f80: 20 3a 20 27 27 29 20 2b 0a 20 20 20 20 20 20 24   : '') +.      $
3f90: 2e 74 72 69 6d 28 74 65 78 74 2e 73 75 62 73 74  .trim(text.subst
3fa0: 72 28 73 74 61 72 74 2c 20 32 34 30 29 29 20 2b  r(start, 240)) +
3fb0: 0a 20 20 20 20 20 20 28 28 73 74 61 72 74 20 2b  .      ((start +
3fc0: 20 32 34 30 20 2d 20 74 65 78 74 2e 6c 65 6e 67   240 - text.leng
3fd0: 74 68 29 20 3f 20 27 2e 2e 2e 27 20 3a 20 27 27  th) ? '...' : ''
3fe0: 29 3b 0a 20 20 20 20 76 61 72 20 72 76 20 3d 20  );.    var rv = 
3ff0: 24 28 27 3c 64 69 76 20 63 6c 61 73 73 3d 22 63  $('<div class="c
4000: 6f 6e 74 65 78 74 22 3e 3c 2f 64 69 76 3e 27 29  ontext"></div>')
4010: 2e 74 65 78 74 28 65 78 63 65 72 70 74 29 3b 0a  .text(excerpt);.
4020: 20 20 20 20 24 2e 65 61 63 68 28 68 6c 77 6f 72      $.each(hlwor
4030: 64 73 2c 20 66 75 6e 63 74 69 6f 6e 28 29 20 7b  ds, function() {
4040: 0a 20 20 20 20 20 20 72 76 20 3d 20 72 76 2e 68  .      rv = rv.h
4050: 69 67 68 6c 69 67 68 74 54 65 78 74 28 74 68 69  ighlightText(thi
4060: 73 2c 20 27 68 69 67 68 6c 69 67 68 74 65 64 27  s, 'highlighted'
4070: 29 3b 0a 20 20 20 20 7d 29 3b 0a 20 20 20 20 72  );.    });.    r
4080: 65 74 75 72 6e 20 72 76 3b 0a 20 20 7d 0a 7d 3b  eturn rv;.  }.};
4090: 0a 0a 24 28 64 6f 63 75 6d 65 6e 74 29 2e 72 65  ..$(document).re
40a0: 61 64 79 28 66 75 6e 63 74 69 6f 6e 28 29 20 7b  ady(function() {
40b0: 0a 20 20 53 65 61 72 63 68 2e 69 6e 69 74 28 29  .  Search.init()
40c0: 3b 0a 7d 29 3b 0a                                ;.});.