#input-file #file-format #castep #chemistry #cell #edit #save

castep-cell-io

A crate helping to parse, edit and save castep input file format .cell

21 releases

0.2.11 Dec 24, 2024
0.2.10 Dec 24, 2024
0.2.9 Oct 28, 2024
0.2.7 Jul 9, 2024
0.1.5 May 22, 2024

#667 in Parser implementations

Download history 14/week @ 2024-09-21 8/week @ 2024-10-12 1/week @ 2024-10-19 242/week @ 2024-10-26 41/week @ 2024-11-02 2/week @ 2024-11-09 3/week @ 2024-11-16 1/week @ 2024-11-23 10/week @ 2024-12-07 1/week @ 2024-12-14 226/week @ 2024-12-21 14/week @ 2024-12-28

251 downloads per month
Used in 2 crates

MIT license

160KB
4.5K SLoC

castep-cell-io

A crate helping to parse, edit and save .cell of Castep.

Development

Currently, the parser can seek and parse the two required block entries in the .cell regardless of their appearance orders in the file: lattice parameters (LATTICE_CART or LATTICE_ABC) and ionic positions (POSITIONS_FRAC or POSITIONS_ABS). POSITIONS_XXX_INTERMEDIATE and POSITIONS_XXX_PRODUCT are supported if feature TS is turned on.

Contents after comment marks (# or !) are supposed to be ignored. The comments should not break the valid format of the data. The parser fails when the comment cut the necessary data, just as how castep fails when accepting such input .cell.

More keywords and data are supported in the future.

Usage

Add the crate by cargo

cargo add castep-cell-parser

In your code:

use std::{fs, path::Path};
use castep_cell_parser::{CellParser, CellDocument};

let path = Path::new("SAC_GDY_V.cell");
let input = fs::read_to_string(path).unwrap();
let mut cell_parser = CellParser::from(&input.as_str());
let cell_doc: CellDocument = cell_parser.parse().unwrap();

Dependencies

~7MB
~152K SLoC