1 Omega 1.4.26 (2024-07-18):
7 + Make robust to the indexer process being run with stdin or stdout closed.
11 * Support "bm25+" and "pl2+" in "$set{weighting,...}".
13 * Deprecate "lm" in "$set{weighting,...}". This was meant to implement the
14 "Language Model" Weighting scheme, but we've discovered the implementation
15 was incorrect and fixing it requires ABI-incompatible changes in xapian-core.
16 For 1.4.x we need to leave it in place so as not to break existing code, but
17 we recommended avoiding using it. It will be removed in the next release
18 series and replaced with new separate classes implementing Language Model
19 weighting with each smoothing.
21 * Add "prob" as new preferred name for probabilistic query expansion in
22 "$set{expansion,...}", with the previous "trad" still being accepted for now.
26 * Report result of probe to determine compiler support for -Werror or
29 * If pkg-config is available, use it to probe for libmagic.
31 * configure: Probe for closefrom(). Patch from Qiu Yingbo in
32 https://github.com/xapian/xapian/pull/323
36 * configure: Fix clang detection which wasn't working when configure determined
37 a -std=X option was needed to get C++11 support. The obvious symptom was
38 that --enable-werror wouldn't add -Werror.
40 * configure: NetBSD automatically pulls in library dependencies, so set
41 link_all_deplibs_CXX=no there.
43 * Define __WIN32__/__WIN64__ like we do for xapian-core. Spotted by Baran Demir.
45 * Avoid using sprintf() if snprintf() is available, even in cases where the
46 output size is bounded to avoid deprecation warnings on macOS. For 1.4.x
47 we still fall back to sprintf() to avoid a point release breaking support
48 for any platform still lacking snprintf().
50 * Use `override` for subclassing functors. This is good practice as it gives a
51 clear compile error if we have to change the signature of an virtual method
52 on such a functor. See #830.
54 * Fix building with MSVC - it seems to support AR=lib we need to use AM_PROG_AR
55 which probes for AR's command line interface.
57 Omega 1.4.25 (2024-03-08):
61 * omegatest.pl: Correct program name in error message.
65 * configure: DragonflyBSD automatically pulls in library dependencies, so set
66 link_all_deplibs_CXX=no there.
68 * configure: Avoid compiler warning during GCC version check when compiler
69 needs an option to enable C++11 support (same fix as applied to xapian-core
72 Omega 1.4.24 (2023-11-06):
76 * Document $filesize error handling.
82 + Implement piped input to filters for __WIN32__. Previously it looks like
83 the filter was run but the input wasn't connected to its stdin so it would
84 probably block indefinitely.
86 + Fix corner case in shell emulation - we no longer set environment variables
87 which start with a digit.
89 This issue was spotted from reading the code - in practice this isn't a
90 case that's likely to be encountered, and the previous behaviour doesn't
91 appear to have any security consequences even if a user was somehow tricked
92 into specifying an extraction command that did this.
96 + Check if we can actually support %z in parsedate action. Previously we
97 assumed we could if struct tm had a tm_gmtoff member, but that's only a
98 necessary condition and not sufficient, e.g. on Cygwin we have tm_gmtoff
99 but strptime() doesn't currently understand %z.
101 + If we were expecting an action but didn't get an identifier this triggered
102 an infinitely repeating error:
104 Unknown index action ''
106 Now we instead give a single error:
108 Expected index action, found '...'
110 where '...' shows the sequence of non-whitespace characters encountered.
114 * Run tests under eatmydata if available.
116 * Turn off MSYS2 argument conversion for tests as it breaks omegatest, and we
117 shouldn't need this conversion there.
119 * omegatest: Rewrite in Perl as we were hitting non-portable quoting issues
120 with the shell implementation, and really it had grown too large to make
121 sense as a shell script anyway.
125 * Add --enable-werror configure option.
127 * configure: Only auto-enable -D_FORTIFY_SOURCE=2 if it works without
128 additional libraries and remove the hard-coded block against using it
129 on mingw. Mingw-w64 v11.0.0 eliminated the requirement to link with -lssp
130 so we now auto-enable -D_FORTIFY_SOURCE=2 there.
134 * Fix to build on Cygwin.
136 * Rename our bswap32 helper function to avoid clash with system-provided
137 function on FreeBSD and NetBSD.
139 Omega 1.4.23 (2023-07-07):
143 * Improve documentation for OmegaScript numerical and logical operators. Patch
144 from Vaibhav Kansagara.
146 * Improve documentation for DATEVALUE, xFILTERS and $filters.
152 + Handle XPS files with multiple FixedDocument parts better. Previously we
153 only extracted text from the first FixedDocument part.
155 + Prefer latter subparts of multipart/alternative which is what RFC2046 (and
156 earlier RFCs which that obsoletes) say, but previously we used the first
157 subpart that we could get text from.
159 + Prefer latter subparts of multipart/alternative when indexing Outlook
162 + Fix obscure bug in --mimetype option. We keep track of the length of the
163 longest extension we have a mapping for, but this was being updated using
164 the length of the MIME type rather than the length of the extension.
165 Theoretically this could have led to us effectively ignoring a --mimetype
166 option, but in the real world the MIME type will probably always be longer
167 so this just results in us testing long extensions unnecessarily.
171 * Ignore DATEVALUE CGI parameter if START.n, etc is specified on the same
172 slot. We explicitly document not to do this, but if that advice is ignored
173 it's more helpful to at least preserve the property that we only have
174 one date range per value slot.
176 * Add flag_ngrams as a preferred new alias for flag_cjk_ngram. In the next
177 release series this feature has been expanded to cover many more languages
178 so the "cjk" in the name has become inaccurate as it stands for
179 "Chinese, Japanese and Korean".
181 * Fix handling of Outlook .msg containing Unicode. Codepoints <= U+00FF appear
182 to have been handled correctly, but anything higher resulted in individual
183 bytes of the UTF-8 encoding being treated as separate characters.
185 Fixes https://github.com/xapian/xapian/pull/326, reported by uhuntu.
189 * Fix compatibility code for old libmagic versions. The code we were using
190 seems like it would never have worked. Nobody's reported this (it was
191 spotted while looking at the code) so we could just require libmagic >= 4.22,
192 but it's trivial to actually handle so we've fixed the fallback code.
194 * Remove lingering traces of IRIX support as it's been dead for many years.
196 Omega 1.4.22 (2023-02-02):
200 * Improve term prefix documentation.
206 + Add --date-terms and --no-date-terms options.
208 + Extract page/sheet count for OpenDocument text documents and spreadsheets.
210 + Extract created date and keywords for MS XML formats.
214 + Fix handling of an unterminated final line in input file.
218 * Add OmegaScript commands to report value slot bounds.
220 * Add OmegaScript $sortableunserialise{} command.
222 Omega 1.4.21 (2022-09-22):
226 * Consistently say "macOS" not "Mac OS X", "OS X", etc.
232 + Add support for gzip-compressed SVG files (.svgz).
234 + Handle <title> in SVG. Previously only <dc:title> inside <metadata> was
235 considered. If both are present, <title> now takes precedence.
239 * omegatest: Add skip-for-32-bit-time_t mechanism and use it to conditionally
240 enable some testcases which fail on platforms with 32-bit time_t.
244 * Update to use AX_CXX_COMPILE_STDCXX which is a replacement for
245 AX_CXX_COMPILE_STDCXX_11 (which we were using) which also supports newer C++
246 standards versions which will be useful. For C++11 the only difference seems
247 to be that the macro now checks for attribute support - we use C++11
248 attributes so that seems a good thing.
250 Omega 1.4.20 (2022-07-04):
256 + OpenDocument: Previously we only inserted an implicit space before each
257 paragraph. Now we insert them both before and after each paragraph and
258 heading, and before forced each line-break and tab.
260 + Add extension mapping for .awt (Abiword templates).
262 + Index metadata from XPS files.
264 + -G and -C short options were documented in --help but not previously
265 actually handled. Reported by David Bremner.
267 + Show --max-size required argument in --help output.
269 + Remove lingering handling for database backends without slot bounds since
270 all backends have been required to support these since 1.4.11.
274 + Process an incomplete final line from a dump file. Previously if the final
275 line lacked a newline scriptindex would quietly ignore it (unless it was
278 + The `unique` action now takes an optional `missing` parameter to specify
279 what to do if a record doesn't trigger the unique action or triggers it
280 with an empty value. The default is now to issue a warning and create a
281 new document (the same as before, except that there was only previously a
282 warning for the empty value case). In Omega 1.5.0 the default will change
283 to an error as that seems a better default, but is less compatible with
284 potential existing use.
286 + Explicitly allow multiple blank lines in input files. Previously such
287 extra blank lines were treated as empty records and in many cases these
288 got quietly skipped, but e.g. with the new UNIQUE checks this could result
289 in a warning or error.
291 + If we hit an error while parsing the index script we used to exit right
292 away, but now we finish parsing the index script since it's more helpful to
293 report all the errors in an index script rather than the user having to
294 fix them one by one. This requires us to sensibly recover after each index
295 script parse error - if you find a case where this recovery triggers
296 further bogus errors please report it and we'll try to improve the
299 + In four cases while handling input data (two cases of bad hex data fed
300 to `hextobin`, an input data line without a `=`, and `load` failing to
301 load the specified file) we'd emit a diagnostic that was labelled as an
302 "error" but really it was handled as a warning as we kept reading input
303 and the "error" didn't affect the exit status. It doesn't really make
304 sense to continue in any of these cases so we now exit with non-zero status
307 + A parameter in the index script which should be an integer but isn't, or
308 should be positive but isn't now gives an error rather than a warning since
309 an error seems more helpful.
311 + All diagnostics issued while parsing the index script now include column
314 + Avoid forcibly flushing the output stream after every message.
318 * Improve test coverage for scriptindex.
322 * Require PCRE2 instead of PCRE. The original PCRE is now EOL and unmaintained
323 (last release was June 2021). In omega it's potentially used to process
324 input from the internet, so security is a real concern hence we're switching
327 Omega 1.4.19 (2021-12-31):
331 * configure: Add missing AC_ARG_VAR for all programs so that they are
332 documented in --help output, and so that autoconf knows they are "precious"
333 and preserves them if configure is rerun even when they're specified via an
334 environment variable.
336 * Add usage examples for $jsonobject.
338 * Fix path to omega in quickstart document. Fixes #813, reported by Jim Lynch.
340 * Update for the IRC channel move from freenode to libera.chat.
344 * Fix handling of UTF-16 BOMs in XML and HTML - we had the sense of the
345 endianness indicated by the BOM the wrong way round.
347 * Avoid making an extra temporary copy of HTML/XML data which has a UTF16 BOM.
349 * We now ignore an end of line immediately after a PHP close tag to match what
354 + Fix handling of formatted xlsx dates in certain cases.
358 + Add new scriptindex whitespace removal actions `ltrim`, `rtrim`, `squash`,
361 + Improve `truncate` action - if a word ends exactly on the requested length
362 we now leave it in place rather than removing it.
364 + Report the location of previous `unique` action in the error given when
365 `unique` is used more than once.
369 * Clamp START and END with packed timestamps. The 4-byte unsigned packed
370 time_t format can't represent dates before 1970 or after Sun 07 Feb 2106
371 06:28:15 UTC so clamp dates before or after these - previously they would
374 * The JSON produced by $jsonobject no longer contains newlines, which makes it
375 usable as a single line serialisation format without post-processing.
377 * Add $base64 OmegaScript command.
379 * omega: Add flag_no_positions to wrap new
380 Xapian::QueryParser::FLAG_NO_POSITIONS.
384 * Fix topterms template to not trigger early matching. We were checking $msize
385 before including the `query` template, but doing so would trigger the query
386 to be run, which means that settings early in the `query` template which
387 should affect the result (such as $setmap{prefix,...}) were being ignored
388 when the `topterms` template was used. Partly addresses #815, reported by
391 * Add field support to opensearch and xml templates. These templates now also
392 search title, topic and filename by default and support `title:`, `author:`
393 and `topic:` in the query string (both like the template `query` already
394 does). Fixes remaining issue in #815, reported by Gennadiy.
398 * Expand omegatest. All scriptindex actions now have test coverage.
402 * Replace uses of obsolete autoconf macros, fixing warnings if configure is
403 regenerated with a recent release of autoconf.
407 * Don't automatically use _FORTIFY_SOURCE on mingw-w64. Recent mingw-w64
408 versions require -lssp to be linked when _FORTIFY_SOURCE is enabled, so just
409 skip the automatic enabling. Users who want to enable it can specify it
412 Fixes #808, reported by xpbxf4.
414 * Automatically enable GCC warnings -Wduplicated-cond and -Wduplicated-branches
415 if using a GCC version new enough to support them. The usefulness of
416 -Wduplicated-cond was highlighted by dcb in #816.
418 * Fix GCC -Wshadow warning.
420 * Use clock_gettime() and nanosleep() under modern mingw as these allow higher
421 precision than what we previously used.
423 Omega 1.4.18 (2021-01-14):
429 + Add default MIME mapping for application/rtf. IANA have registrations for
430 text/rtf and (more recently) application/rtf (it seems because newer
431 versions of the RTF format can contain 8-bit data) so we now recognise
432 application/rtf by default and handle it the same way as text/rtf.
434 Current libmagic seems to always return text/rtf (no matches for
435 application/rtf in magic.mgc) and we continue to map extension rtf to
436 text/rtf, so this change is mainly future-proofing against libmagic future
439 + Add support for indexing OpenXPS, which is effectively the same as XPS
440 internally in ways we care about, but it uses a different mimetype and a
441 different filename extension.
445 * Explicitly use OR for MORELIKE queries.
447 Since 1.3.0 the default value of DEFAULTOP has been AND, which typically
448 makes MORELIKE queries much less useful since they'll only match documents
449 containing all the terms from the query expansion. We now explicitly insert
450 " OR " between the terms if DEFAULTOP hasn't been set to OR, which makes them
451 work much more like they did in 1.2.x.
453 * Make $stoplist and $unstem consider all query strings by always passing the
454 new Xapian::QueryParser::FLAG_ACCUMULATE flag.
456 * Add $foreach command which works like $map, but just concatenates the
457 evaluated results rather than adding tabs to turn them into an OmegaScript
460 * Extend $include{} to allow handling failure to open the specified file via an
461 optional second argument which if specified will be evaluated and returned
462 instead. Patch from Gaurav Arora.
464 * Support multiple MORELIKE parameters - we now form an RSet from all the
465 specified documents and use that to generate the query to run (previously
466 only one of multiple MORELIKE parameters was used).
468 Omega 1.4.17 (2020-08-21):
472 * Document comment format supported by scriptindex index scripts. We've
473 supported comments on a line by themselves and introduced with a # since
474 scriptindex was first added back in 2002, but it seems have never actually
475 been documented before now.
479 * Check for SERVER_PROTOCOL=INCLUDED before anything which might throw an
480 exception so that if it is set we suppress the Content-Type: when reporting
481 such exceptions. Spotted by Gaurav Arora.
483 * Report get_description() for Xapian::Error exceptions instead of get_msg().
484 This means we now report the exception's type, context (useful for network
485 errors), and errno information.
487 * Avoid leaking MyStopper object. The object essentially has the lifespan of
488 omega itself, but becomes unreachable when the QueryParser object is
489 destroyed. To make it easier to use leak-checking tools, hand ownership of
490 this object to the QueryParser object.
494 * omegatest: Tell leak sanitizer not to report leaks for allocations which
495 aren't explicitly released on exit - the OS will reclaim all memory from the
496 process at this point and explicitly releasing everything just takes time for
497 no real benefit. We will still see leaks of objects which become unreachable
500 Omega 1.4.16 (2020-06-08):
504 * Fix handling of XML empty tag syntax when there's a quoted parameter right
505 before the closing `/>`. This caused `<title xml:lang="en-US"/>` to treat
506 the body text as the document title. Spotted by Gaurav Arora.
508 * omindex: Fix killing of filter child process if the parent process receives a
509 signal. Spotted by Gaurav Arora.
513 * Reject $setrelevant without an argument list. This has never been documented
514 as allowed, and previously crashed with a segfault. Fixes #802, reported by
517 * If there's an error opening the databases we now close any we managed to open
518 successfully before the error so that things like $dbsize can't end up
519 reporting values for a subset of the specified databases.
523 * Use our own autoconf cache variable namespace (xo_cv_ prefix instead of
524 ac_cv_) to avoid colliding with standard autoconf macro use if config.site or
525 a shared config.cache is used. The former case caused a build failure for
526 the OpenBSD port with 1.4.15, reported by Lucas R.
528 Omega 1.4.15 (2020-02-24):
532 * Update documentation about how to add a new format to omindex. Patch from
537 * Check for a BOM on HTML files, which for HTML5 should determine the encoding.
541 * Allow $if{COND} without any actions which is useful as a way to evaluate
542 something but ignore the result if you just want the side effects. Indeed
543 we were already recommending to use it if you want to ignore the return value
544 of $log. Fixes bug introduced in 1.4.14, reported by tuftedocelot.
546 * Add OmegaScript support for $jsonbool{COND} for encoding a boolean value for
547 use in JSON. This is equivalent to $if{COND,true,false} but more readable.
549 * Add OmegaScript support for $jsonobject{} which allows producing a JSON
550 object from an OmegaScript map.
552 * Allow specifying a format to $jsonarray{} so it is no longer restricted to
553 producing an array of strings.
555 * Add $keys{MAP} OmegaScript command which gives a sorted list of the keys from
560 * Simplify probes for snprintf. The broken snprintf in libbsd in Linux libc4
561 is from ~25 years ago so way too ancient to matter now, and all callers
562 already handle the pre-ISO semantics of returning -1 for an undersize buffer
563 so we don't need to run a test program to probe for this at configure time,
564 which is more cross-compile friendly.
566 * Avoid deprecation warning on recent Linux. We were including sys/sysctl.h if
567 it existed, which it does on Linux but we don't actually use it there.
568 Including it now warns that it is deprecated, so skip including it under
569 Linux. Reported on IRC by kumaran.
571 Omega 1.4.14 (2019-11-23):
575 * Improve omindex --help docs for --duplicates.
579 * Add built-in support for iso-8859-15 so we can handle it without iconv.
580 This charset is a variant of iso-8859-1 with 8 characters changed, most
581 notably including the euro currency symbol. It's the most commonly seen
582 charset we didn't have built-in support for.
586 * Fix error handling in $lookup. We now check for errors from cdb_init()
587 and cdb_get(). We've never checked for errors from cdb_init(), while
588 for cdb_get() this bug was introduced by a warning fix in 1.2.20.
590 Omega 1.4.13 (2019-10-14):
594 * Document that $log will start to return an error message in 1.5.0, and that
595 one can wrap it using a $if with no action now to be future-proof.
599 * Optimise converting us-ascii to UTF-8 to do nothing, like we already do when
600 converting UTF-8 to UTF-8.
604 + Add new 'gap' action which provides a way to leave a gap in the term
605 positions between fields to prevent phrases and positional operators from
606 matching across fields.
610 * Future-proof use of $log against changes in 1.5.0.
612 Omega 1.4.12 (2019-07-23):
616 * Improve docs for OmegaScript $hitlist{}.
618 * Fix RST formatting errors in omega docs.
620 * Clarify use of Q prefix for unique ID terms - it was described as "reserved",
621 but the use of "Q" is really just a convention (and in fact omindex uses "U"
624 * Clarify scriptindex's weight action takes parameter >= 0.
626 * Correct typo in OmegaScript $add parameter documentation.
632 + Fix typo in mimetypes used for Apple iWork documents ("apply" instead of
633 "apple") which meant that these documents weren't actually being indexed.
634 Patch from Bruno Baruffaldi.
636 + Pipe input to ps2pdf as this accepts input on stdin. Possibility pointed
641 + If parsedate action's format includes %z adjust for the timezone if
642 possible (this requires the non-POSIX tm_gmtoff member of struct tm)
643 and flag an error for other platforms.
645 + If parsedate action's format include %Z flag an error as that doesn't
646 seem to be usefully supported by strptime() anywhere.
648 + Fix parsedate action to treat formats without a timezone as being UTC
649 instead of localtime.
651 + Add date=unixutc. The existing date=unix works in localtime which is
652 unhelpful if you want to use it on the output of parsedate since that's in
653 UTC; date=unixutc is just like date=unix except it always works in UTC.
655 + The date action now emits a warning for invalid values. The documentation
656 used to say "invalid values are ignored at present", but it's more helpful
657 to flag bad data than quietly ignore it.
659 + We now check the date action's parameter at script parse time and unknown
660 values result in an error and nothing being indexed. Previously an unknown
661 format uselessly resulted in the terms D, M and Y literally being added to
664 + The split action now supports a new "prefixes" split style. This gives all
665 the prefixes from the split, so split=/,prefixes on a file path gives all
670 * Remove documented limitation of $subdb and $subid - the implementation
671 assumed that each omega database name corresponded to a single Xapian
672 database, and if a database name referred to a stub database file expanding
673 to multiple Xapian databases then they would misbehave. Such cases are now
674 handled properly as well.
676 * Extend $addfilter to support adding negated filters via a new optional second
677 argument which specifies the type of filter to add.
679 * Stop $sort from needlessly ensuring the match has run.
681 * Handle corner case of nested $hitlist gracefully instead of potentially
682 entering an infinite loop.
686 * omegatest: Avoid setting TZ globally during tests as that hides bugs where
687 behaviour depends on the local timezone when it shouldn't.
689 * omegatest: Support testing when built using LeakSanitizer by suppressing
690 leak reports for cached compiled pcre regular expressions. These aren't
691 released when the program exits but aren't memory leaks.
695 * Remove outdated deprecation warning suppression which was there to support
696 building from git in the run up to 1.3.2 - a development version which is
697 nearly 5 years ago now.
701 * Fix problems with fallback strptime() implementation which was being included
702 in the wrong binary, and was lacking a required const_cast on the return
705 * Rework setenv() compatibility handling. Now that Solaris 9 is dead we can
706 assume setenv() is provided by Unix-like platforms (POSIX requires it). For
707 other platforms, provide a compatibility implementation of setenv() so the
708 compatibility code is encapsulated in one place rather than replicated at
711 Omega 1.4.11 (2019-03-02):
717 + outlookmsg2html: Handle Subject, Date, and From headers.
721 * In $div and $mod we were converting a non-zero denominator from string to int
722 twice for no good reason.
726 * omegatest: Fix testcase which was failing if the local timezone was behind
727 UTC. This testcase was added in 1.4.10.
729 * omegatest: Tweak to not fail when $time not supported - it seems that the
730 OS time functions we use report an error on GNU Hurd for unknown reasons.
734 * Sync up probes for OS time functions in omega's configure with those in
735 xapian-core which may solve $time not being supported on GNU Hurd.
739 * Add missing includes of <cerrno>. Fixes #776, reported by Matthieu Gautier.
741 * Stop using htonl()/ntohl() in a non-network context which should improve
742 portability to platforms without a POSIX-like socket API.
744 Omega 1.4.10 (2019-02-12):
748 * Use https for URLs where supported.
754 + Index .apxl and .kth files as Apple Keynote. The .apxl extension is used
755 for the XML files inside .key bundles/directories which hold the text
756 content of the presentation, and by handling them we can index .key
757 directories more usefully. It seems they are also sometimes found by
758 themselves. Keynote themes have a .kth extension, and key2text can also
761 + Pipe input to pdftotext, pdfinto and dpkg. These tools all support piping
762 an input file on stdin, which can be a little more efficient when we
763 already have the file open (e.g. to determine its type using libmagic, or
764 to calculate its checksum).
766 + An empty string for the start directory is now flagged as an error.
767 Previously `/` was used instead, which is unlikely to be what is wanted
768 (and `/` can be explicitly specified if that really is what is wanted).
770 + Fix emulation of stderr redirection when the indexer's stderr has been
771 closed. We try to avoid using the shell when running external filters, and
772 emulate 2>/dev/null in commands, but if the indexer's stderr was closed
773 this emulation was buggy and would make give the filter a closed stderr
774 instead of one redirected to /dev/null.
776 + When emulating redirection to /dev/null, we now open /dev/null once and
777 dup that fd each time which is a little more efficient and simplifies the
782 + date=unix is now a no-op for empty input - previously it would unhelpfully
783 add boolean date terms for 1970-01-01.
785 + Warn for empty filename in LOAD action. Previously this gave a slightly
786 confusing error: "Couldn't load file '': No such file or directory"
788 + Unknown command-line options now cause scriptindex to give a non-zero exit
793 * omegatest: Add testcase for SPAN.n on different slots.
795 * omegatest: Update expected QueryParser output for the xapian-core change to
796 produce flatter Query trees.
800 * Use AM_ICONV to detect iconv() which should handle non-system install of GNU
801 libiconv properly. Fixes #775, reported by Ryan Schmidt.
805 * Provide fall-back strptime() implementation for platforms which don't provide
806 it, using the C++11 std::get_time() function. We use strptime() directly
807 where it's available as some older C++11 compilers seem to lack
808 std::get_time() (GCC 4.8 for example). This is used by the parsedate action,
809 which was added in 1.4.6.
811 Omega 1.4.9 (2018-11-02):
817 + Try harder to avoid opening a file being indexed more than once by
818 reusing the file descriptor in more cases.
820 + Hint to the OS not to cache output from external filters which require
821 using a temporary file.
825 + If the LOAD action successfully opens a file but hits a read error the
826 error message now reports the file name correctly. Previously it would
827 report the partial file contents read so far instead of the file name.
831 * We no longer call posix_fadvise() with POSIX_FADV_NOREUSE under Linux,
832 since it's still not implemented there. We also now only call
833 posix_fadvise() with POSIX_FADV_DONTNEED right before we close the file
834 descriptor under Linux.
836 Omega 1.4.8 (2018-10-25):
840 * Assorted minor documentation improvements.
846 + Improve date handling in .eml files. We now handle a "Date:" header
847 without the day of the week, which is allowed by RFC822 and RFC2822
848 (though seems rare in practice). If the date can't be parsed, we now
849 just omit the date information rather than failing to process the file.
851 + Add support for indexing Apple iWork documents (Keynote (.key), Numbers
852 (.numbers) and Pages (.pages)) using libetonyek. Currently only the file
853 variants are handled since omindex doesn't currently support indexing a
854 directory as a document.
856 + Index Visio files using vsd2xhtml.
858 + Extend --filter to support filters which produce SVG as output.
860 + Handle SVG embedded in XML with svg: namespace prefix.
862 + Add --read-filters option to read a list of filters from a file, each line
863 of which is a rule as passed to --filter. Based on a patch from Gaurav
866 + Add new --mime-type-match option which allows specifying a MIME
867 Content-Type for a given shell filename pattern pattern (with the special
868 Content-Type values "ignore" and "skip" supported, as for --mime-type).
870 + Adjust --mime-type to allow ':' in the extension. A valid MIME
871 Content-Type can't contain a colon, so if the argument to --mime-type
872 contains more than one colon it makes more sense to split at the *last*
873 colon (we used to split at the first), as an extension could conceivably
874 contain a colon. Mostly this change is for consistency with the new
875 --mime-type-match option, where the leafname pattern could reasonably
878 + Remove failed entries for ignored files. If a file is mapped to
879 pseudo-mimetype "ignore" then remove any existing failure record for it so
880 that ignored files so we don't potentially end up with a lot of cruft
881 failure records for files we are no longer trying to index.
883 + If a file fails to index due to failing to allocate enough memory we now
884 try to flag it as failed to index so it will be skipped by default on
885 future runs. This should help to avoid indexing getting stuck on
888 + Add a "pages" field with the number of pages in the document where we
889 know how to determine this (currently only for PDF files for which pdfinfo
890 reports this information).
892 + Handle initially empty database exactly the same was as when --overwrite
893 is specified. This probably has no user-visible consequences, but it's
894 cleaner for the handling to be exactly the same.
898 + Improve scriptindex diagnostic messages. All diagnostics are now labelled
899 as "error", "warning" or "note" as appropriate, and we now consistently
900 report "FILE:LINE:" (and also "COLUMN:" in most cases) to make it clearer
901 where the problem lies.
903 + Add new "split" action which splits the text on a specified delimiter and
904 executes the following actions for each piece. Based on a patch by Gaurav
907 + Missing whitespace after the closing " on an action argument is now
908 flagged as an error. Previously scriptindex would attempt to parse
909 the following characters as the next action.
911 + Support C-like escapes for quoted parameter values. Notably this means it
912 is now possible to include `"` in quoted parameter values.
916 + Value-based date range filters can now be specified via CGI parameters
917 START.N, END.N and/or SPAN.N where N is a value slot number, allowing
918 multiple concurrent filters on different slots to be specified.
920 + Support YYYY and YYYYMM limits in term-based date ranges. Previously
921 value-based date ranges supported these as limits, but term-based date
922 ranges gave an error.
924 + Add stem_strategy option and deprecate existing stem_all option in favour
925 of this new more versatile option.
927 + Support "natural" $sort option via new flag "#" which sorts embedded
928 natural numbers in numerical order.
930 + Support numeric $sort option via new flag "n", similar to GNU sort -n.
932 + Rewrite field parsing to be more efficient, and store fields in an
933 unordered_map for faster lookup.
937 * htmlparsetest: Test whitespace collapsing.
941 * omegatest: Avoid "set -". The autoconf manual notes that POSIX no longer
942 requires this, and that with traditional shells it resets -v and -x which
943 makes debugging harder.
945 * omegatest: Fix shell printf quoting issues which were a latent bug on macOS.
947 * Drop special handling for Compaq C++. We never actually achieved a working
948 build using it, and I can find no evidence that this compiler still exists,
949 let alone that it was updated for C++11 which we now require.
951 Omega 1.4.7 (2018-07-19):
955 * New OmegaScript $unique command. The existing $uniq only removes adjacent
956 entries (like the Unix uniq command) so to fully remove duplicates you need a
957 sorted input. Sometimes it is desirable to remove duplicates from an
958 unsorted list without changing the order of the entries which are left, so
959 add $unique to do that. If the list is sorted already, then $uniq is more
962 * Fix $map to cleanly reject a single argument.
966 * templates/query: Merge multiple entries in the term frequency information,
967 which came from searching several prefixes by default. Reported by Alistair
968 Buxton on #xapian-discuss.
970 * When multiple words with the same stem are in the query string we now fully
971 eliminate duplicates when showing term frequency information.
973 Omega 1.4.6 (2018-07-02):
977 * Fix generate_sample() (used by OmegaScript $truncate and omindex) to return
978 an empty sample instead of throwing an exception when the requested sample
979 size is less than the size of the truncation indicator string. Patch from
980 Addy. Fixes https://trac.xapian.org/ticket/754 reported by Gaurav Arora.
984 * Use terminology "value slot number" instead of "value number".
986 * Stop talking about "probabilistic terms" and "probabilistic queries" - we've
987 supported other families of weighting schemes since 1.3.2.
991 * Check for the HTML5 doctype or legacy doctype declaration and use default
992 charset UTF-8 if either is present. Previously we always used ISO-8859-1,
993 which is correct for older HTML versions, but not for HTML5.
997 + When running commands without going through the shell, emulate shell exit
998 codes 127 (for command not found) and 126 (for other cases where we fail to
999 run the command). This means the "missing filter" handling should now work
1000 properly for such commands. Noted by Gaurav Arora.
1002 + Index POD files despite minor formatting errors. We now pass
1003 --errors=stderr to pod2text so that minor formatting errors don't prevent
1004 us from indexing a file. (It may seem that --errors=none is a better
1005 option, but for podlators < 4.11 that results in an ERRATA section in the
1006 generated text version which we then end up indexing; 4.11 fixed that but
1007 we can't assume that's in use). Reported by Gaurav Arora.
1011 + Avoid some unnecessary copying of Action objects by making use of C++11
1014 + Consistently send errors to stderr - some were sent to stdout.
1015 Patch from Gaurav Arora.
1017 + Add new "hextobin" action. Based on a patch from Gaurav Arora.
1019 + Warn about non-integer arg to hash.
1021 + Fix hash action without an argument, which was failing with an assertion.
1022 Based on a patch by Gaurav Arora: https://github.com/xapian/xapian/pull/189
1024 + Reject 'hash' with argument < 6. The hashing truncates and then adds a
1025 6 character hash of the removed part, so can't produce a result shorter
1026 than 6 characters. Patch from Gaurav Arora.
1028 + Look for alphanumerics when parsing index actions. None of the current
1029 index actions contain digits, but we give more helpful error messages this
1032 + Deprecate allowing spaces around = in scripts. This was never documented
1033 as supported, and leads to a missing argument quietly swallowing the next
1034 action rather than using an empty value or giving an error. Reported by
1035 Gaurav Arora in https://github.com/xapian/xapian/pull/182
1037 + In boolean and unique actions, add a colon between prefix and term when
1038 the term starts with a colon. This means the mapping is reversible, and
1039 matches what omega actually does in this case when it tries to reverse the
1040 mapping. Thanks to Andy Chilton for pointing out this corner case.
1042 + Add parsedate and valuepacked actions. Together these assist adding date
1043 values for sorting and date range filtering. Based on a patch from Gaurav
1046 + Use DB_RETRY_LOCK to wait if the database is already in use rather than
1047 sleeping for a second and retrying. On most platforms this means we make a
1048 blocking request for the lock, and even on platforms where that's not
1049 supported, we now sleep and retry inside libxapian, and without having to
1050 throw and catch an exception each time.
1054 * $freq: Speed up some cases by avoiding throwing and catching an exception
1055 when we know the MSet has no term frequency information.
1057 * $sort: New OmegaScript command which does a string sort on an OmegaScript
1058 list, with u (unique) and r (reverse) options.
1060 * $cond: New OmegaScript conditional multi-way conditional. Inspired by LISP's
1061 COND, this provides a neater way to write a cascade of $if checks.
1063 * $switch: New OmegaScript multi-way conditional which provides an even neater
1064 way to write a cascade of $if{$eq{X,VALUE1},$if{$eq{X,VALUE2},...}}.
1066 * $subdb and $subid: New commands which report the subdatabase name and the
1067 docid in that subdatabase.
1069 + $termprefix and $unprefix: New OmegaScript commands which expose the existing
1070 code inside omega for splitting up a term.
1072 * Use str() to convert time_t to string, which is simpler code and faster than
1077 * omegatest: Fix message when faketime is not installed - we were misreporting
1078 this case as "faketime not working".
1080 * omegatest: Add feature tests of $map.
1082 * Add testcases for XML charset. We already handle both default and specified
1083 charsets for XML, but we didn't have any testcases for it.
1087 * configure: Fix potentially confusing messages suggesting snprintf was added
1088 in C90 - it was actually standardised in C99.
1090 * Improve handling of multitarget rule stamp files. Clean them on "make
1091 maintainer-clean" and ship them so that --enable-maintainer-mode when
1092 building from a tarball doesn't needlessly rerun the multitarget rules.
1096 * Check for EAGAIN as well as EINTR from select(). The Linux select(2) man
1097 page says: "Portable programs may wish to check for EAGAIN and loop, just as
1098 with EINTR" and that seems to be necessary for Cygwin at least.
1102 * Use https for tarball URLs in .spec files. This provides protection against
1103 MITM attacks on people building packages using these spec files, and is also
1104 slightly more efficient as the http: URLs redirect to the https: versions
1107 Omega 1.4.5 (2017-10-16):
1111 * Direct users towards $set{flag_spelling_correction,true} rather than the
1112 deprecated $set{spelling,true} (which is slated for removal in 1.5.0).
1120 + Check file size before calling libmagic to get the mime type, since
1121 reading the file size is a much cheaper check and we can skip the
1122 libmagic test if the file is empty or larger than the specified
1123 maximum size. Patch from caiyulun.
1127 + Reject index scripts with multiple "unique" actions. We don't handle this
1128 case sensibly, and it doesn't seem like it really has a use, so better to
1129 give an error for people who do this inadvertently.
1133 * New $seterror command to set the error message. Implemented by Gaurav Arora.
1135 * Make $highlight more efficient. Patch from Vivek Pal.
1139 * query: Use $prettyurl for the URL shown at the end of each match (previously
1140 we only used it on the URL shown as a fallback when the document has no
1141 title). Split off from changes by Vivek Pal in
1142 https://github.com/xapian/xapian/pull/161
1146 * omegatest: Tell faketime to freeze the clock - previously the clock ran on
1147 from the specified fake time, and on a slow and/or heavily loaded machine a
1148 test taking more than a second might fail due to this.
1150 * Start adding feature tests for scriptindex (so far, checking that specifying
1151 multiple 'unique' actions results in an error).
1153 Omega 1.4.4 (2017-04-19):
1159 + 1.4.3 added a new --sample option, but contrary to the documentation
1160 the default behaviour was to take the sample from the meta description
1161 (which was the hard-wired behaviour in 1.4.2 and earlier). The default
1162 has now been changed to take the sample from the body.
1164 + Index .shtm, .xhtml and .xhtm as HTML by default - .shtm is another
1165 extension used for server-parsed HTML (in addition to the more common
1166 .shtml), and .xhtm and .xhtml are XHTML.
1168 + Fix fallback lookup for extension containing upper case. User mappings
1169 worked, but built-in extension to MIME type mappings were effectively being
1170 ignored (because the result of the function call was not being checked).
1171 Bug introduced in 1.3.4.
1173 + Fix term-based date ranges, broken by changes in 1.4.2. Found and
1174 diagnosed by Gaurav Arora.
1176 + Handle date range with start after end better - with term-based ranges,
1177 this used to generate a bogus filter, but now just generates Dlatest.
1179 + Use Y-term when range starts/ends at year start/end. Previously we used 12
1180 M-terms for these cases.
1182 + Use full leap-year check when constructing term-based date ranges -
1183 previous code was good until 2100, but even then it would only result
1184 in an extra term being included for a non-existent February 29th in
1189 * New OmegaScript command $cgiparams which returns a list of the parameter
1192 * Handle tab in a CGI parameter name in the same way as space. Mostly this is
1193 a way to avoid having tabs in CGI parameter names - they aren't useful, but
1194 if they could have tabs in we can't put CGI parameter names in a list.
1198 * query: Fix highlighting of matching terms. We were using both $snippet and
1199 $highlight, which results in double highlighting and HTML escaping, most
1200 noticeable by literal <strong> and </strong> appearing around matching terms
1201 in the rendered HTML snippet. Reported by Mark Thomas on xapian-discuss.
1205 * If gen-mimemap failed after creating mimemap.h, the rule wouldn't get rerun.
1207 Omega 1.4.3 (2017-01-25):
1213 + Add support for indexing vCard files if Perl and its Text::vCard module
1216 + Recognise application/x-rpm as alternative type since libmagic reports this
1217 rather than application/x-redhat-package-manager.
1219 + Use official MIME type application/vnd.debian.binary-package for debian
1220 packages. We used to map .deb and .udeb to application/x-debian-package,
1221 but in 2014 (after we added that support for .deb) an official type was
1222 registered with IANA. We now map extensions .deb and .udeb to the official
1223 type, but the unofficial type is still recognised (older versions of
1224 libmagic probably report it, and users may be mapping to it).
1226 + Handle PHP as MIME type text/x-php. The main difference this makes is that
1227 PHP files which don't have extension '.php' (e.g. .phtml, .phps, .php5,
1228 .ph4, etc) get identified by libmagic as text/x-php and will now be indexed.
1229 It also means that the user can now more easily configure different filters
1232 + Don't use meta description as sample by default. Now we have dynamic
1233 snippets (via $snippet), the body text is a better default. Also generated
1234 HTML sometimes has unhelpful content in the meta description. To get the
1235 previous behaviour, use the new omindex command line option:
1236 --sample=description
1238 Omega 1.4.2 (2016-12-26):
1242 * Replace auto-generated list of the supported MIME types with an
1243 auto-generated table showing the extensions that are mapped to each MIME type
1244 by default. Partly addresses #569, reported by catkin.
1248 * omindex: Add support for indexing markdown files (extension .md or .markdown,
1249 mime-type text/markdown, using "markdown" to convert to HTML).
1253 * Add support for "make installcheck" to run tests against installed version.
1257 * configure: Fail with clear error with xapian-core < 1.4.0.
1261 * Fix GCC -Wimplicit-fallthrough warning.
1263 * Add missing <ctime> for time_t.
1265 * Avoid snprintf for formatting fixed-width integers - it results in warnings
1266 about possible output truncation with GCC7 (which aren't actually possible
1267 due to limited input range) and it's a bit heavyweight for this job anyway.
1269 Omega 1.4.1 (2016-10-21):
1273 * Document bug in how $filters encodes DOCIDORDER=A.
1275 * Suggest DOCIDORDER=X for DONT_CARE.
1277 * Correct mentions of C++ API method MSet::get_snippet() to MSet::snippet().
1279 * Fix typo in Omega 1.4.0 NEWS entry. Patch from James Aylett.
1283 * omindex: Also index leafname with _ and & replaced by spaces. Literal spaces
1284 are often avoided in filenames, and "hello_world.txt" ought to be searchable
1285 for via "hello" and "world". Partly addresses #618, reported by Julien
1290 * Add support for sorting by more than one value - e.g. SORT=+1,-2
1292 * Add $msizelower and $msizeupper which provide access to the lower and upper
1293 bounds on the number of matches.
1295 * Add support for $set{weighting,coord}.
1297 * Add weightingpurefilter option. Normally a query consisting only of filter
1298 terms won't have relevance weights calculated. This new option allows you to
1299 specify a weighting scheme to use for such queries, with the same values
1300 supported as for the existing weighting option. For example,
1301 $set{weightingpurefilter,coord} will weight such queries by how many filter
1302 terms match each document.
1304 * $filters now includes DATEVALUE, which means we'll force the first page when
1305 reloading or changing page starting from existing URLs upon upgrade to 1.4.1,
1306 but the exact same existing URL could be for a search without the date filter
1307 where we want to force the first page, so there's an inherent ambiguity
1308 there. Forcing first page in this case seems the least problematic
1309 side-effect. Omission noted by Gaurav Arora.
1313 * Add feature test for boolprefix and prefix maps.
1315 * Add more feature tests for $filters.
1319 * GCC 4.7 is now enforced as the minimum version.
1321 * Drop unused configure check for symbol visibility
1323 * Drop compiler options that are no longer useful:
1324 + -fshow-column is the default in all GCC versions we now support
1325 (checked as GCC 4.6).
1326 + -Wno-long-long is no longer necessary now that we require C++11 where
1327 "long long" is a standard type.
1331 * Fix build on platforms which don't provide timegm(), such as Cygwin.
1332 Reported on xapian-discuss by John Bankert.
1334 Omega 1.4.0 (2016-06-24):
1338 * Clarify $allterms and $terms documentation. Make it clearer how they differ,
1339 and document that $allterms without a parameter list gives all terms indexing
1340 the current hit. Noted by Andy Chilton.
1342 Omega 1.3.7 (2016-06-01):
1346 * Make named entity look-up (e.g. é -> 233) use the same keyword-lookup
1347 table approach we already use for HTML tags and built-in MIME content-types,
1348 rather than a std::map, which makes it faster while using less memory.
1350 Omega 1.3.6 (2016-05-09):
1354 * Fix overview.rst processing in VPATH build. Our workaround for lack of an
1355 include path in docutils was only handling the first include in the file.
1359 * Implement $match command for omegascript. Patch from Richhiey Thomas.
1363 * Lower case all HTML tags, attributes and values; explicitly close <option>
1364 tags. Patches from Vivek Pal and Nirmal Singhania.
1366 * Migrate Omega Templates to HTML5. Patch from Nirmal Sighania.
1368 * templates/query: Remove stray double quote from generated URL for spelling
1369 suggestion when THRESHOLD is set. Patch from Nirmal Singhania.
1371 * templates/opensearch: Change response feeds to support OpenSearch 1.1.
1372 Patch from Nirmal Singhania.
1376 * Update omegatest - the order of subqueries has changed in some cases, due
1377 to the "grouping" changes in the C++ API.
1381 * Drop workaround for old git master before 1.3.2
1383 Omega 1.3.5 (2016-04-01):
1385 This release includes all changes from 1.2.23 which are relevant.
1389 * Add optional prefix argument to $terms.
1391 * $snippet now uses MSet::snippet() instead of the Snipper class.
1393 * Add $contains{STRING1,STRING2}. Contributed by Ayush Gupta.
1395 * Add support for negated boolean filter terms, specified by CGI parameter "N".
1397 * Support a direction prefix on SORT: '+' for ascending, '-' for descending.
1398 SORTREVERSE set to non-0 now flips the direction. Fixes #697, reported by
1403 * Need to AC_SUBST probed value of ZLIB_LIBS. Noted by Paul Wise.
1407 * omegatest; Test faketime actually works, and if it doesn't work skip
1408 testcases which use it. On OS X 10.11, faketime from homebrew doesn't seem
1409 to work, probably due to the new "System Integrity Protection". Fixes part
1410 of #707, reported by James Aylett.
1412 Omega 1.3.4 (2016-01-01):
1414 This release includes all changes from 1.2.22 which are relevant.
1418 * The lists of recognised MIME types and of ignored extensions are now
1419 generated along with the corresponding source code from a single master list.
1420 Partly addresses #569, reported by Charles Atkinson.
1422 * Note when $json and $jsonarray were added.
1428 + Avoid using the shell to run most external commands as it's unnecessary
1429 overhead. For the built-in filters, the only cases which now use a shell
1430 are where we run two unzip commands. For user-specified commands, a simple
1431 and slightly conservative test is used, which should avoid a shell in most
1432 common cases where it isn't needed. Notably, environment variables set
1433 before the command are handled.
1435 + Track files which couldn't be indexed in the user metadata and skip them by
1436 default on subsequent runs to avoid the costs of repeatedly running a
1437 filter on a file it can't handle. Run omindex with --retry-failed to retry
1440 + Overhaul the "per-site" terms:
1441 - 'H' prefix is hostname as before, except that if the term would be > 240
1442 bytes (unlikely but possible) the end is hashed is the same way 'U'
1444 - 'P' terms are now added for every directory level, not just the start
1446 - A new 'J' prefix term is added with the start URL (less any trailing
1447 '/'), which means all files indexed from a particular "site" are now
1448 indexed by one term. See #376.
1450 + Add 'skip' pseudo-mimetype which extensions can be mapped to, and they will
1451 then be reported and skipped (to complement the existing 'ignore'
1452 pseudo-mimetype which causes files with the specified extension to be
1455 + Treat a command of 'true' specially as meaning make the text extraction a
1456 no-op (as actually running /bin/true effectively would). This provides a
1457 way to index some file types by only meta-data. Fixes #519, reported by
1460 + Add support for wildcard mimetypes */* and *. Combined with filter command
1461 ``true`` for indexing by meta-data only, you can specify a fall back case
1462 of indexing by meta-data only using ``--filter '*:true'``. From a
1463 suggestion by Brian Burton on xapian-discuss.
1465 + Index message/rfc822 and message/news. These are individually saved email
1466 messages and news articles.
1468 + Index archived web page formats MAFF and MHTML.
1470 + Handle .xla, yet another XL extension.
1472 + Handle metadata in LibreOffice HTML export (dcterms.subject,
1473 dcterms.description, dcterms.creator and dcterms.contributor).
1475 + Use zlib's gzopen() instead of invoking "gzip -dc" for compressed Abiword
1480 * Add options argument to $transform.
1482 * Cache compiled regexps used in $transform.
1484 * Add $ord OmegaScript command which returns the Unicode codepoint for the
1485 first character of a UTF-8 string.
1487 * Add $chr OmegaScript command which returns the UTF-8 string for given Unicode
1490 * Add $csv OmegaScript command which escapes a string for use as a field in a
1491 CSV file ("always quote" mode inspired by patch from Gaurav Arora.)
1493 * New $filters encoding which avoids collisions. We also compare CGI parameter
1494 xFILTERS to what $filters would have returned in previous releases, so that
1495 on upgrades old format serialised filters are handled correctly.
1497 * Fix $jsonarray not to prepend ']' to the first array element.
1499 * Skip weighting scheme setup for a pure date range query - it won't be
1500 weighted anyway, so we can avoid having to parse weighting scheme parameters,
1503 * Use value ranges when date range filtering by value. Should be more
1504 efficient than a MatchDecider, and will automatically take advantage of any
1505 future value range optimisations in xapian-core.
1507 * Add default_db and default_template config options. These allow the default
1508 template and default database name to be set via the config file, rather than
1509 being stuck with the respective defaults of "default" and "query". Fixes
1510 #310, reported by Marco Hennigs.
1512 * Add support for non-exclusive filters. Fixes #234, reported by Thomas
1517 * Add start of testsuite for omega CGI.
1521 * configure script now defaults to looking for xapian-config-1.3. This is now
1522 automatically done for development series (odd middle component of the
1523 version number), but not for stable series (even middle component). Fixes
1524 #695, reported by Jorge C. Leitão
1526 * Don't pointlessly link omega binary with libmagic (as we have since 1.3.1).
1530 * Fix "make check" compilation failure on platforms without timegm().
1532 Omega 1.3.3 (2015-06-01):
1534 This release includes all changes from 1.2.20-1.2.21 which are relevant.
1538 * INSTALL: IRIX is past EOL so drop information about IRIX make.
1544 + Add support for %f in command passed to --filter to allow specifying
1545 commands where the input file is not the final argument. Fixed #570,
1546 reported by Charles Atkinson.
1548 + Allow --filter to handle commands which produce output in a temporary file
1549 rather than on stdout.
1551 + Allow --filter to specify the character set of the output the filter
1554 + Handle application/vnd.ms-excel, text/x-perl and application/x-dvi via
1555 default --filter settings instead of hardcoded cases (now possible thanks
1556 to the new abilities that --filter has).
1558 + Add support for specifying a MIME subtype of '*' in --filter arguments.
1560 + Add -track-ctime option to allow omindex to pick up changes to file
1561 ownership and permissions.
1563 + Index terms from the leafname with an 'F' prefix, rather than treating them
1564 as more body text. (Fixes #633, reported by Emmanuel Garette)
1568 * Fix handling of multiple P.<prefix> fields - previously only the first seen
1569 was used. These fields are also now taken into account when deciding if the
1570 query has changed. $query now returns an OmegaScript list with one entry for
1571 each CGI parameter passed.
1575 * templates/query: Fix setting setting of prefix map for P - in 1.3.2, this
1576 would failed to also search in the subject. Now it also searches in the
1581 * configure: Fix typo in message: 'libmagic-devl' -> 'libmagic-devel'
1585 * Require a compiler with good C++11 support, like xapian-core now does.
1587 * Now we require C++11, just include <cstdint> for uint32_t.
1589 * Link omindex-list with our (GNU) getopt for platforms which don't use GNU libc.
1590 Thanks to James Aylett
1592 * Add timegm.cc to scriptindex_SOURCES to fix build on platforms which don't
1595 * Suppress bogus uninitialised variable warning with -Os under GCC 4.7.2.
1599 Omega 1.3.2 (2014-11-24):
1601 This release includes all changes from 1.2.16-1.2.19 which are relevant.
1605 * docs/overview.rst: Document built-in list of stopwords.
1607 * docs/termprefixes.rst: Update for renaming of 'brass' backend to 'glass'.
1613 + The starting URL wasn't previously URL encoded. In 1.2.18, a minimally
1614 intrusive fix was implemented. In 1.3.2, we now encode the starting URL
1615 as we do for the rest of the filename.
1617 + Don't assume .doc is application/msword but let libmagic decide, since .doc
1618 files may actually be RTF, and sometimes people use .doc for plain-text
1621 + Add support for indexing 'topic' and 'created date' meta-data for
1622 OpenDocument format and HTML.
1624 + Index "topic" for PDF documents.
1626 + Commit changes and exit, rather than skipping the current file on most
1627 unexpected errors reading directories or initialising libmagic - otherwise
1628 we can end up deleting a lot of database entries on errors like EHOSTDOWN
1629 when indexing network mounts.
1631 + Add --opendir-sleep=SECS option to allow working around problems with
1632 indexing files on Microsoft DFS shares.
1634 + If we get ENOTDIR trying to index a file, skip it quietly (unless in
1635 verbose mode) as we already do if we get ENOENT, since ENOTDIR is what we
1636 get if the file and the directory it was in got removed between us getting
1637 the filename and trying to open it.
1639 + Handle ENOENT, ENOTDIR and EACCES from readdir().
1641 + If we've already opened the file (as we often will have if using a modern
1642 libmagic with magic_descriptor() available), then use fstat() on that fd
1643 rather than stat()/lstat() on the pathname.
1645 + Pass error message string and errno value in ReadError exceptions.
1647 + Report strerror(errno) if we can't read a file.
1649 + Filtering via text/html now handles HTML documents which specify a charset.
1651 + Add support for indexing Microsoft Publisher files using pub2xhtml.
1653 + Restrict the length of what we consider to be an extension, currently to 7
1654 characters or whatever the longest extension in the mime_map is if it is
1657 + Avoid '//' in temporary filenames (cosmetic only).
1659 * omindex-list: New tool to list URLs of all the documents in a database (or
1660 list of databases) indexed by omindex.
1664 * Allow setting query expansion scheme to "bo1".
1666 * Make the $json and $jsonarray force the text to be valid UTF-8, since
1667 otherwise the output isn't valid JSON.
1669 * Check parameters to $set{weighting,bm25 ...} and $set{weighting,trad ...}
1670 converted OK. Based on patch from Aarsh Shah.
1672 * Add support to $set{weighting,...} for bb2, dlh, dph, ifb2, ineb2, inl2, lm,
1673 pl2 when we're built against a xapian-core which is new enough to have these
1676 * Add $snippet to generate a snippet of text tailored to the search.
1680 * configure: Enable GCC's -Woverloaded-virtual warning.
1684 * Ship common/safewinsock2.h, needed under mingw.
1686 Omega 1.3.1 (2013-05-03):
1688 This release includes all changes from 1.2.10-1.2.15 which are relevant.
1692 * INSTALL,configure: Provide hints as to what package to install for magic.h.
1696 * The HTML parser now explicitly handles <APPLET>, <OBJECT> and <TR>.
1698 * Use a generated compact and efficient table to convert HTML tag names
1699 to enum codes - this is both faster and smaller than the approach we were
1700 using, with the benefit that the table is auto-generated.
1702 * Always use our built-in conversion code for the character sets it can handle
1703 (previously we'd use iconv if available; now we only use iconv for other
1704 character sets). This gives us more consistent results, and in particular
1705 means we now handle BOMs better (at least when using GNU iconv).
1707 * A lot of data labelled as "iso-8859-1" is actually "windows-1252". The two
1708 only differ in characters which are control characters in iso-8859-1, so
1709 assume the latter when we see the former.
1713 + Extend --filter to handle commands which produce HTML on stdout.
1715 + Don't report an error if a file is deleted (or renamed) between us reading
1716 the directory entry for it and trying to read the file itself by default.
1717 In --verbose mode, the situation is still reported, but now with a
1720 + If omindex receives any of the signals SIGHUP, SIGINT, SIGQUIT or SIGTERM,
1721 then kill any active external filter child process, then handle the signal
1722 as we did before. If setpgid() is available, put each external filter in
1723 its own process group and kill the whole process group when we get a
1726 + Use magic_descriptor() if the version of libmagic we're building against
1727 is new enough to have it. This eliminates an extra opening of a file
1728 being indexed in certain cases.
1730 + Use rst2html to handle .rst and .rest files.
1734 * Add new $json and $jsonarray OmegaScript commands to support producing JSON
1737 * Add $truncate command which truncates a string after a word.
1739 * Add support for $set{weighting,tfidf} to allow the new TfIdfWeight weighting
1744 * configure: Now looks for libmagic in MAGIC_PREFIX, to allow building with
1745 libmagic installed in a non-standard location.
1747 * Remove support for 'configure --enable-quiet', 'make QUIET=' and 'make
1748 QUIET=y' - automake now supports 'configure --enable-silent-rules', 'make
1749 V=1' and 'make V=0' which are broadly equivalent and more standard.
1753 * tmpdir.cc: Add safeunistd.h for rmdir, required by GCC 4.7 (reported by
1756 Omega 1.3.0 (2012-03-14):
1760 * Make libmagic a required dependency.
1764 * docs/termprefixes.html: Document how to map a user prefix to multiple term
1767 * docs/overview.html: Improve documentation of htdig_noindex.
1773 + Index title with an 'S' prefix rather than no prefix.
1775 + If the document with the highest existing docid before the run was updated,
1776 we were reporting it as "added", but now we correctly report it as
1779 + Catch and report std::exception explicitly, so failing to allocate memory
1780 is no longer reported as "Unknown exception".
1784 + Remove special error handling case noting that index=nopos was replaced
1785 with indexnopos - this was removed in 1.1.0 so there's been enough time to
1790 + DEFAULTOP now defaults to AND rather than OR, since that matches what pretty
1791 much every search engine does these days. Closes ticket#512.
1793 * Allow mapping a query string prefix to more than one term prefix (which
1794 xapian-core has supported since 1.0.4).
1796 * Add support for search inputs for multiple probabilistic prefixes, with
1797 support for per-prefix stemmers.
1799 * Drop legacy support for handling '.' separated terms in xP - that changed in
1800 Omega 0.9.7, more than 5 years ago now.
1802 * Remove support for OLDP CGI parameter which was superseded by xP
1803 approximately a decade ago, and isn't even documented!
1805 * Drop special handling for R-prefixed terms in $prettyterm - we stopped
1806 generating these in Xapian 1.0.
1812 + We now map unprefixed queries to include S-prefixed terms to match the
1813 change in omindex to prefixing terms from the title with S. You may want
1814 to make the same update to your own templates.
1816 + Set up prefixes for 'author:' and 'title:'.
1820 * xapian-omega.spec: We're ABI compatible within a release series so make
1821 dependency on xapian-core-libs >= rather than =.
1823 Omega 1.2.23 (2016-03-28):
1827 * Update links to Xapian website and trac to use https, which is now supported,
1828 thanks to James Aylett.
1832 * Fix HTML/XML entity decoding to be O(n) not O(n²) - processing HTML/XML with
1833 a lot of entities is now much faster.
1837 * Remove unused country code to name maps. These were intended as examples,
1838 but they aren't very useful as such, and really just bloat the templates
1841 Omega 1.2.22 (2015-12-29):
1845 * Stop maintaining ChangeLog files. They make merging patches harder, and stop
1846 'git cherry-pick' from working as it should. The git repo history should be
1847 sufficient for complying with GPLv2 2(a).
1849 * Clarify help text for omindex --mime-type option.
1851 * docs/omegascript.rst:
1853 + Fix documentation of $last to say it's the MSet index *one beyond* the end
1854 of the current page. Reported by Andrew Chilton.
1856 + Clarify that $split and $substr work in bytes. Previously we said
1857 "characters" which could be taken as meaning they work with UTF-8
1860 + Update documentation for $filters - it was missing these CGI parameters
1861 from the list of those serialised: COLLAPSE, DOCIDORDER, SORT, SORTREVERSE,
1864 + Explicitly note user can use $setmap to create their own maps.
1866 * docs/overview.rst:
1868 + SVG extraction is built-in too.
1870 + Expand paragraph about command `false`. Note the versions where explicit
1871 support was added, and that this will also work with any version on Unix,
1872 where `false` is a command.
1874 + Document `cdb_dir`.
1876 * docs/cgiparams.rst: Document behaviour if xDB is not set.
1878 * Change "characters" to "bytes" in a few places to clarify that we don't mean
1879 Unicode code points.
1885 + Add '--title-size' option.
1887 + Handle .oft the same way as .msg - it's some sort of template email, and
1888 has essentially the same format.
1892 * Make $querydescription ensure the match has been run, so that it includes
1895 * Avoid $allterms, $cgilist, $filterterms and $terms being O(n²) in the number
1896 of items in the returned list.
1898 * If xFILTERS is not set, don't force the first page as that's unhelpful if
1899 someone fails to set it in their template.
1901 * When environment variable SERVER_PROTOCOL is set to INCLUDED (as it is when
1902 we're being included in a page), we already suppress the HTTP headers, but
1903 now we suppress the blank line after the header too.
1905 * Support option flag_cjk_ngram if built against xapian-core >= 1.2.22.
1909 * Add test coverage for parsing of HTML entities.
1913 * Fix error reporting if PCRE isn't installed. Fixes #693, reported by lhz7370.
1917 * Avoid warning when building with glibc >= 2.21.
1919 * Don't provide our own implementation of sleep() under __WIN32__ if there
1920 already is one - mingw provides one, and in some situations it seems to clash
1921 with ours. Reported to xapian-discuss by John Alveris.
1923 * Stop trying to use O_STREAMING - the patch to implement it was never merged
1924 into the Linux kernel, and I can't find any evidence that other platforms
1925 implement it. The constant value O_STREAMING used now seems to be used for
1926 the part of O_SYNC which isn't covered by O_DSYNC, which seems likely to hurt
1927 performance if anything.
1929 Omega 1.2.21 (2015-05-20):
1933 * docs/overview.rst: Document 'E' prefixed boolean terms for filtering by
1934 extension (see #668, reported by bramvdh).
1936 * docs/encodings.rst: Add a document about character encoding, as suggested by
1937 James Aylett in #550.
1943 + outlookmsg2html: Fix handling of message/rfc822 subparts.
1947 * $prettyurl now decodes valid UTF-8 sequences, and some additional ASCII
1948 characters in the path part: []@!$&'()*+.;= (Fixes #550 and #644, reported by
1949 catkin and terencz.)
1951 * $prettyurl now leaves the query and fragment parts of the URL alone and won't
1952 decode an escaped "/" (omindex doesn't create URLs with any of these, so we
1953 only risk breaking other URLs which have them).
1955 * Drop compilation date and time from output when run from the command line -
1956 they prevent reproducible builds and the version number is sufficient
1961 * templates/query: When listing matching terms, don't make the commas italic.
1963 * templates/query: Eliminate blank line before <html>.
1965 * templates/xml: Add XML declaration.
1967 * templates/godmode: Specify charset utf-8 in the content-type.
1971 * Link test programs with libtool's '-no-install' or '-no-fast-install', like
1972 we already do in xapian-core, which means that libtool doesn't need to
1973 generate shell script wrappers for them on most platforms.
1977 * Add spaces between literal strings and macros which expand to literal strings
1978 for C++11 compatibility.
1980 * Remove 'register' as it's deprecated and clang spits out warnings because of
1981 that. Any modern compiler likely just ignores it as an optimisation hint
1984 Omega 1.2.20 (2015-03-04):
1988 * docs/cgiparams.rst: Improve wording of docs for SORT parameter.
1990 * docs/omegascript.rst: Update documentation references to DATE1, DATE2, and
1991 DAYSMINUS which were renamed in 0.6.x and the compatibility aliases removed
1998 + Ignore extensions .msi and .msp, which are Microsoft installer files, but
1999 which libmagic sometimes incorrectly identifies as application/msword.
2001 + Interpret a command of "false" in "--filter" as meaning to ignore files
2002 with that MIME type.
2006 * Handle CGI parameter [=0 as [=1.
2010 * templates/xml: Update handling of DATE1, DATE2 and DAYSMINUS which were
2011 renamed in 0.6.x and the compatibility aliases removed in 1.0.0.
2015 * configure: Use pkg-config in preference to determine flags needed to
2016 compile and link with PCRE, as this will just work when cross-compiling
2017 (at least under MXE).
2019 * configure: Define MINGW_HAS_SECURE_API under mingw to get _putenv_s()
2020 declared in stdlib.h.
2022 * Enable automake option 'subdir-objects' to avoid warning from newer automake.
2026 * Avoid doing link tests with libmagic in configure as they fail on mingw due
2027 to not automatically picking up libraries which libmagic itself depends on.
2029 Omega 1.2.19 (2014-10-21):
2033 * docs/overview.rst: Note that pdftotext is part of poppler as well as xpdf.
2034 (Noted by Paul Wise)
2036 Omega 1.2.18 (2014-06-22):
2042 + Work around libmagic returning a MIME content-type of "Composite Document
2043 File V2 Document[...]" or "application/CDFV2-corrupt" by returning a more
2044 suitable filetype based on looking at the file's extension.
2046 + The starting URL wasn't previously URL encoded. In 1.3.2, this will be
2047 fixed by URL encoding it as we do for the rest of the path, for the 1.2
2048 branch we only URL encode it if it contains a character <= 31 or at least
2049 one of '#', '%', ':' or '?'. This avoids a one-off reindex of every
2050 document in the database in cases which work OK in practice.
2052 + When we skip a file because it exceeds the configured size limit, include
2053 that size limit in the message.
2057 * Add support for setting the query expansion scheme to use.
2061 * Don't compile in unixperm.cc - it isn't currently used, and it fails to build
2062 with mingw. (fixes #635, reported by Alexis Denis)
2064 * Fix warning when built with GCC 4.7.2 using -Os.
2066 * Removed unused inline function, fixing compiler warning.
2068 Omega 1.2.17 (2014-01-29):
2072 * docs/overview.html: Add Abiword as an example use of --filter, based on patch
2073 from Frank J Bruzzaniti (fixes#383).
2077 * Fix "no previous declaration" warning on platforms which don't have
2080 Omega 1.2.16 (2013-12-04):
2086 + Fix off-by-one when finding documents to delete which would sometimes cause
2087 omindex to fail to delete documents from the database when they weren't
2088 refound during an index update.
2090 + Decode dates in xlsx files.
2092 + Ignore extensions 'adm', 'cur', and 'ico' by default.
2094 + Group-readable files which are owner-readable but not world-readable should
2095 still get a "readable by owner" term added. Reported by Emmanuel Garette.
2099 * Compress source tarballs with xz instead of gzip.
2101 * configure: Sync compiler warning flag machinery against xapian-core. The
2102 changes are special handling for clang, passing -fshow-column where
2103 supported, and handling for new warning flags in GCC 4.6 and 4.7.
2105 Omega 1.2.15 (2013-04-16):
2109 * Don't pointlessly link utf8convert.o into the omega CGI.
2111 Omega 1.2.14 (2013-03-14):
2117 + Correct "max" -> "min" when reserving space for shared strings in .xlsx
2118 files. This just means we now reserve a more appropriate amount of space
2121 + Ignore .com files by default.
2123 Omega 1.2.13 (2013-01-09):
2129 + Extracting text using external filters now works for filenames containing a
2130 newline character - previously the newline got lost during escaping for the
2133 + Fix segfault when -F option without a ':' is passed.
2135 + Skip a file if we get a read error while calculating the MD5 checksum (used
2136 for duplicate detection) - previously we used a checksum of the file up to
2139 + Avoid rereading SVG and Atom files when we calculate their MD5 checksums.
2141 + Improvement --help output and man page, most notably:
2143 - Say explicitly that --sample-size accepts the same formats as --max-size.
2145 - Note default size limit on files to index is unlimited.
2147 + When generating a sample for a CSV file, limit the size we pre-allocate to
2148 the CSV file size if that's smaller than the requested sample size, in case
2149 the user sets that limit very high.
2153 * Fix to decode %-encoded character at the end of the query string.
2157 * INCLUDES is now deprecated in automake, so use AM_CPPFLAGS instead.
2159 Omega 1.2.12 (2012-06-27):
2161 No changes since 1.2.11 except to bump the version - this release was made to
2162 fix an incorrect library version information update in xapian-core 1.2.11.
2164 Omega 1.2.11 (2012-06-26):
2168 * Change HTML parser's handling of multiple <body> tags and of text outside of
2169 <body> to match the behaviour of modern web browsers. (ticket#599)
2173 + Add command line option to control the size of the document sample stored.
2174 Patch from Mihai Bivol.
2176 + Rework .xlsx parsing to substitute the shared strings into the positions
2177 they are used in, so that the sample actually matches what appears in the
2178 spreadsheet, and to index calculated cell contents.
2180 + Improve handling of headers and footers in OpenDocument documents.
2182 + pdftotext outputs a formfeed between each page, which messes up our "empty
2183 body" check, so trim any trailing formfeeds before this check.
2187 * Don't explicitly link indirect shared library dependencies on FreeBSD,
2188 OpenBSD, and Solaris.
2190 Omega 1.2.10 (2012-05-09):
2194 * Add support for CDATA to HTML/XML parser.
2198 + Add --max-size option, based on patch from ndaley in ticket#587.
2200 + Add support for atom feed files, patch from Mihai Bivol in ticket#595.
2202 + If the document with the highest existing docid before the run was updated,
2203 we were reporting it as "added", but now we correctly report it as
2204 "updated". (Backported from 1.3.0).
2206 + Catch and report std::exception explicitly, so failing to allocate memory
2207 is no longer reported as "Unknown exception". (Backported from 1.3.0).
2213 * Fix to build with GCC 4.7 by adding cast to rlim_t to fix error about C++11
2214 compatibility (reported by Gaurav Arora).
2216 Omega 1.2.9 (2012-03-08):
2220 * docs/overview.html:
2222 + Document that libmagic is used to determine the MIME type if the extension
2223 isn't known. Partly addresses ticket#569.
2225 + We now limit time as well as CPU and memory for external filters.
2229 * Our HTML parser now ignores sections bracketed by <!--UdmComment--> and
2230 <!--/UdmComment-->, like we already do for <!--htdig_noindex-->.
2232 * omindex: Add more extensions to the default ignore list: bin dat db fon jar
2233 lnk pyc pyd pyo sqlite sqlite3 sqlite-journal tmp ttf
2235 Omega 1.2.8 (2011-12-13):
2239 * scriptindex.cc: Add link to http://xapian.org/docs/omega/scriptindex.html to
2240 --help output (and so also to the man page which is generated from this).
2242 * omegascript.html: Add note to discourage use of percentage scores.
2248 + If we don't get any data from an external filter for 5 minutes, give up -
2249 it has probably ended up blocked indefinitely.
2251 + Improve --help output (and man page which is generated from it). Closes
2256 + If no rules are found in the index script, report an error and give up -
2257 this is inevitably the result of a mistake, and adding empty documents to
2258 the database isn't helpful.
2262 + Add new $prettyurl{} command which undoes RFC3986 URL escaping which
2263 doesn't affect semantics in practice. Partly addresses ticket#550.
2265 + Replace URL decoder with new implementation which handles various corner
2266 cases better. Fixes bug#578.
2268 + If CGI parameter P has trailing spaces, we now remove them all rather than
2273 * templates/query: HTML escape topterms.
2275 * templates/godmode: HTML escape the contents of document values.
2277 * templates/query: Don't show the percentage score in the default template.
2281 * Add new urlenctest unit test of URL encoding and decoding.
2285 * configure: Sync changes from xapian-core: Don't pass -Wshadow for GCC < 4.1;
2286 don't pass -Wstrict-null-sentinel for GCC 4.0.x; only enable symbol
2287 visibility on platforms where it is supported.
2291 * xapian-omega.spec: Package outlookmsg2html helper.
2293 Omega 1.2.7 (2011-08-10):
2297 * docs/termprefixes.html: Document how to map a user prefix to multiple term
2300 * docs/overview.html: Improve documentation of htdig_noindex.
2304 * Improve $version output from "Xapian - xapian-omega 1.2.7" to "xapian-omega
2309 * xapian-omega.spec: We're ABI compatible within a release series so make
2310 dependency on xapian-core-libs >= rather than =.
2312 Omega 1.2.6 (2011-06-12):
2316 * docs/omegascript.html: Correct the documentation of the colours used by
2319 * docs/overview.html: Add using unoconv as more complex example of using
2320 --filter (ticket#324).
2326 + Make search query input type=search.
2328 + Autofocus the search query input (using HTML autofocus attribute with
2329 Javascript fallback for older browsers). (ticket#544)
2333 * Fix a compiler warning.
2335 Omega 1.2.5 (2011-04-04):
2339 * Add index page which links to all the other documentation pages.
2341 * INSTALL: Copy new Multi-Arch section from xapian-core/INSTALL. Replace VPATH
2342 section with better equivalent from Xapian-core/INSTALL.
2344 * docs/omegascript.html: Minor improvements.
2348 * The HTML parser no longer uses an exception to signify it has finished in
2349 the normal case as exceptions are typically costly to handle. In tests,
2350 this made omindex ~0.23% faster when indexing a lot of HTML files.
2354 + Add --ignore-exclusions option, which will index HTML files despite meta
2355 robots tags, etc - omindex is often used in environments where such
2356 exclusions aren't relevant.
2358 + Fix to compile with older versions of libmagic which don't have
2359 MAGIC_MIME_TYPE (e.g. on Ubuntu hardy).
2361 + Tell xls2csv to separate fields with spaces rather than commas, and not to
2362 quote them. Fixes indexing of numeric fields, and means we don't need to
2363 use our CSV parser to get a sample.
2365 + Add whitespace between chunks of text extracted from Microsoft Office 2007
2366 formats to prevent words in adjacent chunks from being run together.
2368 + Encode reserved characters in URLs - links to files with names containing
2369 '#' and '?' now work.
2371 + Handle .xlr extension the same way as .xls (later Microsoft Works versions
2372 apparently produce such files which are really the same format).
2374 + Index filename extension with new standard prefix E.
2376 + Just report the mimetype as unknown instead of saying "unknown Office 2007
2379 + Ignore *.css and *.js by default too.
2381 + Messages reporting skipping files are now more consistent and always report
2384 + New --empty-docs option to allow documents we extract no body text from to
2385 be indexed (existing behaviour), skipped, or reported and then indexed.
2389 * Fix double Content-Type header in some error reporting situations (regression
2390 introduced in 1.2.4).
2392 * Update $url's URL encoding to follow RFC3986.
2394 * Allow QueryParser flags to be set from OmegaScript (ticket#418). The
2395 FLAG_SPELLING_CORRECTION flag can now be set using
2396 $opt{flag_spelling_correction,1} - the old $opt{spelling,true} way to
2397 enable this flag still works, but it now deprecated.
2401 * templates/emptydocs,templates/godmode,templates/opensearch,templates/query,
2402 templates/xml: Add missing escaping. Some of these instances may allow
2403 cross-site scripting, so upgrading your templates is recommended, especially
2404 if you have any sensitive cookies set on the domain Omega is running on.
2408 + Try $field{caption} (which is what omindex sets) before $field{title} when
2409 getting a value for the hit tag's title attribute - this is consistent with
2410 how the query template gets the title.
2412 + Add new 'type' attribute which gives $field{type}.
2414 + Add 'DBSize' attribute to <result> element.
2416 + Fix double escaping of matching terms. This is only likely to affect cases
2417 where a matching term contains '&'.
2419 + Remove support for undocumented HILITECLASS CGI variable. There's no
2420 evidence I can find using Google code search or web search that this has
2421 been used anywhere, and it's difficult to handle escaping it properly in
2422 the face of all the ways it could reasonably be used.
2426 * Fix to compile on Microsoft Windows (ticket#350).
2428 Omega 1.2.4 (2010-12-19):
2432 * Minor documentation improvements.
2436 * Some iconv implementations (such as that on Mac OS X) don't handle many of
2437 the commonly seen mis-punctuated charset names (e.g. UTF16, UTF_16). We now
2438 check for this if iconv fails, fix up the charset name, and retry.
2440 * The built-in character encoding converter now handles spaces in charset
2443 * Use O_NOATIME if available and either the file is owned by the current euid,
2444 or the current euid is 0 (i.e. we're running as root). This avoids updating
2445 the access time of files we index which saves time. Fixes ticket#222.
2447 * Report get_description() for Xapian exceptions, which provides additional
2448 information above get_msg().
2450 * Add boolean terms with add_boolean_term() so they get wdf of 0 and don't
2451 contribute to document length.
2455 + Escape wildcard patterns being passed to unzip - in the unlikely event that
2456 one of these matched files in or under the current directory, we might fail
2457 to extract all the files we wanted to.
2459 + Add explicit support for indexing CSV files (better samples than from
2460 using '-Mcsv:text/plain').
2462 + Add support for indexing .msg files from Microsoft Outlook (using the Perl
2463 module Email::Outlook::Message. (ticket#334)
2465 + Improve --help for --mime-type option.
2467 + Optionally use libmagic to detect MIME types for files for which we have no
2468 extension mapping, which allows us to handle files with a misleading
2469 extension, or no extension at all. (ticket#114)
2471 + Add new --filter option which allows the user to specify new filters
2472 provided they return UTF-8 text on stdout.
2474 + If a filter command isn't installed, previously we wouldn't try it again
2475 for the same file extension - now we won't try it again for the same
2478 + Index the leafname of the file (without any extension) as extra keywords.
2480 + Extract author from HTML, OpenDocument, and PDF files. Index it with an A
2481 prefix, and add it as a field.
2483 + Add support for indexing text and metadata from SVG files.
2485 + Extract metadata from Microsoft Office 2007 file formats.
2487 + Index text in headers and footers for .odt and .docx files.
2489 + Use the CSV parser to generate a nicer sample for files of type
2490 application/vnd.ms-excel.
2492 + Add support for indexing Debian and RPM package files (ticket#493).
2494 + Make the memory limit for filter processes the size of physical memory,
2495 which is a little less arbitrary than 7/8 of this value (ticket#424).
2497 + Under --duplicate=ignore, fix so that old documents which aren't seen get
2498 deleted, which wasn't implemented before (to suppress this deletion, pass
2501 + Rename the short option for --version from -v to -V for consistency with
2502 scriptindex and many other packages, and to free up -v as the short option
2503 for --verbose. For backward compatibility, "omindex -v" is handled
2504 specially and still reports the version.
2506 + Add --verbose option, and disable the less interesting output unless it is
2509 + Deprecate "--preserve-nonduplicates" in favour of new long option
2510 "--no-delete" which does the same thing, but has a clearer name.
2512 + The deletion of documents pass at the end of indexing is now more
2513 efficient. We track how many documents in the database we haven't seen so
2514 we can stop once we've found them all (a particularly big improvement if
2515 there are no documents to delete), and we now use a PostingIterator over
2516 all documents which avoids needing to catch an exception for every gap in
2517 the used document ids.
2519 + Quietly ignore files with mimetype set to "ignore". The initial list of
2520 extensions set to ignore is: .a .dll .dylib .exe .lib .o .obj .so
2522 + Index file owner and read permissions, to allow finding documents with a
2523 particular owner, and so searches can be restricted to documents a user is
2526 + Add file size as a document value, so you can sort on it and filter by it.
2530 + Fix file descriptor leak if the LOADFILE action is used on something which
2535 * Make sure we write out HTTP headers when reporting an error early on.
2537 * Extend $field to take an optional DOCID argument, rather than always using
2538 the context from $hitlist.
2540 * Add new $emptydocs command which returns a list of documents with doclength
2543 * Add support for size: range filtering. Currently the end points of the range
2544 have to be specified in bytes (e.g. size:102400..204800 for 100-200KB).
2548 * templates/emptydocs: New template which lists documents with doclength zero.
2552 * configure: Probe for any options needed to enable large file support.
2553 Handling files >= 2GB isn't especially useful, but more importantly this is
2554 needed to allow omindex to index files on filing systems with 64 bit inodes
2555 on some platforms (e.g. 32-bit Linux).
2557 * Use -no-undefined on platforms which need it to dynamically link such as
2558 cygwin (need to do this taken from ticket#282).
2562 * Fix to compile with Sun C++.
2564 Omega 1.2.3 (2010-08-24):
2568 * docs/termprefixes.html: Update "flint and quartz" to "flint and chert" as
2569 quartz is no longer supported. Give exact term length limit for flint and
2574 * xapian-omega.spec: Don't run autoreconf - it's no longer required.
2576 Omega 1.2.2 (2010-06-27):
2580 * Apply getopt portability fixes from xapian-core 1.2.0, fixing build failures
2581 on Mac OS X (and probably some other platforms with non-GNU getopt
2582 implementations). (ticket#469)
2584 Omega 1.2.1 (2010-06-22):
2586 This release includes all changes from 1.0.21 which are relevant.
2588 Omega 1.2.0 (2010-04-28):
2590 This release includes all changes from 1.0.20 which are relevant.
2594 * configure: Tell libtool not to link in deplibs on platforms where we know
2597 * configure: On Linux, extract the library search path from ldconfig which
2598 gives us the default entries reliably.
2600 Omega 1.1.5 (2010-04-15):
2602 This release includes all changes from 1.0.19 which are relevant.
2604 Omega 1.1.4 (2010-02-15):
2606 This release includes all changes from 1.0.18 which are relevant.
2610 * Use the optimised integer to string conversion routines from xapian-core.
2612 Omega 1.1.3 (2009-11-18):
2614 This release includes all changes from 1.0.15-1.0.17 which are relevant.
2618 * templates/query: If JavaScript is available, convert $field{modtime} to a
2619 string on the client-side so that the timezone is correct. If JavaScript
2620 isn't available, fall back to the existing behaviour of using UTC.
2625 * configure: Default to looking for xapian-config-1.1 unless XAPIAN_CONFIG is
2628 Omega 1.1.2 (2009-07-23):
2630 This release includes all changes from 1.0.14 which are relevant.
2636 + Handle the "macroenabled" versions of MS Office 2007 files too
2639 + Extract pptx notesSlides and comments, if present. (ticket#290).
2641 Omega 1.1.1 (2009-06-09):
2643 This release includes all changes from 1.0.13 which are relevant.
2649 + Check the last modification time of files before reindexing (ticket#342).
2651 + Add "--spelling" option to index spelling correction data.
2655 + Add new "spell" action for indexing spelling correction data (ticket#296).
2659 * Add $suggestion and $opt{spelling} to provide access to spelling correction
2662 * Add $opt{weighting} to allow the weighting scheme and parameters to be
2663 specified (ticket#298).
2665 * If SERVER_PROTOCOL in the environment is set to INCLUDED, then our output is
2666 being included in another page (e.g. using SSI) so suppress the output of any
2671 * templates/query: Offer any spelling correction QueryParser gives.
2675 * configure: Sync warning flags used with GCC with xapian-core apart from
2676 -Woverloaded-virtual which fires for MyHtmlParser::parse_html(). That
2677 probably should be tidied up at some point, but not right now.
2679 Omega 1.1.0 (2009-04-23):
2685 + Make deprecated "index=nopos" an error.
2689 * New OmegaScript command $transform{} which performs regular expression
2690 substitutions using the PCRE library (which is now required to build Omega).
2695 * The build system is now bootstrapped with newer versions of autoconf and
2696 libtool which should produce smaller files and speed up configure and
2699 Omega 1.0.23 (2011-01-14):
2705 + Escape wildcard patterns being passed to unzip - in the unlikely event that
2706 one of these matched files in or under the current directory, we might fail
2707 to extract all the files we wanted to when indexing document formats like
2708 OpenDocument which use a zip file container.
2710 + The parser for OpenDocument metadata wasn't initialising its "state" field.
2711 Often you'd be lucky and it would be initialised to zero, but this could
2712 have caused misparsing of metadata in some cases.
2714 * scriptindex: Fix file descriptor leak if the LOADFILE action is used on
2715 something that isn't a file.
2717 * If fstat() fails when trying to load a file, preserve the errno value from
2718 the fstat call to report to the user.
2722 * configure: Probe for any options needed to enable large file support.
2723 Handling files >= 2GB isn't especially useful, but more importantly this is
2724 needed to allow omindex to index files on filing systems with 64 bit inodes
2725 on some platforms (e.g. 32-bit Linux).
2727 * Add -no-undefined to AM_LDFLAGS on platforms which need it to dynamically
2728 link such as cygwin (need to do this taken from ticket#282).
2730 Omega 1.0.22 (2010-10-03):
2734 * Fix to compile with Sun C++.
2736 Omega 1.0.21 (2010-05-18):
2740 * Fix build failure in freemem.cc on Microsoft Windows.
2742 Omega 1.0.20 (2010-04-27):
2746 * Fix build failure on Mac OS X and possibly some other platforms (regression
2747 caused by fix for getopt-related warnings on Cygwin in 1.0.19).
2749 Omega 1.0.19 (2010-04-15):
2753 * Fix getopt-related warning on Cygwin.
2755 Omega 1.0.18 (2010-02-14):
2759 * Make the default charset "utf-8" not "UTF-8" as we lower case explicitly
2760 specified character sets to compare to see if we need to reparse. Previously
2761 XML documents which explicitly specified their character set as UTF-8 would
2762 cause needless restart or the parser.
2766 + Increase the wdf boost for the document title from 2 to 5, since 2 isn't
2771 + Don't abort with "Unknown Exception" if indexing is disallowed or we hit
2772 </body> for a document which had an overridden character set. Fixes
2775 Omega 1.0.17 (2009-11-18):
2781 + On Linux, change the memory limit on external filters to use _SC_PHYS_PAGES
2782 since _SC_AVPHYS_PAGES excludes pages used by the OS cache and so will
2783 often report a really low value. Fixes Debian bug#548987 and ticket#358.
2785 + Fix likely crash when reading output from external filter program if read()
2786 is interrupted by a signal.
2788 + Fix potential crash when indexing PostScript files (fixed by using delete[]
2789 (not delete) for array allocated by new[]).
2793 * utf8converttest: Charset "8859_1" isn't understood by Solaris libiconv, and
2794 isn't a standard charset name, so just test it when using our built-in
2795 converter and GNU libc.
2799 * Fix build failure on Mac OS X 10.6.
2801 * Also check for socketpair() in -lxnet if it isn't found without, which
2802 enables resource limits on external filter programs called by omindex on
2803 Solaris, and possibly some other platforms. Fixes ticket#412.
2805 Omega 1.0.16 (2009-09-10):
2807 * omega: Fix cross-site scripting vulnerability in reporting of exceptions
2810 Omega 1.0.15 (2009-08-26):
2814 * omegascript.vim: The list of OmegaScript commands in the vim mode was rather
2815 out of date, and a few commands were misclassified. Fix both problems and
2816 avoid future recurrences by automatically generating those lists from the
2817 command list in query.cc.
2821 * omegascript.html: Document that $date uses UTC. (ticket#314)
2825 * query: Link to "xapian.org" rather than "www.xapian.org".
2827 * inc/toptermsjs: Use double-quotes rather than single quotes for parameter
2828 values on the <script> tag.
2832 * omindex: Implement correct handling of paths when calling external filter
2833 programs on Microsoft Windows.
2835 Omega 1.0.14 (2009-07-21):
2839 * omindex: Make sure that output is flushed after every message, not just after
2844 * Avoid infinite loop in omindex and scriptindex when reading files under
2845 Cygwin with automatic end of line translation enabled. This same bug can
2846 also manifest on Unix platforms if the file is truncated by another process
2849 Omega 1.0.13 (2009-05-23):
2855 + If the filter program needed for a file format isn't installed, report this
2856 explicitly when skipping subsequent files with the extension instead of
2857 misleadingly reporting "Unknown extension".
2859 + Make -s actually work as a short-form for --stemmer (as documented by
2860 "omindex --help" and "man omindex").
2862 + Drop the copyright info from the output of --version as it's perennially
2863 out of date and we don't report it for any other Xapian programs.
2867 + Add new "valuenumeric" action to add a document value using
2868 Xapian::sortable_serialise() to allow numeric sorting (ticket#260).
2872 * configure: Enable more GCC warnings - "-Wstrict-null-sentinel" for 4.0+,
2873 "-Wlogical-op -Wmissing-declarations" for 4.3+.
2875 Omega 1.0.12 (2009-04-19):
2879 * $log now retries a partial write, or one interrupted by a system call.
2883 * configure: Fix iconv parameter type probe not to implicitly cast a string
2884 literal to char* - this a warning under GCC currently, but the user could
2885 pass -Werror explicitly in CXXFLAGS, and this could be promoted to an error
2886 in future GCC versions, and may already be so for some other compilers.
2888 * Overriding CXXFLAGS at make-time (e.g. "make CXXFLAGS=-Os") no longer
2889 overrides any flags required for building with Xapian.
2891 * We now actually use the compiler warning flags which configure detects.
2893 Omega 1.0.11 (2009-03-15):
2897 * cgiparams.html: Note the technique of using a stub database file to allow a
2898 default of searching over multiple databases.
2904 + Add support for indexing Microsoft Office 2007 formats and XPS files
2907 + Fix the extraction of metadata from OpenDocument formats.
2909 + Fix "-l" which would previously always cause a segmentation fault if used
2910 ("--depth-limit" wasn't affected).
2914 * configure: The output of g++ --version changed format (again) with GCC 4.3
2915 which meant configure got "g++" for the version. Instead use the (hopefully)
2916 more robust technique of using g++ -E to pull out __GNUC__ and
2919 * configure: Turn on _FORTIFY_SOURCE where available (as we do in xapian-core).
2923 * Fix to compile when RLIMIT_AS isn't available (as on NetBSD and OpenBSD).
2924 Instead use RLIMIT_VMEM or RLIMIT_DATA if either is available, else don't try
2925 to limit the memory the filter process can use.
2927 Omega 1.0.10 (2008-12-23):
2931 * This release now uses newer versions of the autotools (autoconf 2.62 ->
2932 2.63; automake 1.10.1 -> 1.10.2). The newer autoconf fixes a regression
2933 in autoconf 2.62 (and so Omega 1.0.7) with detecting the endian-ness of some
2936 Omega 1.0.9 (2008-10-31):
2940 * docs/overview.html: Document HTML parsing a bit, including robots
2941 meta and htdig_noindex.
2945 * omega: Catch std::exception and report what its what() method returns.
2947 * omega: Remove undocumented and non-functional support for numeric sorting
2948 via CGI parameter SORT=#<slot> (SORT=<slot> works as before).
2952 * configure: Sync warning flag handling changes from xapian-core to eliminate
2953 many warnings from GCC 4.3.
2955 Omega 1.0.8 (2008-09-04):
2959 * Fix a few typos and improve wording in a few places.
2965 + If the character encoding is specified using <meta http-equiv=...> in an
2966 HTML document then reparse the document if it isn't the encoding we're
2967 already using so that any preceding <title> is converted correctly
2970 + Convert text from meta tag parameters to UTF-8 (bug#293).
2972 + Handle <meta charset="..."> (new in HTML 5).
2974 + Fix bug in HTML tag parameter parsing which was probably just a small
2975 performance penalty in real world cases, but could perhaps result in
2976 parsing bogus extra parameters in carefully contrived situations.
2980 * Add missing <signal.h>, noted on FreeBSD by Henrik Brix Andersen.
2982 Omega 1.0.7 (2008-07-14):
2986 * omegascript.html,scriptindex.html: Fix empty titles.
2992 + When indexing text files, handle UCS-2 and UTF-16 text files with a
2993 byte-order mark (BOM), and ignore any UTF-8 "byte-order" mark.
2995 + The built-in conversion code (used when iconv isn't available) now handles
2996 UCS-2/UTF-16 with and without a BOM, and also the explicit BE and LE forms.
3000 * Overhaul the $highlight colour combinations since some were rather
3001 unreadable (Debian bug 484456).
3005 * configure: Synchronise code for working out warning flags used for builds
3006 with that used for xapian-core, which in particular handles different
3007 output formats from "gcc --version".
3011 * configure: Fix header checks to pre-include <sys/types.h> which Mac OS X
3012 needs for some other headers to work.
3014 * configure: Fix probing for iconv to work better when iconv isn't found
3015 (previously this only worked on Mac OS X with fink).
3017 * Fix compilation error on FreeBSD, introduced in 1.0.5.
3019 * In omega, cast size to unsigned before division to avoid a warning about
3024 * xapian-omega.spec: Remove "www." from xapian.org and oligarchy.co.uk URLs.
3026 Omega 1.0.6 (2008-03-17):
3030 * docs/omegascript.html: Improve formatting.
3036 + Add support for DjVu files.
3038 + If we get an error trying to read a directory entry, report it to the user
3039 rather than ignoring it.
3043 * New OmegaScript commands $addfilter, $lower, $upper.
3047 * Check "defined HAVE_SYSMP" rather than just "HAVE_SYSMP". This doesn't
3048 change behaviour, but fixes a compile warning on platforms other than Linux
3051 Omega 1.0.5 (2007-12-21):
3055 * Convert .txt docs to reStructedText which we process to produce HTML.
3057 * Add a note inviting suggestions for additional reliable filter programs.
3059 * overview.html: omindex hasn't generated "W"-prefix terms since 0.9.7, so
3060 remove the documentation saying it does.
3066 + If a file's extension isn't found in the mime_map and contains uppercase
3067 ASCII characters, check for the lower cased extension (so .PDF and .Pdf
3068 behave the same way as .pdf, unless you deliberately add different mappings
3071 + '-f' is documented by --help as a short option for '--follow', but wasn't
3072 previously actually recognised.
3074 + Limit filter programs to 7/8 of free physical memory on platforms where we
3075 know how to determine this statistic (currently at least Linux, FreeBSD,
3076 IRIX, HP-UX; probably Solaris and a few others too). This helps to prevent
3077 runaway filters from causing a denial of service (bug#111).
3079 + Avoid rereading uncompressed AbiWord documents in order to calculate their
3084 + Now inserts a ':' between prefix and term, using the same criteria which
3085 Xapian::QueryParser does.
3087 + The 'BOOLEAN' action now ignores an empty input rather than adding just the
3090 + The 'UNIQUE' action now issues a warning for empty input but otherwise
3095 * Add explicit includes of C headers needed to build with the latest snapshots
3098 Omega 1.0.4 (2007-10-30):
3102 * If an OmegaScript template specifies the same field name as both a boolean
3103 and a probabilistic term prefix then previous the boolean setting would
3104 be ignored (e.g. $setmap{prefix,foo,A}$setmap{boolprefix,foo,H}). Now this
3105 generates an error. If you set prefixes in your templates, you may wish to
3106 check them over before upgrading.
3108 Omega 1.0.3 (2007-09-28):
3112 * Distribution tarballs are now in the POSIX "ustar" format since it saves
3113 a few KB and we need to use it for xapian-core anyway.
3117 * Expand the output of 'mbox2omega --help' and refer the reader to it from
3118 docs/scriptindex.txt.
3124 + Add support for indexing AbiWord documents and TeX DVI files.
3126 + Impose a 5 minute CPU time limit on filter programs to prevent problems if
3127 a filter program goes into an infinite loop on a malformed input. Partly
3132 + Fix line number tracking in dump files.
3136 * Add $muldiv{A,B,C} which calculates int(A*B/C).
3138 * Fix bug in decimal fraction in $size for files >= 1M in size.
3144 + Set HTML charset to utf-8 since that's what databases now are by default.
3146 + Restyle to use CSS to draw a "score bar" instead of using images.
3148 + Rework the layout of each hit.
3150 + Add popup hints on mouse-over for various items.
3152 + Tidy up some HTML gremlins.
3154 Omega 1.0.2 (2007-07-05):
3158 * scriptindex.txt: Fix typo.
3164 + If --url isn't passed, default to "/", but print a warning noting that this
3165 default has been used (at least for now).
3167 + Report files that aren't indexed because their extensions aren't
3172 * Value of XAPIAN_CONFIG supplied to configure is now passed to distcheck,
3173 to ensure that it works with uninstalled copies of Xapian.
3177 * Fix test programs to build with a development snapshot of GCC 4.3.
3179 Omega 1.0.1 (2007-06-11):
3183 * overview.txt: As of 1.0.0, we no longer use pstotext for PostScript, but
3184 instead use ps2pdf followed by pdftotext (since this works for Unicode).
3186 * scriptindex.txt: Document that you can delete a document by supplying a new
3187 document which only contains the unique term.
3191 * Fix bug in HTML parser - if the text between two tags consisted entirely of
3192 whitespace it would just be ignored which could run words together if
3193 the tags didn't produce implicit whitespace. This bug dates back to at least
3196 * omindex: Under Linux (and probably some other platforms) struct dirent can
3197 tell us the type of a directory entry for some filing systems, so make use of
3198 this to avoid calling stat() (or lstat()) unnecessarily - when indexing
3199 /usr/share/doc on my Linux box, this saves about 14000 explicit calls to
3200 stat() (leaving about 7000).
3204 * Fix handling of query parsing errors (broken by changes in 1.0.0).
3208 * The required automake version has been lowered to 1.8.3, so RPMs can now be
3209 built on RHEL 4 and SLES 9.
3211 Omega 1.0.0 (2007-05-17):
3215 * Omega and the indexers now work in UTF-8. If iconv() is available, omindex
3216 will use it to convert documents from other formats, otherwise it has
3217 built-in support for UTF-8 and ISO-8859-1; omindex knows how to run the
3218 various external filter programs to generate UTF-8 output; scriptindex
3219 assumes input is already in UTF-8.
3221 * Change the project name (used to name tarballs, and default installation
3222 paths) to "xapian-omega" since that's what the RPMs and Debian packages
3223 already use (there's a Rogue-like game called Omega).
3227 * docs/overview.txt: Document what each of the OmegaScript templates does.
3229 * docs/quickstart.txt: Assorted minor improvements.
3231 * docs/termprefixes.txt: Document new 'Z' prefix, and that the 'R' and 'W'
3232 prefixes are no longer used by Xapian.
3234 * docs/cgiparams.txt: FMT isn't limited to just `a-z' - the actual restriction
3235 is that it may not contain `..'.
3237 * docs/scriptindex.txt: Explicitly note that index=nopos is deprecated
3238 (scriptindex already emits a warning).
3240 * NEWS: Add note that Omega < 0.8.0 NEWS entries are in the xapian-core NEWS
3247 * Updated to use the new Xapian::TermGenerator class. This means that the
3248 indexing strategy has changed.
3250 * "--help" now reports the default stemming language (i.e. "english").
3252 * Implement new sample generating function which normalises all runs of
3253 whitespace to a single space, and fixes invalid UTF-8 in the sample.
3257 + We now index PostScript by converting to PDF with ps2pdf and then indexing
3258 that. This allows us to index PostScript files containing Unicode
3259 characters outside of ISO-8859-1, and also means we now get metadata from
3260 PostScript files. The downside is it is quite a bit slower.
3262 + Add support for indexing MS Works documents using wps2text (part of
3265 + Don't index empty files.
3269 + Fix optimisation of "load truncate=N" to actually work!
3271 + The "truncate" action knows not to chop off a multibyte UTF-8 character.
3273 + Update short option list for scriptindex to match documented usage (-h, -V
3274 and -s were not working).
3276 + Remove -q and -u options - they no longer do anything and are only accepted
3277 for compatibility with really old versions (0.6.1 and earlier for -q; 0.7.5
3278 and earlier for -u).
3282 * Add an alternative implementation of date range filtering which uses a
3283 MatchDecider. This allows everything that the existing implementation does,
3284 plus you can support sorting on a choice of dates (e.g. first published or
3285 last updated), and filtering works to a resolution of a minute rather than a
3286 day. Set CGI parameter DATEVALUE to enable this, and to specify the value to
3287 use. Since omindex now adds the last modified date as value 0, this will
3290 * Enhance $substr{} to accept a negative length (meaning to count back from the
3293 * New CGI parameters to allow finer control of sorting and ranking - SORTAFTER
3296 * The sorting options are now encoded in $filters so Omega can automatically
3297 reset to page 1 if they are changed.
3299 * Add new OmegaScript $weight command which returns the raw document weight -
3300 mostly useful for debugging purposes.
3302 * $topterms{} now generates unstemmed terms.
3304 * $prettyterm{TERM} has been updated to fit with changes to the term generation
3307 * Add 'you' and 'your' as stopwords.
3309 * $filesize{SIZE} enhanced to return a decimal point for K, M, and G (e.g.
3310 "2.1K" and "4.0M" rather than "2K" and "4M"); $filesize{0} is now "0 bytes";
3311 $filesize{1} is now "1 byte"; $filesize{SIZE} where SIZE is negative is now
3314 * Remove $freqs as it has been deprecated for ages.
3316 * Remove support for xB, xDATE1, xDATE2, xDAYSMINUS, and xDEFAULTOP which were
3317 deprecated in favour of xFILTER in 0.7.5 (over 3 years ago).
3319 * Remove deprecated aliases for CGI parameters (deprecated in 0.6.3 or 0.6.5,
3320 more than 3.5 years ago): RAW_SEARCH (now RAWSEARCH), DATE1 (now START),
3321 DATE2 (now END), DAYSMINUS (now SPAN but with slightly different semantics),
3322 and MIN_HITS (now MINHITS).
3324 * Remove "bias_weight" and "bias_halflife" CGI parameters since they rely on
3325 Enquire::set_bias() which has been removed.
3329 * The 'query' template no longer uses $topterms by default.
3331 * New 'topterms' template provides a query template with $topterms support.
3333 * Template fragments which aren't intended for direct use have been moved to
3334 an "inc" subdirectory.
3338 * md5test: Add tests for MD5 code.
3342 * `./configure --enable-quiet' already allows you to specify at configure time
3343 to pass `--quiet' to libtool. Now you can override this at make-time by
3344 using `make QUIET=' (to turn off `--quiet') or `make QUIET=y' (to turn on
3347 * configure: Disable probes for f77, gcj, and rc completely by preventing
3348 the probe code from even appearing in configure - this reduces the size of
3349 configure by 29% and should speed it up significantly.
3353 * Fixed to build with GCC 4.3 snapshot.
3355 * We now make use of the safe*.h portability headers from xapian-core.
3357 * Ensure that the result of snprintf is zero terminated since MSVC's snprintf
3358 is broken (by design it seems).
3360 * configure: xapian-config --cxxflags now includes -ptused for SGI's C++
3361 compiler, so we don't need to probe for it here.
3363 * configure: Perform a link test for posix_fadvise to fix misdetection on
3366 Omega 0.9.10 (2007-03-04):
3370 * docs/omegascript.txt: Rewrite introductory paragraph. Note that
3371 whitespace is significant, and add explicit warning to $setmap.
3373 * docs/termprefixes.txt: Expand section on boolean prefixes, showing
3374 how to generate them using scriptindex, and how to allow them to be
3375 selected in an HTML form.
3379 * omindex: Generate correct MD5 checksums on big-endian platforms.
3383 * Fix $substr{} with negative start to actually work.
3385 * Fix $substr{} to never cause a C++ exception.
3389 * omega.spec.in: Remove "." from the end of the Summary.
3391 Omega 0.9.9 (2006-11-09):
3395 * Ship our custom INSTALL file rather than the generic one from autoconf which
3396 we've accidentally been shipping instead since 0.9.5.
3400 * scriptindex: The "date" action no longer modifies the value it operates on
3401 (it was never meant to!)
3405 * Report an error if $setmap is called with an even number of parameters.
3406 An incorrect example in the documentation used to suggest this, so it's
3407 particularly useful to catch this case.
3411 * RPMs: Prevent binaries getting an rpath for /usr/lib64 on FC6.
3413 Omega 0.9.8 (2006-11-02):
3417 * $substr where the start is negative and longer than the string (e.g.
3418 $substr{abcd,-5,1}) wasn't working as intended.
3422 * configure: Tell AC_CHECK_HEADERS to suppress its backward compatibility mode,
3423 so it only checks headers with the compiler. This speeds up configure a
3424 little, and is what we do elsewhere.
3426 * configure: Warning flags for GCC weren't actually getting used. Fix this to
3427 work and use the same warning flags for GCC and Intel C++ as xapian-core does.
3428 Fix all the warnings this uncovered!
3430 * omega,omindex,scriptindex: Remove some old unused code.
3434 * Ensure that we always pass an unsigned char value to isupper(), toupper(),
3435 etc as they are undefined on other values (glibc makes them work for signed
3436 char values too, but this is an extension).
3438 * configure: Pass magic options to SGI's C++ compiler to allow linking of
3441 * configure: IRIX doesn't allow stdint.h to be included from C++ so we need
3442 a smarter configure test than AC_CHECK_HEADERS.
3444 * Fix warnings from SGI's C++ compiler.
3446 Omega 0.9.7 (2006-10-10):
3450 * omegascript.txt: Note that (by design) an omegascript template can't
3451 contain an infinite loop.
3453 * termprefixes.txt: "$setmap{title,S}" should be "$setmap{prefix,title,S}".
3455 * Use the default paths to the database directories and the omega CGI binary in
3458 * README: Update reference to "CVS" to say "SVN".
3462 * Don't get confused by "a<b" in Javascript in a <script> tag. Fixes bug#91.
3464 * Support htdig's "ignore this bit" comments.
3466 * Don't generate terms with more than 3 trailing symbols ('-', '+', or '#').
3470 + Add the file last modified time as value #0.
3472 + Generate an MD5 checksum of each file indexed and store it in value #1
3473 to allow duplicates to be collapsed.
3475 + Store the file's last modified time in the document data as "modtime" so it
3476 shows up in search results (and tweak the query template so the display of
3477 this information looks nicer). Don't add "modtime" field if the timestamp
3480 + Run pdfinfo once and pull out the fields we want using string operations,
3481 instead of running it twice filtered through sed.
3483 + Parse the XML from OpenDocument and OpenOffice using new subclasses of
3484 HtmlParser. Only extract meta.xml once.
3486 + Add "size" field to document data.
3488 + Run xls2csv on MS Excel files, run catppt on MS Powerpoint files, and also
3489 index MS Word templates (.dot) the same way as .doc files.
3491 + Don't generate 'W' terms since omega doesn't use them.
3493 + If a filter program isn't installed, then don't try it again for the same
3494 extension (not perfect but an improvement - previously we indexed an empty
3497 + If popen() fails, treat it as a read error.
3501 + Add new "load" action to allow the contents of an external file to be
3504 + Fix check for whether a record has content in the case where the same field
3505 is processed more than once.
3509 * Add $pack and $unpack OmegaScript commands to allow big endian binary values
3510 to be encoded and decoded (for use with omindex's lastmod in value #1).
3512 * omega.conf: Fix code which reads omega.conf to be line based as documented
3513 rather than the wacky whitespace based scheme that was actually implemented.
3514 Also we now allow "#" comments and blank lines in omega.conf.
3516 * Fix $highlight{} to work with capitalised words (it used to work but
3517 regressed in 0.8.2).
3519 * Use '\t' to separate terms in xP since filter terms might contain '.'. Fixes
3524 * Add htmlparsetest which tests the MyHtmlParser class.
3528 * Makefile.am: Make use of the dist_ prefix to avoid having to list files in
3529 EXTRA_DIST as well as in *_SCRIPTS, *_DATA, and man_MANS.
3531 * Makefile.am: Prefer $(sysconfdir) to @sysconfdir@ since the former can be
3532 overridden on the "make" command line.
3536 * xapian-config will now switch Sun's C++ compiler into ANSI C++ compliant
3537 mode, so remove all the special case bits of code added for just this one
3540 * omindex: Fix escaping of filenames to cast characters to "unsigned char" so
3541 that isalnum() works correctly everywhere. Not a security hole as dangerous
3542 characters were still being escaped.
3544 * Call pclose() not fclose() on a FILE* obtained from popen(). This bug could
3545 cause us to run out of file descriptors on some platforms.
3547 * configure: Check for strftime.
3551 * omega.spec.in: Include documentation in the RPM package.
3553 Omega 0.9.6 (2006-05-15):
3557 * docs/omegascript.txt: Clarified description of $now.
3561 * scriptindex: Fix "index" and "indexnopos" without a prefix to set the weight
3562 correctly (bug introduced in 0.9.5).
3566 * Added new OmegaScript commands $filterterms and $substr.
3570 * configure: Update snprintf detection to match xapian-core.
3572 * Fix MSVC warnings.
3576 * omega.spec.in: Create and package /var/lib/omega/cdb and /var/log/omega.
3578 Omega 0.9.5 (2006-04-08):
3582 * README: Add pointer to documentation.
3584 * Added man pages for omindex and scriptindex, generated using help2man.
3590 + If we fail to open the index script, die with an error (previously we
3591 acted as if an empty file was specified).
3593 + Warn about a useless "weight" action, even if it's followed by another
3594 non-useless action (e.g. "field") - previously we only warned if it
3595 was last or followed only by other useless actions.
3597 + Warn if "unique=<prefix>" is used without a corresponding
3598 "boolean=<prefix>" on the same line.
3600 + Warn that "index=nopos" is deprecated and should be replaced by
3603 + Add explanatory text "(note that actions are executed from left to right)"
3604 when reporting useless actions.
3606 + Added new "hash" command to allow hashed terms to be generated from long
3607 URLs like omindex does.
3609 * htdig2omega.script,mbox2omega.script: Make use of the new scriptindex "hash"
3612 * dbi2omega: Check DBIDRIVER environmental variable to allow a driver other
3613 than mysql to be specified without modifying the script.
3617 * Fix $opt[fieldnames] handling. Previously it would try to kick in if you
3618 didn't set fieldnames but set any alphabetically later option! The symptom
3619 was that $field{} would stop working (bug#72).
3623 * omindex,omega: Tweaks for MSVC compilation.
3625 Omega 0.9.4 (2006-02-21):
3629 * COPYING: Updated FSF address.
3631 Omega 0.9.3 (2006-02-16):
3635 * overview.txt: The U prefix (URL term) was grouped with the date searching
3636 prefixes, but it makes more sense to group it with the prefixes relating to
3637 parts of the URL (H for hostname, P for path, etc).
3639 * overview.txt: Add pointer to documentation of the supported query syntax.
3641 * omegascript.txt: Improve descriptions of $cgi, $collapsed, $value, $version.
3643 * termprefixes.txt: Fix typo.
3647 * omindex: add --preserve-nonduplicates / -p option to not delete any documents
3648 that aren't updated, in replace duplicates mode (so that multiple runs of
3649 omindex on different subsites don't stomp on each other).
3651 * omindex,scriptindex: Add "--stemmer" option to omindex and scriptindex
3652 to allow the stemming language to be set. Fixes bug#11.
3654 * omindex,scriptindex: More consistent --help and --version output.
3656 * omindex: Add support for OpenDocument format mimetypes and extensions out of
3657 the box. Previously you could index them but had to pass a "-m" option for
3658 each OpenDocument filename extension you wanted to handle.
3660 * scriptindex: The "-q" option no longer actually controls anything. Just
3661 ignore it for backwards compatibility (and don't document it in --help).
3665 * If executing an OmegaScript command causes a Xapian exception to be thrown,
3666 catch it and copy the error message into error_msg (which is read by the
3667 $error command). This allows such errors to reported in a nicer way.
3669 * Added "SORTREVERSE" CGI parameter which allows the sort order to be reversed
3670 when sorting on a value. Removed "SORTBANDS" CGI parameter since it no
3671 longer does anything.
3673 * Added $find{LIST,STRING} to return the subscript of the first occurrence of
3674 string STRING in list LIST.
3676 * Added $lookup{CDBFILE,KEY} OmegaScript command to perform a lookup in a CDB
3679 * Added new feature which allows you to avoid storing fieldnames in every
3680 document. Instead you just store the field values, one per line, and add
3681 something like "$set{fieldnames,$split{caption sample url}}" to the
3682 OmegaScript template to specify the fieldnames to use. This can save a lot
3683 of disk space for a large database.
3685 * Add new "$split{}" OmegaScript command which splits a string to give an
3688 * Fix $url{} to escape "+" to "%2b". Also fix encoding of top-bit-set
3689 characters on platforms where char is signed by default.
3691 * Speed up $highlight{} - only compare terms which are the same length.
3693 * Reduce memory usage if a lot of documents are marked as relevant.
3697 * query: Make the page title shorter so there's more chance it will fit on icon
3700 * opensearch: Add missing escaping.
3702 * godmode: If a non-existent docid is specified, report the error and prompt
3703 the user to enter another docid. Fixes bug#60.
3707 * omega: Fix printf type mismatch on 64 bit platforms.
3709 * omega: Cast time_t to unsigned long to avoid problems on 64bit platforms.
3711 * Use snprintf where available.
3713 * Write top-bit set characters using \xXX notation to avoid warnings from
3714 Intel's C++ compiler.
3716 Omega 0.9.2 (2005-07-15):
3718 * omega: Changed $highlight so if OPEN and CLOSE aren't specified, they default
3719 to highlighting each word from the query with a different background colour
3720 like gmane does (previous default was to use '<strong>' and '</strong>').
3722 * omega: Call QueryParser::set_database() as this is now used to decide what to
3723 do for terms like "C#".
3725 * omega: Added the ability to set boolean prefixes for the QueryParser by
3726 setting a "boolprefix" map in the omegascript template.
3728 * omega: Added $length{} and $stoplist{} commands to OmegaScript.
3730 * scriptindex: Fix infinite loop if there's no newline at the end of a dumpfile.
3732 * docs/termprefixes.txt: Explain how to use termprefixes with scriptindex and
3733 omega, since that's what most people will want to know.
3735 * docs/omegascript.txt: Use standard "S" prefix for title in example for
3736 $setmap, rather than "XT".
3738 Omega 0.9.1 (2005-06-06):
3740 * Releases are now created using libtool 1.5.18 and automake 1.9.5.
3742 * Updated RPM packaging.
3744 Omega 0.9.0 (2005-05-13):
3746 * Updated for 0.9.0 API changes.
3748 * omindex/scriptindex: Generate terms like "c#".
3750 * Added mbox2omega script which allows a mail folder to be indexed using
3751 scriptindex. Mostly it's an example as there's no mechanism included to show
3752 the full original message.
3756 * The configuration file is now looked for differently - you can now set
3757 the environmental variable OMEGA_CONFIG_FILE. See docs/overview.txt for
3760 * $highlight can now highlight terms like "C#".
3762 * Add new template 'opensearch' to implement basic opensearch feeds of search
3767 * URL hashing previously depended on sizeof(long) so databases weren't totally
3768 portable between platforms. This is now fixed, but to do so we've had to
3769 break compatibility with databases built on platforms with 64 bit longs
3770 with URLs > 228 bytes.
3772 * Removed useless "DUPE_duplicate" option.
3774 * Added support for indexing Perl "pod" documentation using pod2text.
3776 * Replaced -l/--no-recurse with -l/--depth-limit which takes an argument
3777 allowing recursion to be restriction to any depth, not just 0 or infinity!
3779 * Extend -M/--mime-type to allow an existing mapping to be removed by omitting
3782 * Fixed code so that we get lstat() prototype on Linux systems where we have
3787 * Improved handling of extra blank lines in dump file.
3789 * Strip multiple \r characters from end of line.
3791 * Complain if a dump file doesn't appear to have been = escaped correctly.
3793 * Flush database after each input file to ensure all changes from a file
3798 * docs/omegascript.txt: Clarify $field description slightly.
3800 * docs/cgiparams.txt,docs/omegascript.txt: Fixed 3 references to OmXxxx classes.
3802 * docs/termprefixes.txt: Added a single document covering all aspects of term
3805 * docs/omegascript.txt: Moved $collapsed into correct place alphabetically!
3807 * docs/cgiparams.txt,docs/overview.txt: Improved description of how B filters
3808 are handled when building the query.
3810 * docs/scriptindex.txt: Note that actions are applied in the specified order.
3812 Omega 0.8.5 (2004-12-23):
3814 * README,INSTALL: Proper installation instructions.
3816 * omega: If an exception is thrown, make sure that the HTTP headers
3817 get written so that we don't cause "500 Internal Server Error".
3818 This problem was introduced by the change to allow a user specified
3819 Content-Type in 0.8.0. Partly addresses bug#60.
3821 * scriptindex: Fixed "Unknown Exception" when trying to "unhtml" text which
3822 contains "</body>" (bug#61). This bug was introduced in 0.8.4.
3824 * omindex/scriptindex: <h1> - <h6> and </h1> - </h6> now leave a space in the
3825 dumped HTML. This bug was introduced in 0.8.4 - before that any tag left
3826 a space in the dumped HTML.
3828 * omindex: Only try to delete removed documents in "replace duplicates" mode
3829 (which is the default).
3831 * omindex: Change behaviour of crawler such that it doesn't follow symbolic
3832 links any more. The new "--follow" command line option turns following of
3835 * dbi2omega: Add a comment to the start of the file detailing what
3838 Omega 0.8.4 (2004-12-08):
3840 * omindex,scriptindex: Improved HTML to text conversion - now we strip
3841 leading and trailing whitespace and convert all other consecutive groups of
3842 whitespace to a single space. Also the parser now knows that some tags
3843 should be regarded as word breaks and some shouldn't (previously all tags
3844 were treated as word breaks).
3846 * omindex: Removed bogus extra line from code which was meant to
3847 truncate samples, titles, etc at a word boundary, but has never actually
3850 * omindex: Added hooks for indexing the following formats: OpenOffice (requires
3851 unzip), MS Word (requires antiword), Wordperfect (requires wpd2text), RTF
3854 * omindex: If a filename to be passed to a filter program has a leading "-",
3855 protect it from possible interpretation as an option by prepending "./".
3857 * omega: When there's only a boolean query we promote it to be the query.
3858 Tweaked so we use boolean weights in this case.
3860 * omega: Use Query::empty() instead of the now deprecated Query::is_empty().
3862 * omega,omindex,scriptindex: Use the new Database/WritableDatabase
3865 * templates/godmode: Finished off godmode template.
3867 * Compile everything as C++.
3869 * Check snprintf actually works - some older versions don't implement C90
3872 * XAPIAN_FLAGS already links with xapianqueryparser so remove
3873 -lxapianqueryparser from omega_LDADD as it was causing link errors on cygwin.
3875 Omega 0.8.3 (2004-09-20):
3877 * scriptindex: --version now actually reports the version. --help now exits
3878 with status 0 rather than status 1.
3880 * RPM packaging: Updated. The most notable change is that the RPM is now
3881 called xapian-omega because there's already an omega RPM (in Fedora Core at
3882 least) which is a game. Also htdig2omega and htdig2omega.script are now
3883 included in the RPM.
3885 * Install htdig2omega.script in ${prefix}/share/omega/ rather than
3888 Omega 0.8.2 (2004-09-13):
3890 * omega: $highlight now handles accented characters (bug#9).
3892 * omega: Use new checkatleast parameter to Enquire::get_mset to implement
3895 * omindex: When running with "replace duplicates" mode (the default), detect
3896 documents removed since the last indexing run and delete them from the
3899 * omindex: Use the new WritableDatabase::replace_document(term, doc) method.
3901 * scriptindex: Report index script file name and line number when
3902 reporting errors in it. Added warning for redundant actions,
3903 such as "truncate" as the last action in a rule.
3905 * templates/query: Always report if the database is not found - previously we
3906 only did so if there was a query.
3908 * templates/query: Fixed missing </center> tag which happened in certain cases.
3910 * docs/omegascript.txt: Added note about that $add{$hit,1} gives
3913 * Now includes htdig2omega and htdig2omega.script which allow you to crawl
3914 remote websites with ht://dig, then build a searchable index of them with
3917 * Link with -lxapianqueryparser, not -lomqueryparser.
3919 Omega 0.8.1 (2004-06-30):
3921 * omindex: Renamed hash() to hash_string() to avoid colliding with something
3924 * omega: Changed MORELIKE to pick up to 40 terms, rather than up to 6 (feedback
3925 on the mailing list suggests this gives much better results).
3927 * scriptindex: Added explicit catch for std::bad_alloc.
3929 Omega 0.8.0 (2004-04-19):
3931 * scriptindex: Change default to *not* overwriting the database (use
3932 --overwrite if you really want to do this); -u is now accepted but ignored.
3934 * scriptindex: Use getopt for option parsing.
3936 * omindex: Added --overwrite option which forces an existing database to be
3937 deleted before indexing begins.
3939 * templates/xml: Correct spelling of `relavence' to `relevance'. NB: if you're
3940 parsing the XML output, you'll need to fix this spelling in your parser!
3942 * templates/xml: Now set HTTP header: "Content-Type: application/html".
3944 * templates/xml: Remove unused OmegaScript code:
3945 `$set{topterms,$or{$ne{$msize,0},$query}}'.
3947 * indextext.cc,omindex.cc,scriptindex.cc: Updated to use add_term() instead of
3950 * omega: Added $httpheader Omegascript to allow arbitrary HTTP headers and
3951 alternative Content-Type headers to be specified.
3953 * omega: If the probabilistic query was bad, don't try to run the match.
3955 * omega: Don't crash if there's a date filter but no probabilistic query.
3957 * omindex/scriptindex: Raw terms with a multicharacter prefix are now indexed
3958 with a : inserted (e.g. as XFOO:Rterm). This matches what the query parser
3961 * omindex/scriptindex: Don't create R terms for terms which start with a digit.
3963 * omindex: Use O_STREAMING and/or posix_fadvise() when reading files to be
3964 indexed (if available). This helps to keep the Xapian database in cache,
3965 and should greatly improve indexing throughput.
3967 * docs/scriptindex.txt: Make more explicit that boolean produces a *single*
3970 * docs/cgiparams.txt: Note that START and END should be in the format YYYYMMDD.
3972 For NEWS entries for Omega versions prior to 0.8.0, see the xapian-core NEWS