4343f704c3b83b37d1c6784504e19463561d77ad jcasper Wed Apr 16 08:53:12 2025 -0700 Some command-line tools useful for parsing MaveDB data, refs #31812 diff --git src/hg/oneShot/hgvsToBed/hgvsToBed.c src/hg/oneShot/hgvsToBed/hgvsToBed.c new file mode 100644 index 00000000000..97c9df5eb75 --- /dev/null +++ src/hg/oneShot/hgvsToBed/hgvsToBed.c @@ -0,0 +1,46 @@ +/* hgvsToBed - Translate an HGVS term into BED coordinates if possible. */ +#include "common.h" +#include "linefile.h" +#include "hash.h" +#include "options.h" +#include "jksql.h" +#include "hgHgvs.h" + +void usage() +/* Explain usage and exit. */ +{ +errAbort( + "hgvsToBed - Translate an HGVS term into BED coordinates if possible\n" + "usage:\n" + " hgvsToBed \n" + "options:\n" + " -xxx=XXX\n" + ); +} + +/* Command line validation table. */ +static struct optionSpec options[] = { + {NULL, 0}, +}; + +void hgvsToBed(char *db, char *hgvsTerm) +/* hgvsToBed - Translate an HGVS term into BED coordinates if possible. */ +{ +struct hgvsVariant *hgvs = hgvsParseTerm(hgvsTerm); +if (hgvsValidate(db, hgvs, NULL, NULL, NULL)) //char **retFoundAcc, int *retFoundVersion, +// char **retDiffRefAllele); + { + struct bed *output = hgvsMapToGenome(db, hgvs, NULL); //char **retPslTable); + bedTabOut(output, stdout); + } +} + +int main(int argc, char *argv[]) +/* Process command line. */ +{ +optionInit(&argc, argv, options); +if (argc != 3) + usage(); +hgvsToBed(argv[1], argv[2]); +return 0; +}