/***********************************************************************
 * link_selection.c : Implementation of a pattern for links. It allows to
 *                   filter the links in several ways. Only the length
 *                   of the link is supported yet.
 ***********************************************************************/

/***********************************************************************
 *  This file is part of SpaceChart.
 *  Copyright (C) 2000 Miguel Coca <e970095@zipi.fi.upm.es>
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 ***********************************************************************/

#include <stdlib.h>
#include "../include/starmap.h"
#include "../include/link.h"
#include "../include/link_selection.h"

struct st_link_selection
{
        int is_min_length;
        double min_length;
        int is_max_length;
        double max_length;
};

link_selection_t* link_selection_new( void )
{
        link_selection_t* selection;
        
        if((selection = (link_selection_t*) malloc(sizeof(link_selection_t))))
        {
                selection->is_min_length = 0;
                selection->min_length = 0;
                selection->is_max_length = 0;
                selection->max_length = 0;
        }
        
        return selection;
}

int link_selection_match( link_selection_t* selection, link_t* link )
{
        int matches = 1;
        if( selection->is_min_length )
                matches = matches && 
                        (link_get_distance(link) >= selection->min_length);
        if( selection->is_max_length )
                matches = matches && 
                        (link_get_distance(link) <= selection->max_length);
        return matches;
}

void link_selection_act_min_length( link_selection_t* selection, double min )
{
        selection->is_min_length = 1;
        selection->min_length = min;
}

void link_selection_deact_min_length( link_selection_t* selection )
{
        selection->is_min_length = 0;
}

int link_selection_is_min_length( link_selection_t* selection )
{
        return selection->is_min_length;
}

double link_selection_get_min_length( link_selection_t* selection )
{
        return selection->min_length;
}

void link_selection_act_max_length( link_selection_t* selection, double max )
{
        selection->is_max_length = 1;
        selection->max_length = max;
}

void link_selection_deact_max_length( link_selection_t* selection )
{
        selection->is_max_length = 0;
}

int link_selection_is_max_length( link_selection_t* selection )
{
        return selection->is_max_length;
}

double link_selection_get_max_length( link_selection_t* selection )
{
        return selection->max_length;
}

void link_selection_destroy( link_selection_t* selection )
{
        free( selection );
}


syntax highlighted by Code2HTML, v. 0.9.1