file_path <- "R/experiments/jobs/gaussian/15_nodes/paths_cpdags.txt"

# create files if they do not exist
create_file_if_not_exists <- function(file_path) {
  if (!dir.exists(dirname(file_path))) {
    dir.create(dirname(file_path), recursive = TRUE)
  }

  if (!file.exists(file_path)) {
    file.create(file_path)
  }
}



create_file_if_not_exists(file_path)

# create and open files write mode
file_conn_all <- file(file_path, open = "w")

base_dir <- "experiments/5_causal_discovery/gaussian/16_nodes/2_neighbors_9_parents_y"

do_we_gather <- function(file_path) {
  if (grepl("[0-9]+_oracle_cpdag.rds$", file_path)) {
    return(TRUE)
  } else if (grepl("[0-9]+_pc_1000n", file_path)) {
    return(TRUE)
  } else if (grepl("[0-9]+_fges_1000", file_path)) {
    return(TRUE)
  }
  return(FALSE)
  
} 

for (file_path in list.files(base_dir, full.names = TRUE)) {
  if (do_we_gather(file_path)) {
        line <- paste0(file_path)
        writeLines(line, file_conn_all)
  } 
}

# close file connection
close(file_conn_all)

