diff --git a/src/nomad_parser_wannier90/parsers/parser.py b/src/nomad_parser_wannier90/parsers/parser.py index 0536a24..acd534b 100644 --- a/src/nomad_parser_wannier90/parsers/parser.py +++ b/src/nomad_parser_wannier90/parsers/parser.py @@ -546,45 +546,46 @@ def parse( required=MetadataRequired(include=['entry_id', 'mainfile']), ).data metadata = [[sid['entry_id'], sid['mainfile']] for sid in search_ids] - if len(metadata) > 1: - for entry_id, mainfile in metadata: - if ( - mainfile == filepath_stripped - ): # we skipped the current parsed mainfile - continue - entry_archive = self.archive.m_context.load_archive( - entry_id, upload_id, None + for entry_id, mainfile in metadata: + if ( + mainfile == filepath_stripped + ): # we skipped the current parsed mainfile + continue + print(self.archive.m_context) + entry_archive = self.archive.m_context.load_archive( + entry_id, upload_id, None + ) + print(entry_archive) + if dft_path == mainfile: + dft_archive = entry_archive + + # ! commented out for now, until VASP parser is ready + # # check if the simulation cell is the same + # dft_cell = dft_archive.m_xpath( + # 'data.model_system[-1].cell[0]' + # ) + # tb_cell = self.archive.m_xpath( + # 'data.model_system[-1].cell[0]' + # ) + # if dft_cell is not None and tb_cell is not None: + # if dft_cell != tb_cell: + # logger.warning( + # 'The DFT and TB cells do not coincide. We might be connecting wrongly the DFT and TB tasks.' + # ) + # else: + # logger.warning( + # 'Could not resolve the DFT and TB cells.' + # ) + # return + + # Parse the workflow information + dft_plus_tb_archive = self._child_archives.get( + 'DFTPlusTB_workflow' ) - if dft_path == mainfile: - dft_archive = entry_archive - - # ! commented out for now, until VASP parser is ready - # # check if the simulation cell is the same - # dft_cell = dft_archive.m_xpath( - # 'data.model_system[-1].cell[0]' - # ) - # tb_cell = self.archive.m_xpath( - # 'data.model_system[-1].cell[0]' - # ) - # if dft_cell is not None and tb_cell is not None: - # if dft_cell != tb_cell: - # logger.warning( - # 'The DFT and TB cells do not coincide. We might be connecting wrongly the DFT and TB tasks.' - # ) - # else: - # logger.warning( - # 'Could not resolve the DFT and TB cells.' - # ) - # return - - # Parse the workflow information - dft_plus_tb_archive = self._child_archives.get( - 'DFTPlusTB_workflow' - ) - dft_plus_tb = parse_dft_plus_tb_workflow( - dft_archive=dft_archive, tb_archive=self.archive - ) - dft_plus_tb_archive.workflow2 = dft_plus_tb - break + dft_plus_tb = parse_dft_plus_tb_workflow( + dft_archive=dft_archive, tb_archive=self.archive + ) + dft_plus_tb_archive.workflow2 = dft_plus_tb + break except Exception: logger.warning('Could not resolve the DFT+TB workflow for Wannier90.')