# Vocabulary Operations This directory contains a command-line tool that provides operations for Vocabulary structures, including intersection, difference, union, version, filterCommon and export. ## Usage: The vocabulary-operations tool accepts a command that specifies which operation (union, intersection, difference, version, filterCommon, export) to run, and accepts at least one vocabulary file as an argument. Files can be provided using either command line arguments: vocabulary-operations -[command] [] [] ... [] or can be read using standard input: vocabulary-operations -[command] < [] where is a text file containing the paths of vocabulary protocol buffer files. ## Examples: vocabulary-operations -union < [] The `-union` options creates a new Vocabulary pb that combines the provided pb files into one large Vocabulary pb. The new Vocabulary pb is saved in the current working directory as "vocabulary-operations.pb" vocabulary-operations -intersection [] [] The `-intersection` options creates a new Vocabulary pb that contains vocabulary that is present in all of the provided files. The new Vocabulary pb is saved in the current working directory as "vocabulary-operations.pb" vocabulary-operations -difference [] [] The `-difference` options creates a new Vocabulary pb that contains vocabulary that is present in the first provided file but not the other provided files. The new Vocabulary pb is saved in the current working directory as "vocabulary-operations.pb" vocabulary-operations -version ["directory path"] The `-version` option creates a new VersionHistory pb that contains the history of an API's lifecycle. The operator takes a directory which contains numerous versions of the same API's vocabulary, and creates a VersionHistory pb which contains the new and deleted terms from each update. The VersionHistory is saved in the current working directory as "(directory-name)-version-history.pb" vocabulary-operations -filter-common <[files.txt]> The `-filter-common` option takes numerous vocabularies and will return a slice of Vocabulary pbs that contain the unique term for each API among the other. The new Vocabulary pb is saved in the current working directory as "vocabulary-operations.pb" vocabulary-operations -export [] The `-export` option accepts *one* Vocabulary file and converts it into a user-friendly readable CSV file. The CSV file is saved in the current working directory as "vocabulary-operations.csv". **Note:** While the other options accept both command line arguments and standard input, the export function only supports command line arguments.