File: ExtractProteinChains.C

package info (click to toggle)
ball 1.5.0%2Bgit20180813.37fc53c-6
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 239,888 kB
  • sloc: cpp: 326,149; ansic: 4,208; python: 2,303; yacc: 1,778; lex: 1,099; xml: 958; sh: 322; makefile: 95
file content (125 lines) | stat: -rw-r--r-- 3,641 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
#include <BALL/FORMAT/PDBFile.h>

#include <BALL/FORMAT/commandlineParser.h>

#include "version.h"

using namespace std;
using namespace BALL;

int main(int argc, char* argv[])
{
	// instantiate CommandlineParser object
	CommandlineParser parpars("ExtractProteinChains", "separate all chains of a pdb file into separate pdb files", VERSION, String(__DATE__), "Preparation");

	parpars.registerMandatoryInputFile("pdb",  "input pdb file ");
	parpars.registerOptionalStringParameter("chain_id",  "chain to extract ");
	//TODO
	//parpars.registerFlag("skip_nonaa", "skip all non aminoacids", false);

	parpars.registerMandatoryOutputFile("o", "output file name ");
	parpars.setParameterAsHidden("o");

	// parameters for galaxy for handling multiple output files
	parpars.registerOptionalGalaxyOutputId("o_id", "output id", "$o.id");
	// need to be hidden in command line mode
	parpars.setParameterAsAdvanced("o_id");
	parpars.setParameterAsHidden("o_id");

	// parameters for galaxy for handling multiple output files
	parpars.registerOptionalGalaxyOutputFolder("o_dir", "output directory for 2nd to last solution", "$__new_file_path__");
	// need to be hidden in command line mode
	parpars.setParameterAsAdvanced("o_dir");
	parpars.setParameterAsHidden("o_dir");

	// the manual
	String man = String("This tool splits a pdb file into its chains.");

	parpars.setToolManual(man);

	parpars.setSupportedFormats("pdb", "pdb");
	parpars.setSupportedFormats("o", "pdb");

	// parse the command line
	parpars.parse(argc, argv);


	PDBFile pdb;
	pdb.open(parpars.get("pdb"), std::ios::in);

	if (!pdb)
	{
		// if file does not exist: complain and abort
		Log.error() << "error opening " << parpars.get("pdb") << " for input." << std::endl;
		exit(2);
	}

	System sys;
	pdb >> sys;
	pdb.close();

	// called as command line or e.g. via galaxy?
	bool is_cmd =    !parpars.has("env")
		            || ((parpars.has("env") && parpars.get("env")=="cmdline"));

	// get the optional chain_id
	String chain_id = "";
	if (parpars.has("chain_id"))
	{
		chain_id = parpars.get("chain_id");
	}
/*	else if ( is_cmd && (parpars.get("o_dir") == "$__new_file_path__"))
	{
		Log.error() << endl << "unspecified parameter o_dir. Abort." << endl;
		return 2;
	}
*/

	int export_counter = 0;
	ChainConstIterator c_it = sys.beginChain();
	for (; +c_it ; ++c_it)
	{
		if ((chain_id == "") || (chain_id == c_it->getName()))
		{
			// create the output name
			String outfile_name = String(parpars.get("o")) + "chain_" + String(export_counter) + ".pdb";

			//TODO this is a temporary hack :-(
			// are we given a parameter o_dir
			if (parpars.has("o_dir") && is_cmd && (parpars.get("o_dir") != "$__new_file_path__"))
			{
				outfile_name = String(parpars.get("o_dir")) + "/" + c_it->getName() + "_" + outfile_name;
			}

			// NOTE: Galaxy requires this strange naming convention 
			//       including the fact, that zero-th element has a different name
			if (!is_cmd)
			{
				outfile_name = (export_counter == 0) ? String(parpars.get("o"))
			                               :   String(parpars.get("o_dir")) + "/primary_"
			                                 + String(parpars.get("o_id"))  + "_chain" + String(export_counter)
			                                 + "_visible_pdb";
			}
			// now write the chain
			PDBFile outfile(outfile_name, ios::out);

			if (outfile.bad())
			{
				Log.error() << endl << "cannot write file " << outfile_name << endl;
				return 2;
			}

			outfile << *c_it;
			outfile.close();

			Log << "wrote file " << outfile_name << endl;

			export_counter++;
		}
	}

	return 0;
}