diff options
Diffstat (limited to 'raidgrep.1.asciidoc')
| -rw-r--r-- | raidgrep.1.asciidoc | 278 | 
1 files changed, 278 insertions, 0 deletions
| diff --git a/raidgrep.1.asciidoc b/raidgrep.1.asciidoc new file mode 100644 index 0000000..a737bce --- /dev/null +++ b/raidgrep.1.asciidoc @@ -0,0 +1,278 @@ += raidgrep(1) +:doctype: manpage +:man source: raidgrep +:man manual: raidgrep manpage +:toc: +:homepage: https://gitlab.com/dunj3/raidgrep + +== NAME +raidgrep - A search tool for Guild Wars 2/arcdps log files. + +== SYNOPSIS +*raidgrep* ['-OPTION' ['...']] ['--' ['-PREDICATE' ['...']]] + +== DESCRIPTION +raidgrep is a CLI search tool to search through .evtc log files generated by +arcdps (a Guild Wars 2 addon). + +raidgrep was inspired by other search tools - namely +ripgrep+ and +find+ - but +has support for reading and parsing the binary files produced by arcdps and +applying Guild Wars 2 specific filters. + +== OPTIONS + +The following options have to be given before any filters are given on the +command line: + +*--debug*:: +    Print more debugging information to stderr. + +*-l*, *--files-with-matches*:: +    Only show the name of matching files. + +*--guilds*:: +    Load guild information from the API. + +    + +    Loading guild information requires network access and slows down the +    program considerably, so this is disabled by default. + +*--no-color*:: +    Disable colored output. + +*--repl*:: +    Run the REPL. + +*-V*, *--version*:: +    Prints version information. + +*-d* 'path', *--dir* 'path':: +    Path to the folder with logs [default: .] + +== PREDICATES + +The following predicates can be used after the options. Note that they should +be preceeded by a +--+ on the command line, to signal the parser to switch from +parsing options to parsing predicates. + +=== Predicate Combinators + +'A' [*and*] 'B':: +    Match the log only if both 'A' and 'B' are matching. The *and* is optional, +    predicates written after each other are implicitely joined with *and*. + +'A' *or* 'B':: +    Match the log if 'A' or 'B' are matching. + +*not* 'PREDICATE':: +    Match the log only if the given predicate does not match. + +*(* 'PREDICATE' *)*:: +    Parenthesis can be used to group predicates to enforce the correct operator +    ordering. + +=== Log Predicates + +Those predicates can be used as-is in the filter: + +*-success*:: +    Include logs that are successful. + +*-wipe*:: +    Include logs that are failed. + +*-outcome* 'OUTCOMES':: +    Include logs with the given outcomes. Outcomes are 'success', 'wipe', or a +    comma-separated combination thereof. + +*-weekday* 'WEEKDAYS':: +    Include logs made on the given weekdays. Weekdays are given either fully or +    as a 3-letter-abbreviation and can be combined by commas. + +*-before* 'DATE':: +    Include logs made before the given date. Date can be either in +    "year-month-day" or "year-month-day hour:minute:second" format. + +*-after* 'DATE':: +    Include logs made after the given date. See *-before* for valid date +    formats. + +*-boss* 'BOSSES':: +    Include logs from the given bosses. See below for a list of valid boss +    names. Names can also be comma separated. + +*-player* 'REGEX':: +    Include logs in which at least one player's account or character name +    matches the given regex. + +    + +    Note that you have to quote the regex if it contains spaces or other special characters. + +*all(player:* 'PREDICATES' *)*:: +    Include logs in which all players match the given player predicates. See +    below for a list of player predicates. + +*any(player:* 'PREDICATES' *)*:: +    Include logs in which any player matches the given player predicates. See +    below for a list of player predicates. + +=== Player Predicates + +The following predicates have to be wrapped in either a *any(player: ...)* or +*all(player: ...)* construct to be accepted. + +*-character* 'REGEX':: +    Matches the player if the character name matches the given regular +    expression. + +*-account* 'REGEX':: +    Matches the player if the account name matches the given regular +    expression. + +*-name* 'REGEX':: +    Shorthand that matches if the character or the account name match the given +    regular expression. + +=== Boss Names + +Bosses can be referred to by their official name, although if that name +contains spaces it must be enclosed in quotes, and it's cumbersome to write. +Therefore, raidgrep also accepts a lot of shorthands that are established in +the community. + +The following list is an inexhaustive list of all accepted boss names, with one +name per boss given: + +* *Wing 1*: vg, gorseval, sabetha +* *Wing 2*: slothasor, matthias +* *Wing 3*: kc, xera +* *Wing 4*: cairn, mo, samarog, deimos +* *Wing 5*: desmina, dhuum +* *Wing 6*: ca, largos, qadim +* *Wing 7*: adina, sabir, qadimp +* *100 CM*: skorvald, artsariiv, arkk +* *99 CM*: mama, siax, ensolyss +* *Strike Missions*: icebrood, fraenir, kodans, boneskinner, whisper + +=== Regular Expressions + +raidgrep uses Rust's +regex+ library for regular expression support. A full +syntax reference can be found at https://docs.rs/regex/#syntax. A (very) short +primer is given here: + +*foo*:: +    Match foo literally. + +*foo|bar*:: +    Match either foo or bar. + +*.*:: +    Match any character. + +*^*:: +    Match the beginning of the string. + +*$*:: +    Match the end of the string. + +=== A Note About Quoting + +raidgrep uses its own parser to split and parse the given predicates. However, +when calling raidgrep from the command line, the shell also applies some +splitting. raidgrep tries to reconstruct the given predicates as good as +possible, but it does not always work. + +This means that sometimes, predicates as described here may not work correctly +when used in the CLI argument. To circumvent this, there are multiple options: + +* Use the raidgrep REPL, which is not subject to your shell's splitting. +* Pass the filter as a single big argument, which is usually achieved by +  enclosing it in quotes and escaping any quotes in the filter. + +Most use cases should work without much adaption. If there is a case that looks +like it should work but doesn't, feel free to report it as a bug (see below). + +== REPL + +If given the *--repl* option, raidgrep will not start searching for logs and +instead enter a read-eval-print-loop. You can give it a predicate, it will +print the results and ask for the next predicate. + +Any options given in this mode will apply to the whole REPL session. For +example, if started with *-l*, all REPL evaluations will only print the file +names of the matching files. + +== EXAMPLES + +The following are examples of predicates as they might be entered in the REPL. +They can also be used on the command line, but proper escaping might have to be +applied (depending on your shell): + ++-success -player Godric+:: +    Find any logs that were successful and had a player called "Godric" in +    them. + ++-wipe (-player Godric or -player Emma)+:: +    Find any logs that were unsuccesful and had either a player called "Godric" +    or a player called "Emma" in them. + ++-after 2020-01-01 any(player: -character Xenia)+:: +    Find any logs after the 1st of January 2020 where a player had a character +    name matching "Xenia". + +The following examples are raidgrep invocations that show how predicates can be +supplied as arguments to raidgrep: + ++raidgrep -- -success -player Godric+:: +    Same as above. Special quoting is not necessary, as raidgrep can figure out +    what the user meant. + ++raidgrep -- -player "Godric Gobbledygook"+:: +    Find any logs with a player called "Godric Gobbledygook". Raidgrep can +    figure out how the quotes were meant to be, even though the shell stripped +    them away. + +`raidgrep -- 'all(player: -character "o{2}")'`:: +    In this example, the whole command line is wrapped in single quotes, to +    prevent the shell from splitting it apart. This should work for most +    predicates. + +== FILES + +* '$XDG_CACHE_HOME/raidgrep': Temporary data. + +Note that 'XDG_CACHE_HOME' defaults to '~/.cache' if unset. + +== BUGS + +Bugs and other issues are tracked in the Gitlab repository at +https://gitlab.com/dunj3/raidgrep/-/issues. + +If you want to report a bug, you can either + +* Open an issue in the aforementioned issue tracker +* Write an email to mailto:raidgrep@kingdread.de[] +* Contact me through Guild Wars 2: +Dunje.4863+ + +When reporting a bug, please include as much information as you can beforehand +- that includes the version of raidgrep that you are using, your operating +system and (if possible) the log file itself that raidgrep fails on. + +== COPYRIGHT +This program is free software: you can redistribute it and/or modify it under +the terms of the GNU General Public License as published by the Free Software +Foundation, either version 3 of the License, or (at your option) any later +version. + +This program is distributed in the hope that it will be useful, but WITHOUT +ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along with +this program.  If not, see <http://www.gnu.org/licenses/>. + +== RESOURCES +* Source repository: https://gitlab.com/dunj3/raidgrep/ +* Binary releases: https://kingdread.de/raidgrep/ +* arcdps addon for Guild Wars 2: https://www.deltaconnected.com/arcdps/ + +== AUTHOR +*raidgrep* was written by Daniel Schadt. | 
