@speleotica/frcsdata 4.0.1 → 4.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -268,6 +268,7 @@ lines) {
268
268
  };
269
269
  trips.push(trip);
270
270
  } else if (trip) {
271
+ var _exec;
271
272
  const {
272
273
  shots,
273
274
  header: {
@@ -340,6 +341,32 @@ lines) {
340
341
  down
341
342
  };
342
343
  }
344
+ let comment = getComment();
345
+ let fromLrudComment = comment;
346
+ const commentFromStr = comment ? (_exec = /^\S{1,5}/.exec(comment)) === null || _exec === void 0 ? void 0 : _exec[0] : null;
347
+ if (commentFromStr) {
348
+ const fromStr = commentFromStr;
349
+ fromLrudComment = ' '.repeat(5 - fromStr.length) + fromLrudComment;
350
+ const gap = fromLrudComment.substring(5, 40);
351
+ const lrudStr = fromLrudComment.substring(40, 52);
352
+ const lStr = fromLrudComment.substring(40, 43);
353
+ const rStr = fromLrudComment.substring(43, 46);
354
+ const uStr = fromLrudComment.substring(46, 49);
355
+ const dStr = fromLrudComment.substring(49, 52);
356
+ if (/^\s*\S+$/.test(fromStr) && !gap.trim() && isValidOptFloat(lStr) && isValidOptFloat(rStr) && isValidOptFloat(uStr) && isValidOptFloat(dStr) && /\d/.test(lrudStr)) {
357
+ const up = parseLrud(uStr, distanceUnit);
358
+ const down = parseLrud(dStr, distanceUnit);
359
+ const left = parseLrud(lStr, distanceUnit);
360
+ const right = parseLrud(rStr, distanceUnit);
361
+ fromLruds = {
362
+ left,
363
+ right,
364
+ up,
365
+ down
366
+ };
367
+ comment = null;
368
+ }
369
+ }
343
370
 
344
371
  // azimuth and inclination
345
372
  const azmFsStr = validate(19, 25, 'azimuth', isValidOptUFloat);
@@ -439,7 +466,7 @@ lines) {
439
466
  down
440
467
  },
441
468
  excludeDistance,
442
- comment: getComment()
469
+ comment
443
470
  };
444
471
  if (isSplay) shot.isSplay = true;
445
472
  if (fromLruds) shot.fromLruds = fromLruds;
@@ -455,4 +482,4 @@ lines) {
455
482
  errors
456
483
  };
457
484
  }
