source: cpp/frams/genetic/genoconv.h @ 117

Last change on this file since 117 was 109, checked in by sz, 11 years ago

source reorganization (see README)
new feature added: part/joint shapes (see frams/_demos/part_shapes.cpp)

  • Property svn:eol-style set to native
File size: 3.6 KB
Line 
1// This file is a part of the Framsticks GDK library.
2// Copyright (C) 2002-2011  Szymon Ulatowski.  See LICENSE.txt for details.
3// Refer to http://www.framsticks.com/ for further information.
4
5#ifndef _GENCONV_H_
6#define _GENCONV_H_
7
8#include "geno.h"
9#include <frams/param/param.h>
10#include <frams/util/list.h>
11#include <frams/util/sstring.h>
12
13#include <string>
14#include <vector>
15
16
17class GenoConvManager;
18
19class GenoConvParam: public Param
20{
21GenoConvManager *gcm;
22std::vector<std::string> gcnames;
23char tmp_id[20];
24void freetab();
25public:
26GenoConvParam(GenoConvManager *g);
27~GenoConvParam();
28void *getTarget(int);
29const char* id(int i);
30void updatetab();
31};
32
33class MultiMap;
34
35/// Base class for all Geno Converters.
36/// In constructor you have to set public fields
37/// indicating your identity and supported formats.
38/// Each converter serves one in-out format pair.
39/// Instance of your converter should be registered
40/// in GenoConvManager.
41class GenoConverter
42{
43public:
44const char *name;       //< converter name (short)
45char in_format,         //< input format, eg. '1'
46        out_format;     //< output format, eg. '0'
47const char *info;       //< detailed info about converter, format or copyright
48long enabled;   //< don't touch this! (used by configuration module)
49long mapsupport; //< set to 1 if your converter supports genotype mapping
50
51/// You have to reimplement this method.
52/// If your converter cannot do its job, return empty string
53/// (return SString();), any other return value is assumed
54/// to be output genotype.
55/// @param map if not null, mapping informaton is requested, converter should add conversion map to this object
56virtual SString convert(SString &i,MultiMap *map) {return SString();}
57
58virtual ~GenoConverter() {}
59/// Don't forget to set public fields in your constructor
60GenoConverter():name(""),in_format(-1),out_format('0'),info(""),enabled(1),mapsupport(0) {}
61};
62
63/// This class gathers abilities of all converters and can
64/// convert a genotype to any other one, provided there is
65/// a path of GenoConverters between them.
66/// In most cases you don't use this class directly,
67/// Geno::getConverted(int) provides full converting functionality.
68/// Explicit GenoConvManager object is only needed for registering
69/// your GenoConverter.
70/// Use DefaultGenoConvManager to register the standard genotype converters automatically.
71class GenoConvManager
72{
73friend class GenoConvParam;
74SList converters;
75static GenoConvManager *globalobject;
76public:
77GenoConvManager();
78~GenoConvManager();
79class GenoConvParam param;
80/// select an object for use as global GenoConvManager
81void useManager(GenoConvManager *m) {globalobject=m;}
82/// get global converter
83static GenoConvManager *getGlobalObject() {return globalobject;}
84/// make a genotype in other format. genotype will be invalid
85/// if GenoConvManager cannot convert it.
86Geno convert(Geno &in,char format,MultiMap *map=0);
87/// static conversion function (uses global GenoConvManager)
88static Geno globalConvert(Geno &in,char format,MultiMap *map=0);
89/// register GenoConverter
90void addConverter(GenoConverter *conv);
91/// unregister GenoConverter
92void removeConverter(GenoConverter *conv);
93
94char *getPath(char in,char out,char *path,int maxlen,int *mapavailable=0);
95char *getFormatPath(char in,char out,char *path,int maxlen,int *mapavailable=0);
96/// returns the list of converters meeting the specified criteria
97/// pass result=0 if you only need one result (by return value)
98/// default criteria values mean "don't care", pass anything else to narrow your search
99GenoConverter *findConverters(SListTempl<GenoConverter*>* result=0,char in=-1,char out=-1,int enabled=-1,char* name=0);
100};
101
102#endif
103
104
Note: See TracBrowser for help on using the repository browser.