Skip to content

Commit

Permalink
Merge pull request googleprojectzero#2 from uberspot/master
Browse files Browse the repository at this point in the history
Really minor typos
  • Loading branch information
ifratric authored Sep 22, 2017
2 parents 33fb6ef + 04a7dd3 commit af2fa7a
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 8 deletions.
12 changes: 6 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ To generate multiple samples with a single call run:

`python generator.py --output_dir <output directory> --no_of_files <number of output files>`

The generated samples will be placed in the specified directory and will be named as fuzz-&lt;number&gt;.html, e.g. fuzz-1.html, fuzz2.html etc. Generating multiple samples is faster because the input grammar files need to be loaded and parsed only once.
The generated samples will be placed in the specified directory and will be named as fuzz-&lt;number&gt;.html, e.g. fuzz-1.html, fuzz-2.html etc. Generating multiple samples is faster because the input grammar files need to be loaded and parsed only once.

#### Code organization

Expand Down Expand Up @@ -60,7 +60,7 @@ A grammar is described as a set of rules in the following basic format

`<symbol> = a mix of constants and <other_symbol>s`

Each grammar rule contains a left side and the right side separated by the equal character. The left side contains a symbol, while the right side contains the details on how that symbol may be expanded. When expanding a symol, all symbols on the right-hand side are expanded recursively while everything that is not a symbol is simply copied to the output. Note that a single rule can't span over multiple lines of the input file.
Each grammar rule contains a left side and the right side separated by the equal character. The left side contains a symbol, while the right side contains the details on how that symbol may be expanded. When expanding a symbol, all symbols on the right-hand side are expanded recursively while everything that is not a symbol is simply copied to the output. Note that a single rule can't span over multiple lines of the input file.

Consider the following simplified example of a part of the CSS grammar:

Expand Down Expand Up @@ -114,7 +114,7 @@ To generate programming language code, a similar syntax can be used, but there a
!end lines
```

If we instruct the engine to generate 5 lines, we may end up with someting like
If we instruct the engine to generate 5 lines, we may end up with something like

```
try { var00001 = document.getElementById("hw"); } catch(e) {}
Expand Down Expand Up @@ -173,7 +173,7 @@ Importing works a bit differently
!import other.txt
```

tells the parser to create a new Grammar() object that can then be referenced from the current grammar by using the special `<import>` symbol, for exampple like this:
tells the parser to create a new Grammar() object that can then be referenced from the current grammar by using the special `<import>` symbol, for example like this:

```
<cssrule> = <import from=css.txt symbol=rule>
Expand Down Expand Up @@ -202,7 +202,7 @@ Sometimes you might want to call custom Python code in your grammar. For example

The python functions are defined between ‘!begin function <function_name>’ and ‘!end function’ commands. The functions can be called in two ways: using ‘beforeoutput’ attribute and using <call> symbol.

By specifying the ‘beforeoutput’ attribute in some symbol, the corresponding function will be called when this symbol is expanded, just before the result of the expension is output to the sample. The expansion result will be passed to the function in the ret_val variable. The function is then free to modify ret_val, store it for later use or perform any other operations.
By specifying the ‘beforeoutput’ attribute in some symbol, the corresponding function will be called when this symbol is expanded, just before the result of the expansion is output to the sample. The expansion result will be passed to the function in the ret_val variable. The function is then free to modify ret_val, store it for later use or perform any other operations.

When using a special `<call>` symbol, the function (specified in a ‘function’ attribute) will be called when the symbol is encountered during language generation. Any value stored by the function in ret_val will be considered the result of the expansion (ret_val gets included in the sample).

Expand All @@ -224,7 +224,7 @@ The following symbols have a special meaning and should not be redefined by user
- `<space>` - space character
- `<tab>` - tab character
- `<ex>` - ‘!’ character
- `<char>` - can be used to generate an arbitrary ascii character using ‘code’ attribute. For example `<char code=97>` corresponds to ‘a’. Generates random character if not speciffied. Supports ‘min’ and ‘max’ attribute.
- `<char>` - can be used to generate an arbitrary ascii character using ‘code’ attribute. For example `<char code=97>` corresponds to ‘a’. Generates random character if not specified. Supports ‘min’ and ‘max’ attribute.
- `<hex>` - generates a random hex digit
- `<int>`, `<int 8>`, `<uint8>`, `<int16>`, `<uint16>`, `<int32>`, `<uint32>`, `<int64>`, `<uint64>` - can be used to generate random integers. Supports ‘min’ and ‘max’ attribute that can be used to limit the range of integers that will be generated. Supports the ‘b’ and ‘be’ attribute which makes the output binary in little/big endian format instead of text output.
- `<float>`, `<double>` - generates a random floating-point number. Supports ‘min’ and ‘max’ attribute (0 and 1 if not specified). Supports ‘b’ attribute which makes the output binary.
Expand Down
4 changes: 2 additions & 2 deletions grammar.py
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ class Grammar(object):
>>> grammar.ParseFile('grammar.txt')
After this, you can generate the language starting from the root symbol:
>>> ret = grammar.GenerateRoot()
Or a speciffic symbol
Or a specific symbol
>>> ret = grammar.GenerateSymbol('foo')
"""

Expand Down Expand Up @@ -692,7 +692,7 @@ def _RemoveComments(self, line):
def _FixIdents(self, source):
"""Fixes indentation in user-defined functions.
Exec requires zero firs-level indentation. This function fixes it by
Exec requires zero first-level indentation. This function fixes it by
finding a minimum indentation in code and removing it from all lines.
Args:
Expand Down

0 comments on commit af2fa7a

Please sign in to comment.