458
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_parseSegment","require","_unitized","_FrcsShot","parseNumber","s","unit","value","parseFloat","isNaN","UnitizedNumber","parseAzimuth","parsed","get","Angle","degrees","Unitize","parseKind","kind","FrcsShotKind","Horizontal","Diagonal","Normal","parseLengthUnit","Length","inches","feet","meters","parseAngleUnit","gradians","milsNATO","isValidStation","test","isValidUInt","isValidFloat","isValidOptFloat","isValidOptUFloat","isValidUFloat","isValidOptInclination","parseLrud","Number","isFinite","parseFrcsSurveyFile","file","lines","cave","location","trips","errors","tripName","tripTeam","tripDate","inTripComment","tripCommentStartLine","tripCommentEndLine","tripComment","commentLines","trip","inBlockComment","section","getComment","comment","join","trim","lineNumber","line","errored","thisLineNumber","error","message","startColumn","endColumn","push","SegmentParseError","Segment","source","startLine","startCol","substring","validate","fieldName","validator","field","match","exec","charAt","undefined","k","team","month","parseInt","day","year","Date","split","indexOf","part","distanceUnit","slice","azimuthUnit","inclinationUnit","backsightAzimuthCorrected","backsightInclinationCorrected","hasBacksightAzimuth","hasBacksightInclination","header","name","date","shots","fromStr","lStr","rStr","uStr","dStr","up","down","left","right","toStr","shot","from","to","distance","frontsightAzimuth","backsightAzimuth","frontsightInclination","backsightInclination","fromLruds","excludeDistance","fromLrudMatch","RegExp","replace","map","azmFsStr","azmBsStr","incFsStr","incBsStr","horizontalDistance","verticalDistance","isSplay","feetStr","inchesStr","invalid","add","h","v","Math","sqrt","atan2","d","asin","toLruds"],"sources":["../src/parseFrcsSurveyFile.ts"],"sourcesContent":["import { FrcsSurveyFile } from './FrcsSurveyFile'\nimport { FrcsTrip } from './FrcsTrip'\nimport { Segment, SegmentParseError } from 'parse-segment'\nimport {\n  Angle,\n  Length,\n  Unit,\n  UnitizedNumber,\n  UnitType,\n  Unitize,\n} from '@speleotica/unitized'\nimport { FrcsShot, FrcsShotKind } from './FrcsShot'\n\nfunction parseNumber<T extends UnitType<T>>(\n  s: string,\n  unit: Unit<T>\n): UnitizedNumber<T> | null {\n  const value = parseFloat(s)\n  if (isNaN(value)) return null\n  return new UnitizedNumber(value, unit)\n}\n\nfunction parseAzimuth(\n  s: string,\n  unit: Unit<Angle>\n): UnitizedNumber<Angle> | null {\n  const parsed = parseNumber(s, unit)\n  return parsed?.get(Angle.degrees) === 360 ? Unitize.degrees(0) : parsed\n}\n\nfunction parseKind(kind: string): FrcsShotKind {\n  switch (kind) {\n    case 'H':\n      return FrcsShotKind.Horizontal\n    case 'D':\n      return FrcsShotKind.Diagonal\n    default:\n      return FrcsShotKind.Normal\n  }\n}\n\nfunction parseLengthUnit(unit: string): Unit<Length> | null {\n  switch (unit) {\n    case 'FI':\n      return Length.inches\n    case 'FF':\n    case 'FT':\n      return Length.feet\n    case 'MT':\n    case 'M ':\n      return Length.meters\n  }\n  return null\n}\nfunction parseAngleUnit(unit: string): Unit<Angle> | null {\n  switch (unit) {\n    case 'D':\n      return Angle.degrees\n    case 'G':\n      return Angle.gradians\n    case 'M':\n      return Angle.milsNATO\n  }\n  return null\n}\n\n// determines if a cell contains a valid station name.\nfunction isValidStation(s: string): boolean {\n  return /^\\s*\\S+\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned integer.\nfunction isValidUInt(s: string): boolean {\n  return /^\\s*[0-9]+\\s*$/.test(s)\n}\n// determines if a cell contains a valid float.\nfunction isValidFloat(s: string): boolean {\n  return /^\\s*[-+]?([0-9]+(\\.[0-9]*)?|\\.[0-9]+)\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned float or whitespace.\nfunction isValidOptFloat(s: string): boolean {\n  return /^\\s*[-+]?[0-9]*(\\.[0-9]*)?\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned float or whitespace.\nfunction isValidOptUFloat(s: string): boolean {\n  return /^\\s*[0-9]*(\\.[0-9]*)?\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned float.\nfunction isValidUFloat(s: string): boolean {\n  return /^\\s*([0-9]+(\\.[0-9]*)?|\\.[0-9]+)\\s*$/.test(s)\n}\n// determines if a cell contains a valid inclination or whitespace.\nfunction isValidOptInclination(s: string): boolean {\n  return /^\\s*[-+]?[0-9]*(\\.[0-9]*)?\\s*$/.test(s)\n}\nfunction parseLrud<T extends UnitType<T>>(\n  s: string,\n  unit: Unit<Length>\n): UnitizedNumber<Length> | null {\n  const value = parseFloat(s)\n  return !Number.isFinite(value) || value < 0\n    ? null\n    : new UnitizedNumber(value, unit)\n}\n\n/**\n * Parses a raw cdata.fr survey file.  These look like so:\n *\n<pre>      Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE\nPETER QUICK, KEITH ORTIZ   -  2-15-81\nThis File has Crumps test connected.  11/20/12\n *\nFT C  DD    A\n      AE20     0                          1  3  0  2\n*      %FS\n*     AE20     0        0        0        Bug-can't put before so put after-so can't make 2 fixed 10/28/12\n AE19 AE20   9.3    60.0  60.0-36.0       2 12  0 20\n AE18 AE19  24.5     0.0   0.0-90.0       6 10 25  0\n AE17 AE18   8.0   350.5 350.5 17.0       3  5  0  0\n AE16 AE17   6.7     0.0   0.0-90.0       3  5  6  1\n AE15 AE16  12.6    70.5  71.0-18.0       4  0  2  1\n AE14 AE15  10.0    21.5  20.0  6.0       5  5  0  3\n AE13 AE14  26.8   288.0 286.0-50.0       0  7 20  5\n*\n*SHORT CANYON AT THE BASE OF THE SECOND DROP\n AE12 AE13  20.7   236.0 236.0 34.0       3  5  4  4\n AE11 AE12  12.4   210.0 210.0 35.0       7  4  5  1\n AE10 AE13  25.7    40.0  40.0 -9.0       2  2  3  6\n*\n*AE10 AT JOE'S \" I LOVE MY WIFE TRAVERSE \"\n  AE9 AE10  17.8    32.5  31.0 23.0       4  5 20 15\n  AE1  AE9  13.7    82.0  82.0-13.0\n   A1  AE1  34.3    46.0  48.0-17.5\n*\n*SURVEY TO DOME NEAR THE ENTRANCE DOME (ABOVE THE SECOND DROP)\n  AD1 AE15   8.0   200.0 200.0  0.0       3  1  1  1\n  AD2  AD1  17.7   161.0 161.0  7.0       1  4 25  1\n  AD3  AD2  10.4   180.0 180.0 50.0       4  1 15  5\n *\nTRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY\nDAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN    14 FEB 1981\n *\nFI B  DD\n   A2   A1  48 10  292.0 110.0-42.0       5 10 35  5\n   A3   A2  12  5  333.5 153.5 35.0       3  1 15  5\n   A4   A3   4  2    0.0   0.0 90.0       3  1 10 10\n...</pre>\n *\n */\nexport default async function parseFrcsSurveyFile(\n  file: any, // eslint-disable-line @typescript-eslint/no-explicit-any\n  lines: AsyncIterable<string>\n): Promise<FrcsSurveyFile> {\n  let cave: string | null = null\n  let location: string | null = null\n  const trips: Array<FrcsTrip> = []\n  const errors: Array<SegmentParseError> = []\n\n  let tripName\n  let tripTeam\n  let tripDate\n  let inTripComment = true\n  let tripCommentStartLine = 1\n  let tripCommentEndLine = -1\n  let tripComment: Array<string> = []\n  let commentLines: Array<string> | null = null\n  let trip: FrcsTrip | null = null\n  let inBlockComment = false\n  let section\n\n  function getComment(): string | null {\n    if (!commentLines) return null\n    const comment = commentLines.join('\\n').trim()\n    commentLines = null\n    return comment || null\n  }\n\n  let lineNumber = 0\n\n  for await (const line of lines) {\n    let errored = false\n\n    const thisLineNumber = lineNumber\n\n    const error = (\n      message: string,\n      startColumn: number,\n      endColumn: number\n    ): void => {\n      errored = true\n      errors.push(\n        new SegmentParseError(\n          message,\n          new Segment({\n            value: line,\n            source: file,\n            startLine: thisLineNumber,\n            startCol: 0,\n          }).substring(startColumn, endColumn)\n        )\n      )\n    }\n\n    const validate = (\n      startColumn: number,\n      endColumn: number,\n      fieldName: string,\n      validator: (value: string) => boolean\n    ): string => {\n      const field = line.substring(startColumn, endColumn)\n      if (!validator(field)) {\n        error(\n          (field.trim() ? 'Invalid ' : 'Missing ') + fieldName,\n          startColumn,\n          endColumn\n        )\n      }\n      return field\n    }\n\n    lineNumber++\n\n    if (lineNumber === 1) {\n      const match = /^\\s*([^,]+)(,(.*))?/.exec(line)\n      if (match) {\n        cave = match[1].trim()\n        if (match[3]) {\n          location = match[3].trim()\n        }\n      }\n    }\n\n    if (line.charAt(0) === ' ' && line.charAt(1) === '*') {\n      inTripComment = !inTripComment\n      if (inTripComment) {\n        section = undefined\n        tripComment = []\n        tripCommentStartLine = lineNumber\n      } else {\n        tripCommentEndLine = lineNumber\n      }\n    } else if (inTripComment) {\n      if (lineNumber === tripCommentStartLine + 1) {\n        tripName = line && line.trim()\n      } else if (lineNumber === tripCommentStartLine + 2) {\n        const match = /^(.+?)\\s*[-.]\\s*(\\d+)\\/(\\d+)\\/(\\d+)$/.exec(\n          line && line.trim()\n        )\n        if (match) {\n          let k = 1\n          const team = match[k++]\n          const month = parseInt(match[k++])\n          const day = parseInt(match[k++])\n          const year = parseInt(match[k++])\n          tripDate = new Date(year < 70 ? year + 2000 : year, month - 1, day)\n          tripTeam = team.split(\n            team.indexOf(';') >= 0 ? /\\s*;\\s*/g : /\\s*,\\s*/g\n          )\n        }\n      } else if (lineNumber > 1) {\n        tripComment.push(line)\n      }\n      const match = /^\\*\\*\\*([^*])\\*\\*\\*/.exec(line)\n      if (match) {\n        section = match[1].trim()\n      }\n    } else if (line.charAt(0) === '*') {\n      inBlockComment = !inBlockComment\n      if (inBlockComment) commentLines = []\n      else if (commentLines) {\n        const part = line.substring(1).trim()\n        if (part && commentLines) commentLines.push(part)\n      }\n    } else if (inBlockComment) {\n      if (commentLines) commentLines.push(line)\n    } else if (lineNumber === tripCommentEndLine + 1) {\n      // FT CC DD\n      // 01234567\n      let distanceUnit = parseLengthUnit(line.slice(0, 2))\n      if (!distanceUnit) {\n        distanceUnit = Length.feet\n        error('Invalid distance unit', 0, 2)\n      }\n      let azimuthUnit = parseAngleUnit(line[6])\n      if (!azimuthUnit) {\n        azimuthUnit = Angle.degrees\n        error('Invalid azimuth unit', 6, 7)\n      }\n      let inclinationUnit = parseAngleUnit(line[7])\n      if (!inclinationUnit) {\n        inclinationUnit = Angle.degrees\n        error('Invalid inclination unit', 7, 8)\n      }\n      const backsightAzimuthCorrected = line[3] === 'C'\n      const backsightInclinationCorrected = line[4] === 'C'\n      const hasBacksightAzimuth = line[3] !== ' ' && line[3] !== '-'\n      const hasBacksightInclination = line[4] !== ' ' && line[4] !== '-'\n\n      if (!/[-CB ]/.test(line[3])) {\n        error('Invalid backsight azimuth type', 3, 4)\n      }\n      if (!/[-CB ]/.test(line[4])) {\n        error('Invalid backsight inclination type', 4, 5)\n      }\n\n      trip = {\n        header: {\n          name: tripName || '',\n          comment: (tripComment && tripComment.join('\\n')) || null,\n          section,\n          date: tripDate,\n          team: tripTeam,\n          distanceUnit,\n          azimuthUnit,\n          inclinationUnit,\n          backsightAzimuthCorrected,\n          backsightInclinationCorrected,\n          hasBacksightAzimuth,\n          hasBacksightInclination,\n        },\n        shots: [],\n      }\n      trips.push(trip)\n    } else if (trip) {\n      const {\n        shots,\n        header: { azimuthUnit, inclinationUnit },\n      } = trip\n      let { distanceUnit } = trip.header\n\n      const inches = distanceUnit === Length.inches\n      if (inches) distanceUnit = Length.feet\n\n      // rigorously check the values in all the columns to make sure this\n      // is really a survey shot line, just in case any stray comments are\n      // not properly delimited.\n\n      // from station name\n      if (!/\\S/.test(line.substring(5, 10))) continue\n      const fromStr = validate(5, 10, 'from station', isValidStation)\n\n      // Sadly I have found negative LRUD values in Chip's format and apparently\n      // his program doesn't fail on them, so I have to accept them here\n      // isValidOptFloat instead of isValidOptUFloat\n      const lStr = validate(40, 43, 'left', isValidOptFloat)\n      const rStr = validate(43, 46, 'right', isValidOptFloat)\n      const uStr = validate(46, 49, 'up', isValidOptFloat)\n      const dStr = validate(49, 52, 'down', isValidOptFloat)\n\n      if (errored) continue\n\n      const up = parseLrud(uStr, distanceUnit)\n      const down = parseLrud(dStr, distanceUnit)\n      const left = parseLrud(lStr, distanceUnit)\n      const right = parseLrud(rStr, distanceUnit)\n\n      // to station name\n      const toStr = line.substring(0, 5)\n      if (!toStr.trim()) {\n        const shot: FrcsShot = {\n          from: fromStr.trim(),\n          to: null,\n          kind: FrcsShotKind.Normal,\n          distance: new UnitizedNumber(0, distanceUnit),\n          frontsightAzimuth: null,\n          backsightAzimuth: null,\n          frontsightInclination: null,\n          backsightInclination: null,\n          fromLruds: {\n            left,\n            right,\n            up,\n            down,\n          },\n          excludeDistance: true,\n          comment: getComment(),\n        }\n        shots.push(shot)\n        continue\n      }\n      if (!isValidStation(toStr)) {\n        error('Invalid station name', 0, 5)\n      }\n\n      const fromLrudMatch = new RegExp(\n        `^\\\\s+${fromStr\n          .trim()\n          .replace(\n            /[.*+?^${}()|[\\]\\\\]/g,\n            '\\\\$&'\n          )}((\\\\s+(\\\\d+(\\\\.\\\\d*)?|\\\\.\\\\d+)){4})`\n      ).exec(line.substring(52))\n      let fromLruds\n      if (fromLrudMatch) {\n        const [left, right, up, down] = fromLrudMatch[1]\n          .trim()\n          .split(/\\s+/g)\n          .map(s => parseLrud(s, distanceUnit))\n        fromLruds = { left, right, up, down }\n      }\n\n      // azimuth and inclination\n      const azmFsStr = validate(19, 25, 'azimuth', isValidOptUFloat)\n      const azmBsStr = validate(25, 30, 'azimuth', isValidOptUFloat)\n      const incFsStr = line.substring(30, 35)\n      const incBsStr = line.substring(35, 40)\n\n      if (errored) continue\n\n      let kind: FrcsShotKind\n      let distance: UnitizedNumber<Length>\n      let horizontalDistance: UnitizedNumber<Length> | undefined\n      let verticalDistance: UnitizedNumber<Length> | undefined\n      let frontsightInclination: UnitizedNumber<Angle> | null\n      let backsightInclination: UnitizedNumber<Angle> | null\n      let excludeDistance: boolean\n      let isSplay: boolean\n\n      // parse distance\n      if (inches) {\n        const feetStr = line.substring(10, 14)\n        const inchesStr = line.substring(14, 17)\n        // feet and inches are not both optional\n        if (!isValidUInt(feetStr) && !isValidUInt(inchesStr)) {\n          const invalid = feetStr.trim() || inchesStr.trim()\n          error(invalid ? 'Invalid distance' : 'Missing distance', 10, 17)\n          continue\n        }\n\n        // sometimes inches are omitted, hence the || 0...I'm assuming it's possible\n        // for feet to be omitted as well\n        distance = Unitize.inches(parseFloat(inchesStr) || 0).add(\n          Unitize.feet(parseFloat(feetStr) || 0)\n        )\n\n        kind = parseKind(line[17])\n        // NOTE there are two columns around here that can contain a *.\n        // I think they might represent different values, but thisis confused by\n        // the fact that for ft/in shots, if there is a D or H flag it occupies the\n        // first column that can contain a * for decimal feet shots\n        excludeDistance = line[18] === '*' || line[18] === 's'\n        isSplay = line[18] === 's'\n      } else {\n        // decimal feet are not optional\n        const feetStr = validate(10, 16, 'distance', isValidUFloat)\n        distance = new UnitizedNumber(parseFloat(feetStr), distanceUnit)\n        kind = parseKind(line[16])\n        excludeDistance = line[17] === '*' || line[17] === 's'\n        isSplay = line[17] === 's'\n      }\n\n      if (kind !== FrcsShotKind.Normal) {\n        validate(30, 35, 'vertical-distance', isValidFloat)\n      }\n\n      // convert horizontal and diagonal shots to standard\n      // in this case incFs is the vertical offset between stations\n      // fortunately it appears we can always count on incFs being specified\n      // and incBs not being specified for these types of shots\n      if (kind === FrcsShotKind.Horizontal) {\n        // distance is horizontal offset and incFsStr is vertical offset\n        horizontalDistance = distance\n        const h = horizontalDistance.get(distanceUnit)\n        const v = parseFloat(incFsStr)\n        verticalDistance = new UnitizedNumber(v, distanceUnit)\n        distance = new UnitizedNumber(Math.sqrt(h * h + v * v), distanceUnit)\n        frontsightInclination = Angle.atan2(\n          verticalDistance,\n          horizontalDistance\n        )\n        backsightInclination = null\n      } else if (kind === FrcsShotKind.Diagonal) {\n        // distance is as usual, but incFsStr is vertical offset\n        const d = distance.get(distanceUnit)\n        const v = parseFloat(incFsStr)\n        verticalDistance = new UnitizedNumber(v, distanceUnit)\n        frontsightInclination = Angle.asin(v / d)\n        backsightInclination = null\n      } else {\n        // frontsight inclination\n        validate(30, 35, 'inclination', isValidOptInclination)\n        // frontsight inclination\n        validate(35, 40, 'inclination', isValidOptInclination)\n        frontsightInclination = parseNumber(incFsStr, inclinationUnit)\n        backsightInclination = parseNumber(incBsStr, inclinationUnit)\n      }\n      if (errored) continue\n\n      const frontsightAzimuth = parseAzimuth(azmFsStr, azimuthUnit)\n      const backsightAzimuth = parseAzimuth(azmBsStr, azimuthUnit)\n\n      if (!frontsightInclination && !backsightInclination) {\n        frontsightInclination = Unitize.degrees(0)\n      }\n\n      const shot: FrcsShot = {\n        from: fromStr.trim(),\n        to: toStr.trim(),\n        kind,\n        distance,\n        frontsightAzimuth,\n        backsightAzimuth,\n        frontsightInclination,\n        backsightInclination,\n        toLruds: {\n          left,\n          right,\n          up,\n          down,\n        },\n        excludeDistance,\n        comment: getComment(),\n      }\n      if (isSplay) shot.isSplay = true\n      if (fromLruds) shot.fromLruds = fromLruds\n      if (horizontalDistance) shot.horizontalDistance = horizontalDistance\n      if (verticalDistance) shot.verticalDistance = verticalDistance\n      shots.push(shot)\n    }\n  }\n\n  return {\n    cave,\n    location,\n    trips,\n    errors,\n  }\n}\n"],"mappings":"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"}
485
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_parseSegment","require","_unitized","_FrcsShot","parseNumber","s","unit","value","parseFloat","isNaN","UnitizedNumber","parseAzimuth","parsed","get","Angle","degrees","Unitize","parseKind","kind","FrcsShotKind","Horizontal","Diagonal","Normal","parseLengthUnit","Length","inches","feet","meters","parseAngleUnit","gradians","milsNATO","isValidStation","test","isValidUInt","isValidFloat","isValidOptFloat","isValidOptUFloat","isValidUFloat","isValidOptInclination","parseLrud","Number","isFinite","parseFrcsSurveyFile","file","lines","cave","location","trips","errors","tripName","tripTeam","tripDate","inTripComment","tripCommentStartLine","tripCommentEndLine","tripComment","commentLines","trip","inBlockComment","section","getComment","comment","join","trim","lineNumber","line","errored","thisLineNumber","error","message","startColumn","endColumn","push","SegmentParseError","Segment","source","startLine","startCol","substring","validate","fieldName","validator","field","match","exec","charAt","undefined","k","team","month","parseInt","day","year","Date","split","indexOf","part","distanceUnit","slice","azimuthUnit","inclinationUnit","backsightAzimuthCorrected","backsightInclinationCorrected","hasBacksightAzimuth","hasBacksightInclination","header","name","date","shots","_exec","fromStr","lStr","rStr","uStr","dStr","up","down","left","right","toStr","shot","from","to","distance","frontsightAzimuth","backsightAzimuth","frontsightInclination","backsightInclination","fromLruds","excludeDistance","fromLrudMatch","RegExp","replace","map","fromLrudComment","commentFromStr","repeat","length","gap","lrudStr","azmFsStr","azmBsStr","incFsStr","incBsStr","horizontalDistance","verticalDistance","isSplay","feetStr","inchesStr","invalid","add","h","v","Math","sqrt","atan2","d","asin","toLruds"],"sources":["../src/parseFrcsSurveyFile.ts"],"sourcesContent":["import { FrcsSurveyFile } from './FrcsSurveyFile'\nimport { FrcsTrip } from './FrcsTrip'\nimport { Segment, SegmentParseError } from 'parse-segment'\nimport {\n  Angle,\n  Length,\n  Unit,\n  UnitizedNumber,\n  UnitType,\n  Unitize,\n} from '@speleotica/unitized'\nimport { FrcsShot, FrcsShotKind } from './FrcsShot'\n\nfunction parseNumber<T extends UnitType<T>>(\n  s: string,\n  unit: Unit<T>\n): UnitizedNumber<T> | null {\n  const value = parseFloat(s)\n  if (isNaN(value)) return null\n  return new UnitizedNumber(value, unit)\n}\n\nfunction parseAzimuth(\n  s: string,\n  unit: Unit<Angle>\n): UnitizedNumber<Angle> | null {\n  const parsed = parseNumber(s, unit)\n  return parsed?.get(Angle.degrees) === 360 ? Unitize.degrees(0) : parsed\n}\n\nfunction parseKind(kind: string): FrcsShotKind {\n  switch (kind) {\n    case 'H':\n      return FrcsShotKind.Horizontal\n    case 'D':\n      return FrcsShotKind.Diagonal\n    default:\n      return FrcsShotKind.Normal\n  }\n}\n\nfunction parseLengthUnit(unit: string): Unit<Length> | null {\n  switch (unit) {\n    case 'FI':\n      return Length.inches\n    case 'FF':\n    case 'FT':\n      return Length.feet\n    case 'MT':\n    case 'M ':\n      return Length.meters\n  }\n  return null\n}\nfunction parseAngleUnit(unit: string): Unit<Angle> | null {\n  switch (unit) {\n    case 'D':\n      return Angle.degrees\n    case 'G':\n      return Angle.gradians\n    case 'M':\n      return Angle.milsNATO\n  }\n  return null\n}\n\n// determines if a cell contains a valid station name.\nfunction isValidStation(s: string): boolean {\n  return /^\\s*\\S+\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned integer.\nfunction isValidUInt(s: string): boolean {\n  return /^\\s*[0-9]+\\s*$/.test(s)\n}\n// determines if a cell contains a valid float.\nfunction isValidFloat(s: string): boolean {\n  return /^\\s*[-+]?([0-9]+(\\.[0-9]*)?|\\.[0-9]+)\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned float or whitespace.\nfunction isValidOptFloat(s: string): boolean {\n  return /^\\s*[-+]?[0-9]*(\\.[0-9]*)?\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned float or whitespace.\nfunction isValidOptUFloat(s: string): boolean {\n  return /^\\s*[0-9]*(\\.[0-9]*)?\\s*$/.test(s)\n}\n// determines if a cell contains a valid unsigned float.\nfunction isValidUFloat(s: string): boolean {\n  return /^\\s*([0-9]+(\\.[0-9]*)?|\\.[0-9]+)\\s*$/.test(s)\n}\n// determines if a cell contains a valid inclination or whitespace.\nfunction isValidOptInclination(s: string): boolean {\n  return /^\\s*[-+]?[0-9]*(\\.[0-9]*)?\\s*$/.test(s)\n}\nfunction parseLrud<T extends UnitType<T>>(\n  s: string,\n  unit: Unit<Length>\n): UnitizedNumber<Length> | null {\n  const value = parseFloat(s)\n  return !Number.isFinite(value) || value < 0\n    ? null\n    : new UnitizedNumber(value, unit)\n}\n\n/**\n * Parses a raw cdata.fr survey file.  These look like so:\n *\n<pre>      Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE\nPETER QUICK, KEITH ORTIZ   -  2-15-81\nThis File has Crumps test connected.  11/20/12\n *\nFT C  DD    A\n      AE20     0                          1  3  0  2\n*      %FS\n*     AE20     0        0        0        Bug-can't put before so put after-so can't make 2 fixed 10/28/12\n AE19 AE20   9.3    60.0  60.0-36.0       2 12  0 20\n AE18 AE19  24.5     0.0   0.0-90.0       6 10 25  0\n AE17 AE18   8.0   350.5 350.5 17.0       3  5  0  0\n AE16 AE17   6.7     0.0   0.0-90.0       3  5  6  1\n AE15 AE16  12.6    70.5  71.0-18.0       4  0  2  1\n AE14 AE15  10.0    21.5  20.0  6.0       5  5  0  3\n AE13 AE14  26.8   288.0 286.0-50.0       0  7 20  5\n*\n*SHORT CANYON AT THE BASE OF THE SECOND DROP\n AE12 AE13  20.7   236.0 236.0 34.0       3  5  4  4\n AE11 AE12  12.4   210.0 210.0 35.0       7  4  5  1\n AE10 AE13  25.7    40.0  40.0 -9.0       2  2  3  6\n*\n*AE10 AT JOE'S \" I LOVE MY WIFE TRAVERSE \"\n  AE9 AE10  17.8    32.5  31.0 23.0       4  5 20 15\n  AE1  AE9  13.7    82.0  82.0-13.0\n   A1  AE1  34.3    46.0  48.0-17.5\n*\n*SURVEY TO DOME NEAR THE ENTRANCE DOME (ABOVE THE SECOND DROP)\n  AD1 AE15   8.0   200.0 200.0  0.0       3  1  1  1\n  AD2  AD1  17.7   161.0 161.0  7.0       1  4 25  1\n  AD3  AD2  10.4   180.0 180.0 50.0       4  1 15  5\n *\nTRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY\nDAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN    14 FEB 1981\n *\nFI B  DD\n   A2   A1  48 10  292.0 110.0-42.0       5 10 35  5\n   A3   A2  12  5  333.5 153.5 35.0       3  1 15  5\n   A4   A3   4  2    0.0   0.0 90.0       3  1 10 10\n...</pre>\n *\n */\nexport default async function parseFrcsSurveyFile(\n  file: any, // eslint-disable-line @typescript-eslint/no-explicit-any\n  lines: AsyncIterable<string>\n): Promise<FrcsSurveyFile> {\n  let cave: string | null = null\n  let location: string | null = null\n  const trips: Array<FrcsTrip> = []\n  const errors: Array<SegmentParseError> = []\n\n  let tripName\n  let tripTeam\n  let tripDate\n  let inTripComment = true\n  let tripCommentStartLine = 1\n  let tripCommentEndLine = -1\n  let tripComment: Array<string> = []\n  let commentLines: Array<string> | null = null\n  let trip: FrcsTrip | null = null\n  let inBlockComment = false\n  let section\n\n  function getComment(): string | null {\n    if (!commentLines) return null\n    const comment = commentLines.join('\\n').trim()\n    commentLines = null\n    return comment || null\n  }\n\n  let lineNumber = 0\n\n  for await (const line of lines) {\n    let errored = false\n\n    const thisLineNumber = lineNumber\n\n    const error = (\n      message: string,\n      startColumn: number,\n      endColumn: number\n    ): void => {\n      errored = true\n      errors.push(\n        new SegmentParseError(\n          message,\n          new Segment({\n            value: line,\n            source: file,\n            startLine: thisLineNumber,\n            startCol: 0,\n          }).substring(startColumn, endColumn)\n        )\n      )\n    }\n\n    const validate = (\n      startColumn: number,\n      endColumn: number,\n      fieldName: string,\n      validator: (value: string) => boolean\n    ): string => {\n      const field = line.substring(startColumn, endColumn)\n      if (!validator(field)) {\n        error(\n          (field.trim() ? 'Invalid ' : 'Missing ') + fieldName,\n          startColumn,\n          endColumn\n        )\n      }\n      return field\n    }\n\n    lineNumber++\n\n    if (lineNumber === 1) {\n      const match = /^\\s*([^,]+)(,(.*))?/.exec(line)\n      if (match) {\n        cave = match[1].trim()\n        if (match[3]) {\n          location = match[3].trim()\n        }\n      }\n    }\n\n    if (line.charAt(0) === ' ' && line.charAt(1) === '*') {\n      inTripComment = !inTripComment\n      if (inTripComment) {\n        section = undefined\n        tripComment = []\n        tripCommentStartLine = lineNumber\n      } else {\n        tripCommentEndLine = lineNumber\n      }\n    } else if (inTripComment) {\n      if (lineNumber === tripCommentStartLine + 1) {\n        tripName = line && line.trim()\n      } else if (lineNumber === tripCommentStartLine + 2) {\n        const match = /^(.+?)\\s*[-.]\\s*(\\d+)\\/(\\d+)\\/(\\d+)$/.exec(\n          line && line.trim()\n        )\n        if (match) {\n          let k = 1\n          const team = match[k++]\n          const month = parseInt(match[k++])\n          const day = parseInt(match[k++])\n          const year = parseInt(match[k++])\n          tripDate = new Date(year < 70 ? year + 2000 : year, month - 1, day)\n          tripTeam = team.split(\n            team.indexOf(';') >= 0 ? /\\s*;\\s*/g : /\\s*,\\s*/g\n          )\n        }\n      } else if (lineNumber > 1) {\n        tripComment.push(line)\n      }\n      const match = /^\\*\\*\\*([^*])\\*\\*\\*/.exec(line)\n      if (match) {\n        section = match[1].trim()\n      }\n    } else if (line.charAt(0) === '*') {\n      inBlockComment = !inBlockComment\n      if (inBlockComment) commentLines = []\n      else if (commentLines) {\n        const part = line.substring(1).trim()\n        if (part && commentLines) commentLines.push(part)\n      }\n    } else if (inBlockComment) {\n      if (commentLines) commentLines.push(line)\n    } else if (lineNumber === tripCommentEndLine + 1) {\n      // FT CC DD\n      // 01234567\n      let distanceUnit = parseLengthUnit(line.slice(0, 2))\n      if (!distanceUnit) {\n        distanceUnit = Length.feet\n        error('Invalid distance unit', 0, 2)\n      }\n      let azimuthUnit = parseAngleUnit(line[6])\n      if (!azimuthUnit) {\n        azimuthUnit = Angle.degrees\n        error('Invalid azimuth unit', 6, 7)\n      }\n      let inclinationUnit = parseAngleUnit(line[7])\n      if (!inclinationUnit) {\n        inclinationUnit = Angle.degrees\n        error('Invalid inclination unit', 7, 8)\n      }\n      const backsightAzimuthCorrected = line[3] === 'C'\n      const backsightInclinationCorrected = line[4] === 'C'\n      const hasBacksightAzimuth = line[3] !== ' ' && line[3] !== '-'\n      const hasBacksightInclination = line[4] !== ' ' && line[4] !== '-'\n\n      if (!/[-CB ]/.test(line[3])) {\n        error('Invalid backsight azimuth type', 3, 4)\n      }\n      if (!/[-CB ]/.test(line[4])) {\n        error('Invalid backsight inclination type', 4, 5)\n      }\n\n      trip = {\n        header: {\n          name: tripName || '',\n          comment: (tripComment && tripComment.join('\\n')) || null,\n          section,\n          date: tripDate,\n          team: tripTeam,\n          distanceUnit,\n          azimuthUnit,\n          inclinationUnit,\n          backsightAzimuthCorrected,\n          backsightInclinationCorrected,\n          hasBacksightAzimuth,\n          hasBacksightInclination,\n        },\n        shots: [],\n      }\n      trips.push(trip)\n    } else if (trip) {\n      const {\n        shots,\n        header: { azimuthUnit, inclinationUnit },\n      } = trip\n      let { distanceUnit } = trip.header\n\n      const inches = distanceUnit === Length.inches\n      if (inches) distanceUnit = Length.feet\n\n      // rigorously check the values in all the columns to make sure this\n      // is really a survey shot line, just in case any stray comments are\n      // not properly delimited.\n\n      // from station name\n      if (!/\\S/.test(line.substring(5, 10))) continue\n      const fromStr = validate(5, 10, 'from station', isValidStation)\n\n      // Sadly I have found negative LRUD values in Chip's format and apparently\n      // his program doesn't fail on them, so I have to accept them here\n      // isValidOptFloat instead of isValidOptUFloat\n      const lStr = validate(40, 43, 'left', isValidOptFloat)\n      const rStr = validate(43, 46, 'right', isValidOptFloat)\n      const uStr = validate(46, 49, 'up', isValidOptFloat)\n      const dStr = validate(49, 52, 'down', isValidOptFloat)\n\n      if (errored) continue\n\n      const up = parseLrud(uStr, distanceUnit)\n      const down = parseLrud(dStr, distanceUnit)\n      const left = parseLrud(lStr, distanceUnit)\n      const right = parseLrud(rStr, distanceUnit)\n\n      // to station name\n      const toStr = line.substring(0, 5)\n      if (!toStr.trim()) {\n        const shot: FrcsShot = {\n          from: fromStr.trim(),\n          to: null,\n          kind: FrcsShotKind.Normal,\n          distance: new UnitizedNumber(0, distanceUnit),\n          frontsightAzimuth: null,\n          backsightAzimuth: null,\n          frontsightInclination: null,\n          backsightInclination: null,\n          fromLruds: {\n            left,\n            right,\n            up,\n            down,\n          },\n          excludeDistance: true,\n          comment: getComment(),\n        }\n        shots.push(shot)\n        continue\n      }\n      if (!isValidStation(toStr)) {\n        error('Invalid station name', 0, 5)\n      }\n\n      const fromLrudMatch = new RegExp(\n        `^\\\\s+${fromStr\n          .trim()\n          .replace(\n            /[.*+?^${}()|[\\]\\\\]/g,\n            '\\\\$&'\n          )}((\\\\s+(\\\\d+(\\\\.\\\\d*)?|\\\\.\\\\d+)){4})`\n      ).exec(line.substring(52))\n      let fromLruds\n      if (fromLrudMatch) {\n        const [left, right, up, down] = fromLrudMatch[1]\n          .trim()\n          .split(/\\s+/g)\n          .map(s => parseLrud(s, distanceUnit))\n        fromLruds = { left, right, up, down }\n      }\n\n      let comment = getComment()\n      let fromLrudComment = comment\n      const commentFromStr = comment ? /^\\S{1,5}/.exec(comment)?.[0] : null\n      if (commentFromStr) {\n        const fromStr = commentFromStr\n        fromLrudComment = ' '.repeat(5 - fromStr.length) + fromLrudComment\n        const gap = fromLrudComment.substring(5, 40)\n        const lrudStr = fromLrudComment.substring(40, 52)\n        const lStr = fromLrudComment.substring(40, 43)\n        const rStr = fromLrudComment.substring(43, 46)\n        const uStr = fromLrudComment.substring(46, 49)\n        const dStr = fromLrudComment.substring(49, 52)\n        if (\n          /^\\s*\\S+$/.test(fromStr) &&\n          !gap.trim() &&\n          isValidOptFloat(lStr) &&\n          isValidOptFloat(rStr) &&\n          isValidOptFloat(uStr) &&\n          isValidOptFloat(dStr) &&\n          /\\d/.test(lrudStr)\n        ) {\n          const up = parseLrud(uStr, distanceUnit)\n          const down = parseLrud(dStr, distanceUnit)\n          const left = parseLrud(lStr, distanceUnit)\n          const right = parseLrud(rStr, distanceUnit)\n          fromLruds = { left, right, up, down }\n          comment = null\n        }\n      }\n\n      // azimuth and inclination\n      const azmFsStr = validate(19, 25, 'azimuth', isValidOptUFloat)\n      const azmBsStr = validate(25, 30, 'azimuth', isValidOptUFloat)\n      const incFsStr = line.substring(30, 35)\n      const incBsStr = line.substring(35, 40)\n\n      if (errored) continue\n\n      let kind: FrcsShotKind\n      let distance: UnitizedNumber<Length>\n      let horizontalDistance: UnitizedNumber<Length> | undefined\n      let verticalDistance: UnitizedNumber<Length> | undefined\n      let frontsightInclination: UnitizedNumber<Angle> | null\n      let backsightInclination: UnitizedNumber<Angle> | null\n      let excludeDistance: boolean\n      let isSplay: boolean\n\n      // parse distance\n      if (inches) {\n        const feetStr = line.substring(10, 14)\n        const inchesStr = line.substring(14, 17)\n        // feet and inches are not both optional\n        if (!isValidUInt(feetStr) && !isValidUInt(inchesStr)) {\n          const invalid = feetStr.trim() || inchesStr.trim()\n          error(invalid ? 'Invalid distance' : 'Missing distance', 10, 17)\n          continue\n        }\n\n        // sometimes inches are omitted, hence the || 0...I'm assuming it's possible\n        // for feet to be omitted as well\n        distance = Unitize.inches(parseFloat(inchesStr) || 0).add(\n          Unitize.feet(parseFloat(feetStr) || 0)\n        )\n\n        kind = parseKind(line[17])\n        // NOTE there are two columns around here that can contain a *.\n        // I think they might represent different values, but thisis confused by\n        // the fact that for ft/in shots, if there is a D or H flag it occupies the\n        // first column that can contain a * for decimal feet shots\n        excludeDistance = line[18] === '*' || line[18] === 's'\n        isSplay = line[18] === 's'\n      } else {\n        // decimal feet are not optional\n        const feetStr = validate(10, 16, 'distance', isValidUFloat)\n        distance = new UnitizedNumber(parseFloat(feetStr), distanceUnit)\n        kind = parseKind(line[16])\n        excludeDistance = line[17] === '*' || line[17] === 's'\n        isSplay = line[17] === 's'\n      }\n\n      if (kind !== FrcsShotKind.Normal) {\n        validate(30, 35, 'vertical-distance', isValidFloat)\n      }\n\n      // convert horizontal and diagonal shots to standard\n      // in this case incFs is the vertical offset between stations\n      // fortunately it appears we can always count on incFs being specified\n      // and incBs not being specified for these types of shots\n      if (kind === FrcsShotKind.Horizontal) {\n        // distance is horizontal offset and incFsStr is vertical offset\n        horizontalDistance = distance\n        const h = horizontalDistance.get(distanceUnit)\n        const v = parseFloat(incFsStr)\n        verticalDistance = new UnitizedNumber(v, distanceUnit)\n        distance = new UnitizedNumber(Math.sqrt(h * h + v * v), distanceUnit)\n        frontsightInclination = Angle.atan2(\n          verticalDistance,\n          horizontalDistance\n        )\n        backsightInclination = null\n      } else if (kind === FrcsShotKind.Diagonal) {\n        // distance is as usual, but incFsStr is vertical offset\n        const d = distance.get(distanceUnit)\n        const v = parseFloat(incFsStr)\n        verticalDistance = new UnitizedNumber(v, distanceUnit)\n        frontsightInclination = Angle.asin(v / d)\n        backsightInclination = null\n      } else {\n        // frontsight inclination\n        validate(30, 35, 'inclination', isValidOptInclination)\n        // frontsight inclination\n        validate(35, 40, 'inclination', isValidOptInclination)\n        frontsightInclination = parseNumber(incFsStr, inclinationUnit)\n        backsightInclination = parseNumber(incBsStr, inclinationUnit)\n      }\n      if (errored) continue\n\n      const frontsightAzimuth = parseAzimuth(azmFsStr, azimuthUnit)\n      const backsightAzimuth = parseAzimuth(azmBsStr, azimuthUnit)\n\n      if (!frontsightInclination && !backsightInclination) {\n        frontsightInclination = Unitize.degrees(0)\n      }\n\n      const shot: FrcsShot = {\n        from: fromStr.trim(),\n        to: toStr.trim(),\n        kind,\n        distance,\n        frontsightAzimuth,\n        backsightAzimuth,\n        frontsightInclination,\n        backsightInclination,\n        toLruds: {\n          left,\n          right,\n          up,\n          down,\n        },\n        excludeDistance,\n        comment,\n      }\n      if (isSplay) shot.isSplay = true\n      if (fromLruds) shot.fromLruds = fromLruds\n      if (horizontalDistance) shot.horizontalDistance = horizontalDistance\n      if (verticalDistance) shot.verticalDistance = verticalDistance\n      shots.push(shot)\n    }\n  }\n\n  return {\n    cave,\n    location,\n    trips,\n    errors,\n  }\n}\n"],"mappings":"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"}
@@ -30,7 +30,9 @@ TRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY
30
30
  DAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN 14 FEB 1981
