field-classifier.ts 1.2 KB

123456789101112131415161718192021222324252627282930
  1. /**
  2. * Copyright (c) 2017 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author David Sehnal <david.sehnal@gmail.com>
  5. */
  6. import { Column } from 'mol-base/collections/database'
  7. import { Field } from 'mol-io/reader/cif/data-model'
  8. import { FieldDefinition, FieldType } from 'mol-io/writer/cif/encoder'
  9. const intRegex = /^-?\d+$/
  10. const floatRegex = /^-?(([0-9]+)[.]?|([0-9]*[.][0-9]+))([(][0-9]+[)])?([eE][+-]?[0-9]+)?/
  11. function classify(name: string, field: Field): FieldDefinition {
  12. let floatCount = 0, hasString = false;
  13. for (let i = 0, _i = field.rowCount; i < _i; i++) {
  14. const k = field.valueKind(i);
  15. if (k !== Column.ValueKind.Present) continue;
  16. const v = field.str(i);
  17. if (intRegex.test(v)) continue;
  18. else if (floatRegex.test(v)) floatCount++;
  19. else { hasString = true; break; }
  20. }
  21. if (hasString) return { name, type: FieldType.Str, value: field.str, valueKind: field.valueKind };
  22. if (floatCount > 0) return { name, type: FieldType.Float, value: field.float, valueKind: field.valueKind };
  23. return { name, type: FieldType.Int, value: field.int, valueKind: field.valueKind };
  24. }
  25. export default classify;