31
31
  *
32
32
  FI B DD
33
- A2 A1 48 10 292.0 110.0-42.0 5 10 35 5 A1 2 7 3 4.5
33
+ *
34
+ * A1 2 7 3 4.5
35
+ A2 A1 48 10 292.0 110.0-42.0 5 10 35 5
34
36
  A3 A2 12 5 333.5 153.5 35.0 3 1 15 5
35
37
  A4 A3 4 2 0.0 0.0 90.0 3 1 10 10
36
38
  *
@@ -38,7 +40,7 @@ DOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP
38
40
  PETER QUICK, CHRIS GERACE, PHIL ODEN, CHIP HOPPER - 3-6-81
39
41
  *
40
42
  FT C DD
41
- B31 B30 13.7 360.0 360.0 40.0 2 4 6
43
+ B31 B30 13.7 360.0 360.0 40.0 2 4 6 B30 8 3 5 1.2
42
44
  B30sp B30 13.7 s 360.0 360.0 40.0 2 4 6
43
45
  `;
44
46
  (0, _mocha.describe)('parseFrcsSurveyFile', () => {
@@ -316,6 +318,12 @@ B30sp B30 13.7 s 360.0 360.0 40.0 2 4 6
316
318
  frontsightInclination: _unitized.Unitize.degrees(40),
317
319
  kind: ' ',
318
320
  to: 'B31',
321
+ fromLruds: {
322
+ left: _unitized.Unitize.feet(8),
323
+ right: _unitized.Unitize.feet(3),
324
+ up: _unitized.Unitize.feet(5),
325
+ down: _unitized.Unitize.feet(1.2)
326
+ },
319
327
  toLruds: {
320
328
  left: _unitized.Unitize.feet(2),
321
329
  right: _unitized.Unitize.feet(4),
@@ -633,4 +641,4 @@ MT B- DD
633
641
  });
634
642
  });
635
643
  });
636
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_mocha","require","_index","_unitized","_chai","_FrcsShot","_parseSegment","data","describe","it","parsed","parseFrcsSurveyFile","expect","to","deep","equal","cave","errors","location","trips","header","name","comment","section","undefined","date","team","distanceUnit","Length","feet","azimuthUnit","Angle","degrees","inclinationUnit","backsightAzimuthCorrected","backsightInclinationCorrected","hasBacksightAzimuth","hasBacksightInclination","shots","backsightAzimuth","backsightInclination","distance","Unitize","excludeDistance","from","frontsightAzimuth","frontsightInclination","kind","FrcsShotKind","Normal","fromLruds","left","right","up","down","toLruds","inches","isSplay","Horizontal","Math","sqrt","horizontalDistance","verticalDistance","atan2","Diagonal","asin","SegmentParseError","Segment","value","source","startLine","startCol","substring","meters"],"sources":["../../src/string/parseFrcsSurveyFile.spec.ts"],"sourcesContent":["import { describe, it } from 'mocha'\nimport { parseFrcsSurveyFile } from './index'\nimport { Length, Angle, Unitize } from '@speleotica/unitized'\nimport { expect } from 'chai'\nimport { FrcsShotKind } from '../FrcsShot'\nimport { SegmentParseError, Segment } from 'parse-segment'\n\nconst data = `      Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE\nPETER QUICK, KEITH ORTIZ   -  2-15-81\nThis File has Crumps test connected.  11/20/12\n *\nFT C  DD    A\n      AE20     0                          1  3  0  2\n*      %FS\n*     AE20     0        0        0        Bug-can't put before so put after-so can't make 2 fixed 10/28/12\n AE19 AE20   9.3    60.0  60.0-36.0       2 12  0 20\n AE18 AE19  24.5     0.0   0.0-90.0       6 10 25  0\n AE17 AE18   8.0   350.5 350.5 17.0       3  5  0  0\n AE16 AE17   6.7     0.0   0.0-90.0       3  5  6  1\n AE15 AE16  12.6    70.5  71.0-18.0       4  0  2  1\n AE14 AE15  10.0    21.5  20.0  6.0       5  5  0  3\n AE13 AE14  26.8   288.0 286.0-50.0       0  7 20  5\n*\n*SHORT CANYON AT THE BASE OF THE SECOND DROP\n AE12 AE13  20.7   236.0 236.0 34.0       3  5  4  4\n *\nTRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY\nDAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN    14 FEB 1981\n *\nFI B  DD\n   A2   A1  48 10  292.0 110.0-42.0       5 10 35  5    A1 2 7 3 4.5\n   A3   A2  12  5  333.5 153.5 35.0       3  1 15  5\n   A4   A3   4  2    0.0   0.0 90.0       3  1 10 10\n *\nDOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP\nPETER QUICK, CHRIS GERACE, PHIL ODEN, CHIP HOPPER - 3-6-81\n *\nFT C  DD\n  B31  B30  13.7   360.0 360.0 40.0       2  4  6  \nB30sp  B30  13.7 s 360.0 360.0 40.0       2  4  6  \n`\n\ndescribe('parseFrcsSurveyFile', () => {\n  it('basic test', async function() {\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed).to.deep.equal({\n      cave: 'Fisher Ridge Cave System',\n      errors: [],\n      location: 'Hart Co., KY',\n      trips: [\n        {\n          header: {\n            name:\n              'ENTRANCE DROPS, JOE\\'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE',\n            comment: 'This File has Crumps test connected.  11/20/12',\n            section: undefined,\n            date: undefined,\n            team: undefined,\n            distanceUnit: Length.feet,\n            azimuthUnit: Angle.degrees,\n            inclinationUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: false,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n          },\n          shots: [\n            {\n              backsightAzimuth: null,\n              backsightInclination: null,\n              comment: null,\n              distance: Unitize.feet(0),\n              excludeDistance: true,\n              from: 'AE20',\n              frontsightAzimuth: null,\n              frontsightInclination: null,\n              kind: FrcsShotKind.Normal,\n              to: null,\n\n              fromLruds: {\n                left: Unitize.feet(1),\n                right: Unitize.feet(3),\n                up: Unitize.feet(0),\n                down: Unitize.feet(2),\n              },\n            },\n            {\n              from: 'AE20',\n              to: 'AE19',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(9.3),\n              frontsightAzimuth: Unitize.degrees(60),\n              backsightAzimuth: Unitize.degrees(60),\n              frontsightInclination: Unitize.degrees(-36),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment:\n                \"AE20     0        0        0        Bug-can't put before so put after-so can't make 2 fixed 10/28/12\",\n\n              toLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(12),\n                up: Unitize.feet(0),\n                down: Unitize.feet(20),\n              },\n            },\n            {\n              from: 'AE19',\n              to: 'AE18',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(24.5),\n              frontsightAzimuth: Unitize.degrees(0),\n              backsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(-90),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(6),\n                right: Unitize.feet(10),\n                up: Unitize.feet(25),\n                down: Unitize.feet(0),\n              },\n            },\n            {\n              from: 'AE18',\n              to: 'AE17',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(8),\n              frontsightAzimuth: Unitize.degrees(350.5),\n              backsightAzimuth: Unitize.degrees(350.5),\n              frontsightInclination: Unitize.degrees(17),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(5),\n                up: Unitize.feet(0),\n                down: Unitize.feet(0),\n              },\n            },\n            {\n              from: 'AE17',\n              to: 'AE16',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(6.7),\n              frontsightAzimuth: Unitize.degrees(0),\n              backsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(-90),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(5),\n                up: Unitize.feet(6),\n                down: Unitize.feet(1),\n              },\n            },\n            {\n              from: 'AE16',\n              to: 'AE15',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(12.6),\n              frontsightAzimuth: Unitize.degrees(70.5),\n              backsightAzimuth: Unitize.degrees(71),\n              frontsightInclination: Unitize.degrees(-18),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(4),\n                right: Unitize.feet(0),\n                up: Unitize.feet(2),\n                down: Unitize.feet(1),\n              },\n            },\n            {\n              from: 'AE15',\n              to: 'AE14',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(10),\n              frontsightAzimuth: Unitize.degrees(21.5),\n              backsightAzimuth: Unitize.degrees(20),\n              frontsightInclination: Unitize.degrees(6),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(5),\n                right: Unitize.feet(5),\n                up: Unitize.feet(0),\n                down: Unitize.feet(3),\n              },\n            },\n            {\n              from: 'AE14',\n              to: 'AE13',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(26.8),\n              frontsightAzimuth: Unitize.degrees(288),\n              backsightAzimuth: Unitize.degrees(286),\n              frontsightInclination: Unitize.degrees(-50),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(0),\n                right: Unitize.feet(7),\n                up: Unitize.feet(20),\n                down: Unitize.feet(5),\n              },\n            },\n            {\n              from: 'AE13',\n              to: 'AE12',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(20.7),\n              frontsightAzimuth: Unitize.degrees(236),\n              backsightAzimuth: Unitize.degrees(236),\n              frontsightInclination: Unitize.degrees(34),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: 'SHORT CANYON AT THE BASE OF THE SECOND DROP',\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(5),\n                up: Unitize.feet(4),\n                down: Unitize.feet(4),\n              },\n            },\n          ],\n        },\n        {\n          header: {\n            name: 'TRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY',\n            comment: null,\n            section: undefined,\n            date: undefined,\n            team: undefined,\n            distanceUnit: Length.inches,\n            azimuthUnit: Angle.degrees,\n            inclinationUnit: Angle.degrees,\n            backsightAzimuthCorrected: false,\n            backsightInclinationCorrected: false,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n          },\n          shots: [\n            {\n              from: 'A1',\n              to: 'A2',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.inches(48 * 12 + 10),\n              frontsightAzimuth: Unitize.degrees(292),\n              backsightAzimuth: Unitize.degrees(110),\n              frontsightInclination: Unitize.degrees(-42),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n              fromLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(7),\n                up: Unitize.feet(3),\n                down: Unitize.feet(4.5),\n              },\n              toLruds: {\n                left: Unitize.feet(5),\n                right: Unitize.feet(10),\n                up: Unitize.feet(35),\n                down: Unitize.feet(5),\n              },\n            },\n            {\n              from: 'A2',\n              to: 'A3',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.inches(12 * 12 + 5),\n              frontsightAzimuth: Unitize.degrees(333.5),\n              backsightAzimuth: Unitize.degrees(153.5),\n              frontsightInclination: Unitize.degrees(35),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(1),\n                up: Unitize.feet(15),\n                down: Unitize.feet(5),\n              },\n            },\n            {\n              from: 'A3',\n              to: 'A4',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.inches(4 * 12 + 2),\n              frontsightAzimuth: Unitize.degrees(0),\n              backsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(90),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(1),\n                up: Unitize.feet(10),\n                down: Unitize.feet(10),\n              },\n            },\n          ],\n        },\n        {\n          header: {\n            azimuthUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: false,\n            comment: null,\n            date: undefined,\n            distanceUnit: Length.feet,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n            inclinationUnit: Angle.degrees,\n            name: \"DOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP\",\n            section: undefined,\n            team: undefined,\n          },\n          shots: [\n            {\n              backsightAzimuth: Unitize.degrees(0),\n              backsightInclination: null,\n              comment: null,\n              distance: Unitize.feet(13.7),\n              excludeDistance: false,\n              from: 'B30',\n              frontsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(40),\n              kind: ' ',\n              to: 'B31',\n\n              toLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(4),\n                up: Unitize.feet(6),\n                down: null,\n              },\n            },\n            {\n              backsightAzimuth: Unitize.degrees(0),\n              backsightInclination: null,\n              comment: null,\n              distance: Unitize.feet(13.7),\n              excludeDistance: true,\n              isSplay: true,\n              from: 'B30',\n              frontsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(40),\n              kind: ' ',\n              to: 'B30sp',\n              toLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(4),\n                up: Unitize.feet(6),\n                down: null,\n              },\n            },\n          ],\n        },\n      ],\n    })\n  })\n  it('horizontal shots', async function() {\n    const data = `blah\n *\n *\nTEST\n *\nFT C  DD\n  E22  E21  36.2H  338.5 340.0  1.0      12  2 15 15\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E21',\n      to: 'E22',\n      kind: FrcsShotKind.Horizontal,\n      distance: Unitize.feet(Math.sqrt(36.2 * 36.2 + 1)),\n      horizontalDistance: Unitize.feet(36.2),\n      verticalDistance: Unitize.feet(1),\n      frontsightAzimuth: Unitize.degrees(338.5),\n      backsightAzimuth: Unitize.degrees(340),\n      frontsightInclination: Angle.atan2(1, 36.2),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.feet(12),\n        right: Unitize.feet(2),\n        up: Unitize.feet(15),\n        down: Unitize.feet(15),\n      },\n    })\n  })\n  it('horizontal feet and inches shots', async function() {\n    const data = `blah\n *\n *\nTEST\n *\nFI C  DD\n  A27  A26  16  9H 345.0 163.0 -1.0       0  3  5  4\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'A26',\n      to: 'A27',\n      kind: FrcsShotKind.Horizontal,\n      distance: Unitize.feet(Math.sqrt(16.75 * 16.75 + 1)),\n      horizontalDistance: Unitize.inches(16 * 12 + 9),\n      verticalDistance: Unitize.feet(-1),\n      frontsightAzimuth: Unitize.degrees(345),\n      backsightAzimuth: Unitize.degrees(163),\n      frontsightInclination: Angle.atan2(-1, 16.75),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.feet(0),\n        right: Unitize.feet(3),\n        up: Unitize.feet(5),\n        down: Unitize.feet(4),\n      },\n    })\n  })\n  it('diagonal shots', async function() {\n    const data = `blah\n *\n *\nTEST\n *\nFT C  DD\n  E37  E36  31.6D  231.0 232.0  2.0       3 10 20 32\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Diagonal,\n      distance: Unitize.feet(31.6),\n      verticalDistance: Unitize.feet(2),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Angle.asin(2 / 31.6),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.feet(3),\n        right: Unitize.feet(10),\n        up: Unitize.feet(20),\n        down: Unitize.feet(32),\n      },\n    })\n  })\n  it('invalid distance unit', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nFJ C  DD\n`\n    expect(await parseFrcsSurveyFile('cdata.fr', data)).to.deep.equal({\n      cave: 'blah',\n      errors: [\n        new SegmentParseError(\n          'Invalid distance unit',\n          new Segment({\n            value: 'FJ C  DD',\n            source: 'cdata.fr',\n            startLine: 5,\n            startCol: 0,\n          }).substring(0, 2)\n        ),\n      ],\n      location: null,\n      trips: [\n        {\n          header: {\n            azimuthUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: false,\n            comment: null,\n            date: undefined,\n            distanceUnit: Length.feet,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n            inclinationUnit: Angle.degrees,\n            name: 'TEST',\n            section: undefined,\n            team: undefined,\n          },\n          shots: [],\n        },\n      ],\n    })\n  })\n  it('meters', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT CC DD\n  E37  E36  31.6   231.0 232.0  2.0  3.0  3 10 20 32\n`\n    expect(await parseFrcsSurveyFile('cdata.fr', data)).to.deep.equal({\n      cave: 'blah',\n      errors: [],\n      location: null,\n      trips: [\n        {\n          header: {\n            azimuthUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: true,\n            comment: null,\n            date: undefined,\n            distanceUnit: Length.meters,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: true,\n            inclinationUnit: Angle.degrees,\n            name: 'TEST',\n            section: undefined,\n            team: undefined,\n          },\n          shots: [\n            {\n              from: 'E36',\n              to: 'E37',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.meters(31.6),\n              frontsightAzimuth: Unitize.degrees(231),\n              backsightAzimuth: Unitize.degrees(232),\n              frontsightInclination: Unitize.degrees(2),\n              backsightInclination: Unitize.degrees(3),\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.meters(3),\n                right: Unitize.meters(10),\n                up: Unitize.meters(20),\n                down: Unitize.meters(32),\n              },\n            },\n          ],\n        },\n      ],\n    })\n  })\n  it('exclude length', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT CC DD\n  E37  E36  31.6 * 231.0 232.0  2.0  3.0  3 10 20 32\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Normal,\n      distance: Unitize.meters(31.6),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Unitize.degrees(2),\n      backsightInclination: Unitize.degrees(3),\n      excludeDistance: true,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.meters(3),\n        right: Unitize.meters(10),\n        up: Unitize.meters(20),\n        down: Unitize.meters(32),\n      },\n    })\n  })\n  it('negative LRUD', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT CC DD\n  E37  E36  31.6   231.0 232.0  2.0  3.0 -3 10 20 32\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Normal,\n      distance: Unitize.meters(31.6),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Unitize.degrees(2),\n      backsightInclination: Unitize.degrees(3),\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: null,\n        right: Unitize.meters(10),\n        up: Unitize.meters(20),\n        down: Unitize.meters(32),\n      },\n    })\n  })\n  it('- for no backsight', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT B- DD \n  `\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].header).to.deep.equal({\n      name: 'TEST',\n      comment: null,\n      section: undefined,\n      date: undefined,\n      team: undefined,\n      distanceUnit: Length.meters,\n      azimuthUnit: Angle.degrees,\n      inclinationUnit: Angle.degrees,\n      backsightAzimuthCorrected: false,\n      backsightInclinationCorrected: false,\n      hasBacksightAzimuth: true,\n      hasBacksightInclination: false,\n    })\n  })\n  it('missing both frontsight and backsight inclination', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT B- DD \n  E37  E36  31.6   231.0 232.0           -3 10 20 32\n  `\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Normal,\n      distance: Unitize.meters(31.6),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Unitize.degrees(0),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: null,\n        right: Unitize.meters(10),\n        up: Unitize.meters(20),\n        down: Unitize.meters(32),\n      },\n    })\n  })\n})\n"],"mappings":"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"}
644
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_mocha","require","_index","_unitized","_chai","_FrcsShot","_parseSegment","data","describe","it","parsed","parseFrcsSurveyFile","expect","to","deep","equal","cave","errors","location","trips","header","name","comment","section","undefined","date","team","distanceUnit","Length","feet","azimuthUnit","Angle","degrees","inclinationUnit","backsightAzimuthCorrected","backsightInclinationCorrected","hasBacksightAzimuth","hasBacksightInclination","shots","backsightAzimuth","backsightInclination","distance","Unitize","excludeDistance","from","frontsightAzimuth","frontsightInclination","kind","FrcsShotKind","Normal","fromLruds","left","right","up","down","toLruds","inches","isSplay","Horizontal","Math","sqrt","horizontalDistance","verticalDistance","atan2","Diagonal","asin","SegmentParseError","Segment","value","source","startLine","startCol","substring","meters"],"sources":["../../src/string/parseFrcsSurveyFile.spec.ts"],"sourcesContent":["import { describe, it } from 'mocha'\nimport { parseFrcsSurveyFile } from './index'\nimport { Length, Angle, Unitize } from '@speleotica/unitized'\nimport { expect } from 'chai'\nimport { FrcsShotKind } from '../FrcsShot'\nimport { SegmentParseError, Segment } from 'parse-segment'\n\nconst data = `      Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE\nPETER QUICK, KEITH ORTIZ   -  2-15-81\nThis File has Crumps test connected.  11/20/12\n *\nFT C  DD    A\n      AE20     0                          1  3  0  2\n*      %FS\n*     AE20     0        0        0        Bug-can't put before so put after-so can't make 2 fixed 10/28/12\n AE19 AE20   9.3    60.0  60.0-36.0       2 12  0 20\n AE18 AE19  24.5     0.0   0.0-90.0       6 10 25  0\n AE17 AE18   8.0   350.5 350.5 17.0       3  5  0  0\n AE16 AE17   6.7     0.0   0.0-90.0       3  5  6  1\n AE15 AE16  12.6    70.5  71.0-18.0       4  0  2  1\n AE14 AE15  10.0    21.5  20.0  6.0       5  5  0  3\n AE13 AE14  26.8   288.0 286.0-50.0       0  7 20  5\n*\n*SHORT CANYON AT THE BASE OF THE SECOND DROP\n AE12 AE13  20.7   236.0 236.0 34.0       3  5  4  4\n *\nTRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY\nDAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN    14 FEB 1981\n *\nFI B  DD\n*\n*   A1                                     2  7 3 4.5\n   A2   A1  48 10  292.0 110.0-42.0       5 10 35  5\n   A3   A2  12  5  333.5 153.5 35.0       3  1 15  5\n   A4   A3   4  2    0.0   0.0 90.0       3  1 10 10\n *\nDOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP\nPETER QUICK, CHRIS GERACE, PHIL ODEN, CHIP HOPPER - 3-6-81\n *\nFT C  DD\n  B31  B30  13.7   360.0 360.0 40.0       2  4  6       B30 8 3 5 1.2\nB30sp  B30  13.7 s 360.0 360.0 40.0       2  4  6  \n`\n\ndescribe('parseFrcsSurveyFile', () => {\n  it('basic test', async function() {\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed).to.deep.equal({\n      cave: 'Fisher Ridge Cave System',\n      errors: [],\n      location: 'Hart Co., KY',\n      trips: [\n        {\n          header: {\n            name:\n              'ENTRANCE DROPS, JOE\\'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE',\n            comment: 'This File has Crumps test connected.  11/20/12',\n            section: undefined,\n            date: undefined,\n            team: undefined,\n            distanceUnit: Length.feet,\n            azimuthUnit: Angle.degrees,\n            inclinationUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: false,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n          },\n          shots: [\n            {\n              backsightAzimuth: null,\n              backsightInclination: null,\n              comment: null,\n              distance: Unitize.feet(0),\n              excludeDistance: true,\n              from: 'AE20',\n              frontsightAzimuth: null,\n              frontsightInclination: null,\n              kind: FrcsShotKind.Normal,\n              to: null,\n\n              fromLruds: {\n                left: Unitize.feet(1),\n                right: Unitize.feet(3),\n                up: Unitize.feet(0),\n                down: Unitize.feet(2),\n              },\n            },\n            {\n              from: 'AE20',\n              to: 'AE19',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(9.3),\n              frontsightAzimuth: Unitize.degrees(60),\n              backsightAzimuth: Unitize.degrees(60),\n              frontsightInclination: Unitize.degrees(-36),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment:\n                \"AE20     0        0        0        Bug-can't put before so put after-so can't make 2 fixed 10/28/12\",\n\n              toLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(12),\n                up: Unitize.feet(0),\n                down: Unitize.feet(20),\n              },\n            },\n            {\n              from: 'AE19',\n              to: 'AE18',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(24.5),\n              frontsightAzimuth: Unitize.degrees(0),\n              backsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(-90),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(6),\n                right: Unitize.feet(10),\n                up: Unitize.feet(25),\n                down: Unitize.feet(0),\n              },\n            },\n            {\n              from: 'AE18',\n              to: 'AE17',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(8),\n              frontsightAzimuth: Unitize.degrees(350.5),\n              backsightAzimuth: Unitize.degrees(350.5),\n              frontsightInclination: Unitize.degrees(17),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(5),\n                up: Unitize.feet(0),\n                down: Unitize.feet(0),\n              },\n            },\n            {\n              from: 'AE17',\n              to: 'AE16',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(6.7),\n              frontsightAzimuth: Unitize.degrees(0),\n              backsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(-90),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(5),\n                up: Unitize.feet(6),\n                down: Unitize.feet(1),\n              },\n            },\n            {\n              from: 'AE16',\n              to: 'AE15',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(12.6),\n              frontsightAzimuth: Unitize.degrees(70.5),\n              backsightAzimuth: Unitize.degrees(71),\n              frontsightInclination: Unitize.degrees(-18),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(4),\n                right: Unitize.feet(0),\n                up: Unitize.feet(2),\n                down: Unitize.feet(1),\n              },\n            },\n            {\n              from: 'AE15',\n              to: 'AE14',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(10),\n              frontsightAzimuth: Unitize.degrees(21.5),\n              backsightAzimuth: Unitize.degrees(20),\n              frontsightInclination: Unitize.degrees(6),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(5),\n                right: Unitize.feet(5),\n                up: Unitize.feet(0),\n                down: Unitize.feet(3),\n              },\n            },\n            {\n              from: 'AE14',\n              to: 'AE13',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(26.8),\n              frontsightAzimuth: Unitize.degrees(288),\n              backsightAzimuth: Unitize.degrees(286),\n              frontsightInclination: Unitize.degrees(-50),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(0),\n                right: Unitize.feet(7),\n                up: Unitize.feet(20),\n                down: Unitize.feet(5),\n              },\n            },\n            {\n              from: 'AE13',\n              to: 'AE12',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.feet(20.7),\n              frontsightAzimuth: Unitize.degrees(236),\n              backsightAzimuth: Unitize.degrees(236),\n              frontsightInclination: Unitize.degrees(34),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: 'SHORT CANYON AT THE BASE OF THE SECOND DROP',\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(5),\n                up: Unitize.feet(4),\n                down: Unitize.feet(4),\n              },\n            },\n          ],\n        },\n        {\n          header: {\n            name: 'TRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY',\n            comment: null,\n            section: undefined,\n            date: undefined,\n            team: undefined,\n            distanceUnit: Length.inches,\n            azimuthUnit: Angle.degrees,\n            inclinationUnit: Angle.degrees,\n            backsightAzimuthCorrected: false,\n            backsightInclinationCorrected: false,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n          },\n          shots: [\n            {\n              from: 'A1',\n              to: 'A2',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.inches(48 * 12 + 10),\n              frontsightAzimuth: Unitize.degrees(292),\n              backsightAzimuth: Unitize.degrees(110),\n              frontsightInclination: Unitize.degrees(-42),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n              fromLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(7),\n                up: Unitize.feet(3),\n                down: Unitize.feet(4.5),\n              },\n              toLruds: {\n                left: Unitize.feet(5),\n                right: Unitize.feet(10),\n                up: Unitize.feet(35),\n                down: Unitize.feet(5),\n              },\n            },\n            {\n              from: 'A2',\n              to: 'A3',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.inches(12 * 12 + 5),\n              frontsightAzimuth: Unitize.degrees(333.5),\n              backsightAzimuth: Unitize.degrees(153.5),\n              frontsightInclination: Unitize.degrees(35),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(1),\n                up: Unitize.feet(15),\n                down: Unitize.feet(5),\n              },\n            },\n            {\n              from: 'A3',\n              to: 'A4',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.inches(4 * 12 + 2),\n              frontsightAzimuth: Unitize.degrees(0),\n              backsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(90),\n              backsightInclination: null,\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.feet(3),\n                right: Unitize.feet(1),\n                up: Unitize.feet(10),\n                down: Unitize.feet(10),\n              },\n            },\n          ],\n        },\n        {\n          header: {\n            azimuthUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: false,\n            comment: null,\n            date: undefined,\n            distanceUnit: Length.feet,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n            inclinationUnit: Angle.degrees,\n            name: \"DOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP\",\n            section: undefined,\n            team: undefined,\n          },\n          shots: [\n            {\n              backsightAzimuth: Unitize.degrees(0),\n              backsightInclination: null,\n              comment: null,\n              distance: Unitize.feet(13.7),\n              excludeDistance: false,\n              from: 'B30',\n              frontsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(40),\n              kind: ' ',\n              to: 'B31',\n              fromLruds: {\n                left: Unitize.feet(8),\n                right: Unitize.feet(3),\n                up: Unitize.feet(5),\n                down: Unitize.feet(1.2),\n              },\n              toLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(4),\n                up: Unitize.feet(6),\n                down: null,\n              },\n            },\n            {\n              backsightAzimuth: Unitize.degrees(0),\n              backsightInclination: null,\n              comment: null,\n              distance: Unitize.feet(13.7),\n              excludeDistance: true,\n              isSplay: true,\n              from: 'B30',\n              frontsightAzimuth: Unitize.degrees(0),\n              frontsightInclination: Unitize.degrees(40),\n              kind: ' ',\n              to: 'B30sp',\n              toLruds: {\n                left: Unitize.feet(2),\n                right: Unitize.feet(4),\n                up: Unitize.feet(6),\n                down: null,\n              },\n            },\n          ],\n        },\n      ],\n    })\n  })\n  it('horizontal shots', async function() {\n    const data = `blah\n *\n *\nTEST\n *\nFT C  DD\n  E22  E21  36.2H  338.5 340.0  1.0      12  2 15 15\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E21',\n      to: 'E22',\n      kind: FrcsShotKind.Horizontal,\n      distance: Unitize.feet(Math.sqrt(36.2 * 36.2 + 1)),\n      horizontalDistance: Unitize.feet(36.2),\n      verticalDistance: Unitize.feet(1),\n      frontsightAzimuth: Unitize.degrees(338.5),\n      backsightAzimuth: Unitize.degrees(340),\n      frontsightInclination: Angle.atan2(1, 36.2),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.feet(12),\n        right: Unitize.feet(2),\n        up: Unitize.feet(15),\n        down: Unitize.feet(15),\n      },\n    })\n  })\n  it('horizontal feet and inches shots', async function() {\n    const data = `blah\n *\n *\nTEST\n *\nFI C  DD\n  A27  A26  16  9H 345.0 163.0 -1.0       0  3  5  4\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'A26',\n      to: 'A27',\n      kind: FrcsShotKind.Horizontal,\n      distance: Unitize.feet(Math.sqrt(16.75 * 16.75 + 1)),\n      horizontalDistance: Unitize.inches(16 * 12 + 9),\n      verticalDistance: Unitize.feet(-1),\n      frontsightAzimuth: Unitize.degrees(345),\n      backsightAzimuth: Unitize.degrees(163),\n      frontsightInclination: Angle.atan2(-1, 16.75),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.feet(0),\n        right: Unitize.feet(3),\n        up: Unitize.feet(5),\n        down: Unitize.feet(4),\n      },\n    })\n  })\n  it('diagonal shots', async function() {\n    const data = `blah\n *\n *\nTEST\n *\nFT C  DD\n  E37  E36  31.6D  231.0 232.0  2.0       3 10 20 32\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Diagonal,\n      distance: Unitize.feet(31.6),\n      verticalDistance: Unitize.feet(2),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Angle.asin(2 / 31.6),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.feet(3),\n        right: Unitize.feet(10),\n        up: Unitize.feet(20),\n        down: Unitize.feet(32),\n      },\n    })\n  })\n  it('invalid distance unit', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nFJ C  DD\n`\n    expect(await parseFrcsSurveyFile('cdata.fr', data)).to.deep.equal({\n      cave: 'blah',\n      errors: [\n        new SegmentParseError(\n          'Invalid distance unit',\n          new Segment({\n            value: 'FJ C  DD',\n            source: 'cdata.fr',\n            startLine: 5,\n            startCol: 0,\n          }).substring(0, 2)\n        ),\n      ],\n      location: null,\n      trips: [\n        {\n          header: {\n            azimuthUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: false,\n            comment: null,\n            date: undefined,\n            distanceUnit: Length.feet,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: false,\n            inclinationUnit: Angle.degrees,\n            name: 'TEST',\n            section: undefined,\n            team: undefined,\n          },\n          shots: [],\n        },\n      ],\n    })\n  })\n  it('meters', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT CC DD\n  E37  E36  31.6   231.0 232.0  2.0  3.0  3 10 20 32\n`\n    expect(await parseFrcsSurveyFile('cdata.fr', data)).to.deep.equal({\n      cave: 'blah',\n      errors: [],\n      location: null,\n      trips: [\n        {\n          header: {\n            azimuthUnit: Angle.degrees,\n            backsightAzimuthCorrected: true,\n            backsightInclinationCorrected: true,\n            comment: null,\n            date: undefined,\n            distanceUnit: Length.meters,\n            hasBacksightAzimuth: true,\n            hasBacksightInclination: true,\n            inclinationUnit: Angle.degrees,\n            name: 'TEST',\n            section: undefined,\n            team: undefined,\n          },\n          shots: [\n            {\n              from: 'E36',\n              to: 'E37',\n              kind: FrcsShotKind.Normal,\n              distance: Unitize.meters(31.6),\n              frontsightAzimuth: Unitize.degrees(231),\n              backsightAzimuth: Unitize.degrees(232),\n              frontsightInclination: Unitize.degrees(2),\n              backsightInclination: Unitize.degrees(3),\n              excludeDistance: false,\n              comment: null,\n\n              toLruds: {\n                left: Unitize.meters(3),\n                right: Unitize.meters(10),\n                up: Unitize.meters(20),\n                down: Unitize.meters(32),\n              },\n            },\n          ],\n        },\n      ],\n    })\n  })\n  it('exclude length', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT CC DD\n  E37  E36  31.6 * 231.0 232.0  2.0  3.0  3 10 20 32\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Normal,\n      distance: Unitize.meters(31.6),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Unitize.degrees(2),\n      backsightInclination: Unitize.degrees(3),\n      excludeDistance: true,\n      comment: null,\n\n      toLruds: {\n        left: Unitize.meters(3),\n        right: Unitize.meters(10),\n        up: Unitize.meters(20),\n        down: Unitize.meters(32),\n      },\n    })\n  })\n  it('negative LRUD', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT CC DD\n  E37  E36  31.6   231.0 232.0  2.0  3.0 -3 10 20 32\n`\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Normal,\n      distance: Unitize.meters(31.6),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Unitize.degrees(2),\n      backsightInclination: Unitize.degrees(3),\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: null,\n        right: Unitize.meters(10),\n        up: Unitize.meters(20),\n        down: Unitize.meters(32),\n      },\n    })\n  })\n  it('- for no backsight', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT B- DD \n  `\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].header).to.deep.equal({\n      name: 'TEST',\n      comment: null,\n      section: undefined,\n      date: undefined,\n      team: undefined,\n      distanceUnit: Length.meters,\n      azimuthUnit: Angle.degrees,\n      inclinationUnit: Angle.degrees,\n      backsightAzimuthCorrected: false,\n      backsightInclinationCorrected: false,\n      hasBacksightAzimuth: true,\n      hasBacksightInclination: false,\n    })\n  })\n  it('missing both frontsight and backsight inclination', async function() {\n    const data = `blah\n *\n *\nTEST\n * \nMT B- DD \n  E37  E36  31.6   231.0 232.0           -3 10 20 32\n  `\n    const parsed = await parseFrcsSurveyFile('cdata.fr', data)\n    expect(parsed.trips[0].shots[0]).to.deep.equal({\n      from: 'E36',\n      to: 'E37',\n      kind: FrcsShotKind.Normal,\n      distance: Unitize.meters(31.6),\n      frontsightAzimuth: Unitize.degrees(231),\n      backsightAzimuth: Unitize.degrees(232),\n      frontsightInclination: Unitize.degrees(0),\n      backsightInclination: null,\n      excludeDistance: false,\n      comment: null,\n\n      toLruds: {\n        left: null,\n        right: Unitize.meters(10),\n        up: Unitize.meters(20),\n        down: Unitize.meters(32),\n      },\n    })\n  })\n})\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@speleotica/frcsdata",
3
- "version": "4.0.1",
3
+ "version": "4.0.2",
4
4
  "description": "parser for Chip Hopper's survey data format used in Fisher Ridge Cave System",
5
5
  "main": "index.js",
6
6
  "sideEffects": false,
@@ -168,7 +168,7 @@ function _parseFrcsSurveyFile() {
168
168
  _didIteratorError = false;
169
169
  _context2.prev = 15;
170
170
  _loop = /*#__PURE__*/_regenerator["default"].mark(function _loop() {
171
- var line, errored, thisLineNumber, error, validate, match, _match, k, team, month, day, year, _match2, part, distanceUnit, azimuthUnit, inclinationUnit, backsightAzimuthCorrected, backsightInclinationCorrected, hasBacksightAzimuth, hasBacksightInclination, _trip, shots, _trip$header, _azimuthUnit, _inclinationUnit, _distanceUnit, inches, fromStr, lStr, rStr, uStr, dStr, up, down, left, right, toStr, _shot, fromLrudMatch, fromLruds, _fromLrudMatch$1$trim, _fromLrudMatch$1$trim2, _left, _right, _up, _down, azmFsStr, azmBsStr, incFsStr, incBsStr, kind, distance, horizontalDistance, verticalDistance, frontsightInclination, backsightInclination, excludeDistance, isSplay, feetStr, inchesStr, invalid, _feetStr, h, v, d, _v, frontsightAzimuth, backsightAzimuth, shot;
171
+ var line, errored, thisLineNumber, error, validate, match, _match, k, team, month, day, year, _match2, part, distanceUnit, azimuthUnit, inclinationUnit, backsightAzimuthCorrected, backsightInclinationCorrected, hasBacksightAzimuth, hasBacksightInclination, _exec, _trip, shots, _trip$header, _azimuthUnit, _inclinationUnit, _distanceUnit, inches, fromStr, lStr, rStr, uStr, dStr, up, down, left, right, toStr, _shot, fromLrudMatch, fromLruds, _fromLrudMatch$1$trim, _fromLrudMatch$1$trim2, _left, _right, _up, _down, comment, fromLrudComment, commentFromStr, _fromStr, gap, lrudStr, _lStr, _rStr, _uStr, _dStr, _up2, _down2, _left2, _right2, azmFsStr, azmBsStr, incFsStr, incBsStr, kind, distance, horizontalDistance, verticalDistance, frontsightInclination, backsightInclination, excludeDistance, isSplay, feetStr, inchesStr, invalid, _feetStr, h, v, d, _v, frontsightAzimuth, backsightAzimuth, shot;
172
172
  return _regenerator["default"].wrap(function _loop$(_context) {
173
173
  while (1) switch (_context.prev = _context.next) {
174
174
  case 0:
@@ -213,7 +213,7 @@ function _parseFrcsSurveyFile() {
213
213
  } else {
214
214
  tripCommentEndLine = lineNumber;
215
215
  }
216
- _context.next = 107;
216
+ _context.next = 111;
217
217
  break;
218
218
  case 12:
219
219
  if (!inTripComment) {
@@ -240,7 +240,7 @@ function _parseFrcsSurveyFile() {
240
240
  if (_match2) {
241
241
  section = _match2[1].trim();
242
242
  }
243
- _context.next = 107;
243
+ _context.next = 111;
244
244
  break;
245
245
  case 18:
246
246
  if (!(line.charAt(0) === '*')) {
@@ -252,7 +252,7 @@ function _parseFrcsSurveyFile() {
252
252
  part = line.substring(1).trim();
253
253
  if (part && commentLines) commentLines.push(part);
254
254
  }
255
- _context.next = 107;
255
+ _context.next = 111;
256
256
  break;
257
257
  case 23:
258
258
  if (!inBlockComment) {
@@ -260,7 +260,7 @@ function _parseFrcsSurveyFile() {
260
260
  break;
261
261
  }
262
262
  if (commentLines) commentLines.push(line);
263
- _context.next = 107;
263
+ _context.next = 111;
264
264
  break;
265
265
  case 27:
266
266
  if (!(lineNumber === tripCommentEndLine + 1)) {
@@ -312,11 +312,11 @@ function _parseFrcsSurveyFile() {
312
312
  shots: []
313
313
  };
314
314
  trips.push(trip);
315
- _context.next = 107;
315
+ _context.next = 111;
316
316
  break;
317
317
  case 44:
318
318
  if (!trip) {
319
- _context.next = 107;
319
+ _context.next = 111;
320
320
  break;
321
321
  }
322
322
  _trip = trip, shots = _trip.shots, _trip$header = _trip.header, _azimuthUnit = _trip$header.azimuthUnit, _inclinationUnit = _trip$header.inclinationUnit;
@@ -393,6 +393,32 @@ function _parseFrcsSurveyFile() {
393
393
  down: _down
394
394
  };
395
395
  }
396
+ comment = getComment();
397
+ fromLrudComment = comment;
398
+ commentFromStr = comment ? (_exec = /^\S{1,5}/.exec(comment)) === null || _exec === void 0 ? void 0 : _exec[0] : null;
399
+ if (commentFromStr) {
400
+ _fromStr = commentFromStr;
401
+ fromLrudComment = ' '.repeat(5 - _fromStr.length) + fromLrudComment;
402
+ gap = fromLrudComment.substring(5, 40);
403
+ lrudStr = fromLrudComment.substring(40, 52);
404
+ _lStr = fromLrudComment.substring(40, 43);
405
+ _rStr = fromLrudComment.substring(43, 46);
406
+ _uStr = fromLrudComment.substring(46, 49);
407
+ _dStr = fromLrudComment.substring(49, 52);
408
+ if (/^\s*\S+$/.test(_fromStr) && !gap.trim() && isValidOptFloat(_lStr) && isValidOptFloat(_rStr) && isValidOptFloat(_uStr) && isValidOptFloat(_dStr) && /\d/.test(lrudStr)) {
409
+ _up2 = parseLrud(_uStr, _distanceUnit);
410
+ _down2 = parseLrud(_dStr, _distanceUnit);
411
+ _left2 = parseLrud(_lStr, _distanceUnit);
412
+ _right2 = parseLrud(_rStr, _distanceUnit);
413
+ fromLruds = {
414
+ left: _left2,
415
+ right: _right2,
416
+ up: _up2,
417
+ down: _down2
418
+ };
419
+ comment = null;
420
+ }
421
+ }
396
422
 
397
423
  // azimuth and inclination
398
424
  azmFsStr = validate(19, 25, 'azimuth', isValidOptUFloat);
@@ -400,25 +426,25 @@ function _parseFrcsSurveyFile() {
400
426
  incFsStr = line.substring(30, 35);
401
427
  incBsStr = line.substring(35, 40);
402
428
  if (!errored) {
403
- _context.next = 76;
429
+ _context.next = 80;
404
430
  break;
405
431
  }
406
432
  return _context.abrupt("return", "continue");
407
- case 76:
433
+ case 80:
408
434
  if (!inches) {
409
- _context.next = 89;
435
+ _context.next = 93;
410
436
  break;
411
437
  }
412
438
  feetStr = line.substring(10, 14);
413
439
  inchesStr = line.substring(14, 17); // feet and inches are not both optional
414
440
  if (!(!isValidUInt(feetStr) && !isValidUInt(inchesStr))) {
415
- _context.next = 83;
441
+ _context.next = 87;
416
442
  break;
417
443
  }
418
444
  invalid = feetStr.trim() || inchesStr.trim();
419
445
  error(invalid ? 'Invalid distance' : 'Missing distance', 10, 17);
420
446
  return _context.abrupt("return", "continue");
421
- case 83:
447
+ case 87:
422
448
  // sometimes inches are omitted, hence the || 0...I'm assuming it's possible
423
449
  // for feet to be omitted as well
424
450
  distance = _unitized.Unitize.inches(parseFloat(inchesStr) || 0).add(_unitized.Unitize.feet(parseFloat(feetStr) || 0));
@@ -429,16 +455,16 @@ function _parseFrcsSurveyFile() {
429
455
  // first column that can contain a * for decimal feet shots
430
456
  excludeDistance = line[18] === '*' || line[18] === 's';
431
457
  isSplay = line[18] === 's';
432
- _context.next = 94;
458
+ _context.next = 98;
433
459
  break;
434
- case 89:
460
+ case 93:
435
461
  // decimal feet are not optional
436
462
  _feetStr = validate(10, 16, 'distance', isValidUFloat);
437
463
  distance = new _unitized.UnitizedNumber(parseFloat(_feetStr), _distanceUnit);
438
464
  kind = parseKind(line[16]);
439
465
  excludeDistance = line[17] === '*' || line[17] === 's';
440
466
  isSplay = line[17] === 's';
441
- case 94:
467
+ case 98:
442
468
  if (kind !== _FrcsShot.FrcsShotKind.Normal) {
443
469
  validate(30, 35, 'vertical-distance', isValidFloat);
444
470
  }
@@ -472,11 +498,11 @@ function _parseFrcsSurveyFile() {
472
498
  backsightInclination = parseNumber(incBsStr, _inclinationUnit);
473
499
  }
474
500
  if (!errored) {
475
- _context.next = 98;
501
+ _context.next = 102;
476
502
  break;
477
503
  }
478
504
  return _context.abrupt("return", "continue");
479
- case 98:
505
+ case 102:
480
506
  frontsightAzimuth = parseAzimuth(azmFsStr, _azimuthUnit);
481
507
  backsightAzimuth = parseAzimuth(azmBsStr, _azimuthUnit);
482
508
  if (!frontsightInclination && !backsightInclination) {
@@ -498,14 +524,14 @@ function _parseFrcsSurveyFile() {
498
524
  down: down
499
525
  },
500
526
  excludeDistance: excludeDistance,
501
- comment: getComment()
527
+ comment: comment
502
528
  };
503
529
  if (isSplay) shot.isSplay = true;
504
530
  if (fromLruds) shot.fromLruds = fromLruds;
505
531
  if (horizontalDistance) shot.horizontalDistance = horizontalDistance;
506
532
  if (verticalDistance) shot.verticalDistance = verticalDistance;
507
533
  shots.push(shot);
508
- case 107:
534
+ case 111:
509
535
  case "end":
510
536
  return _context.stop();
511
537
  }
@@ -9,7 +9,7 @@ var _unitized = require("@speleotica/unitized");
9
9
  var _chai = require("chai");
10
10
  var _FrcsShot = require("../FrcsShot");
11
11
  var _parseSegment = require("parse-segment");
12
- var data = " Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE\nPETER QUICK, KEITH ORTIZ - 2-15-81\nThis File has Crumps test connected. 11/20/12\n *\nFT C DD A\n AE20 0 1 3 0 2\n* %FS\n* AE20 0 0 0 Bug-can't put before so put after-so can't make 2 fixed 10/28/12\n AE19 AE20 9.3 60.0 60.0-36.0 2 12 0 20\n AE18 AE19 24.5 0.0 0.0-90.0 6 10 25 0\n AE17 AE18 8.0 350.5 350.5 17.0 3 5 0 0\n AE16 AE17 6.7 0.0 0.0-90.0 3 5 6 1\n AE15 AE16 12.6 70.5 71.0-18.0 4 0 2 1\n AE14 AE15 10.0 21.5 20.0 6.0 5 5 0 3\n AE13 AE14 26.8 288.0 286.0-50.0 0 7 20 5\n*\n*SHORT CANYON AT THE BASE OF THE SECOND DROP\n AE12 AE13 20.7 236.0 236.0 34.0 3 5 4 4\n *\nTRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY\nDAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN 14 FEB 1981\n *\nFI B DD\n A2 A1 48 10 292.0 110.0-42.0 5 10 35 5 A1 2 7 3 4.5\n A3 A2 12 5 333.5 153.5 35.0 3 1 15 5\n A4 A3 4 2 0.0 0.0 90.0 3 1 10 10\n *\nDOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP\nPETER QUICK, CHRIS GERACE, PHIL ODEN, CHIP HOPPER - 3-6-81\n *\nFT C DD\n B31 B30 13.7 360.0 360.0 40.0 2 4 6 \nB30sp B30 13.7 s 360.0 360.0 40.0 2 4 6 \n";
12
+ var data = " Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S \"I LOVE MY WIFE TRAVERSE\", TRICKY TRAVERSE\nPETER QUICK, KEITH ORTIZ - 2-15-81\nThis File has Crumps test connected. 11/20/12\n *\nFT C DD A\n AE20 0 1 3 0 2\n* %FS\n* AE20 0 0 0 Bug-can't put before so put after-so can't make 2 fixed 10/28/12\n AE19 AE20 9.3 60.0 60.0-36.0 2 12 0 20\n AE18 AE19 24.5 0.0 0.0-90.0 6 10 25 0\n AE17 AE18 8.0 350.5 350.5 17.0 3 5 0 0\n AE16 AE17 6.7 0.0 0.0-90.0 3 5 6 1\n AE15 AE16 12.6 70.5 71.0-18.0 4 0 2 1\n AE14 AE15 10.0 21.5 20.0 6.0 5 5 0 3\n AE13 AE14 26.8 288.0 286.0-50.0 0 7 20 5\n*\n*SHORT CANYON AT THE BASE OF THE SECOND DROP\n AE12 AE13 20.7 236.0 236.0 34.0 3 5 4 4\n *\nTRICKY TRAVERSE AND THEN FIRST SURVEY IN UPPER CROWLWAY\nDAN CROWL, KEITH ORTIZ, CHIP HOPPER, PETER QUICK, LARRY BEAN 14 FEB 1981\n *\nFI B DD\n*\n* A1 2 7 3 4.5\n A2 A1 48 10 292.0 110.0-42.0 5 10 35 5\n A3 A2 12 5 333.5 153.5 35.0 3 1 15 5\n A4 A3 4 2 0.0 0.0 90.0 3 1 10 10\n *\nDOUG'S DEMISE (50 FT DROP), CHRIS CROSS, CRAWL ABOVE DROP\nPETER QUICK, CHRIS GERACE, PHIL ODEN, CHIP HOPPER - 3-6-81\n *\nFT C DD\n B31 B30 13.7 360.0 360.0 40.0 2 4 6 B30 8 3 5 1.2\nB30sp B30 13.7 s 360.0 360.0 40.0 2 4 6 \n";
13
13
  (0, _mocha.describe)('parseFrcsSurveyFile', function () {
14
14
  (0, _mocha.it)('basic test', /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
15
15
  var parsed;
@@ -292,6 +292,12 @@ var data = " Fisher Ridge Cave System, Hart Co., KY\nENTRANCE DROPS, JOE'S
292
292
  frontsightInclination: _unitized.Unitize.degrees(40),
293
293
  kind: ' ',
294
294
  to: 'B31',
295
+ fromLruds: {
296
+ left: _unitized.Unitize.feet(8),
297
+ right: _unitized.Unitize.feet(3),
298
+ up: _unitized.Unitize.feet(5),
299
+ down: _unitized.Unitize.feet(1.2)
300
+ },
295
301
  toLruds: {
296
302
  left: _unitized.Unitize.feet(2),
297
303
  right: _unitized.Unitize.feet(4),