This file is indexed.

/usr/include/libMems-1.6/libMems/MatchHashEntry.h is in libmems-1.6-dev 1.6.0+4725-2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
/*******************************************************************************
 * $Id: Match.h,v 1.10 2004/03/01 02:40:08 darling Exp $
 * This file is copyright 2002-2007 Aaron Darling and authors listed in the AUTHORS file.
 * This file is licensed under the GPL.
 * Please see the file called COPYING for licensing details.
 * **************
 ******************************************************************************/

#ifndef __MatchHashEntry_h__
#define __MatchHashEntry_h__

#ifdef HAVE_CONFIG_H
#include "config.h"
#endif

#include "libGenome/gnClone.h"
#include <iostream>
#include <set>
#include "libMems/Match.h"

namespace mems {

/**
 * The Match class stores the location of an <b>equal size</b> (inexact or exactly) 
 * matching region
 * between several sequences.  There are numerous functions in this
 * class which can be used to compare and manipulate this match.
 */

class MatchHashEntry : public Match
{
public:
	enum MemType
	{
		seed,
		extended
	};

public:
	MatchHashEntry();
	/**
	 * Creates a new Match.
	 * @param seq_count The total number of sequences in the alignment
	 * @param mersize The size of the mers used in the sorted mer lists.
	 * @param m_type The type of mem to create, can either be a seed or already extended.
	 * @see MemType
	 */
	MatchHashEntry( const uint seq_count, const gnSeqI mersize, const MemType m_type = seed );
	MatchHashEntry* Clone() const;
	MatchHashEntry* Copy() const;
	virtual void Free();
	MatchHashEntry( const MatchHashEntry& mhe ){ *this = mhe; }
	MatchHashEntry& operator=(const MatchHashEntry& mhe);

	/** comparison operator, compares two matches to see if they are the same */
	boolean operator==(const MatchHashEntry& mhe) const;


	/** @return true if this match has already been extended */
	boolean Extended() const{return m_extended;}
	/** Sets this match to be extended if the value passed in "extended" is true */
	void SetExtended(boolean extended){m_extended = extended;}
	/** @return the mer size of the sorted mer lists used to find this match */
	uint MerSize() const{return m_mersize;}

	/**
	 * Calculates the generalized offset and other bookkeeping information
	 * for this mem.  This should <b>always</b> be called after changing the start
	 * positions of the mem.
	 */
	virtual void CalculateOffset();
	
	/** Returns the generalized offset of this match */
	int64 Offset() const{return m_offset;};

	/** Sets the generalized offset of this match to "offset" */
	void SetOffset(int64 offset){m_offset = offset;};		

	static boolean offset_lessthan(const MatchHashEntry& a, const MatchHashEntry& b);
	static boolean start_lessthan_ptr(const MatchHashEntry* a, const MatchHashEntry* b);
	static bool start_lessthan(const MatchHashEntry& a, const MatchHashEntry& b);
	static boolean strict_start_lessthan_ptr(const MatchHashEntry* a, const MatchHashEntry* b);
	/** compare the end of a to the start of b 
	 */
	static int64 end_to_start_compare(const MatchHashEntry& a, const MatchHashEntry& b);
	static int64 start_compare(const MatchHashEntry& a, const MatchHashEntry& b);

	/**
	 *	Will return true if this match contains mhe
	 *  Containment implies that a match has a length >= the contained
	 *  match, it has coordinates in every genome the contained match has,
	 *  the difference in start positions in each genome is the same.
	 * @param mhe The match to check for containment.
	 * @return True if this match contains mhe.
	 */
	boolean Contains(const MatchHashEntry& mhe) const;

private:

	boolean m_extended;
	gnSeqI m_mersize;
	int64 m_offset;
};

inline
MatchHashEntry* MatchHashEntry::Copy() const
{
	return m_allocateAndCopy(*this);
}
inline
void MatchHashEntry::Free()
{
	m_free(this);
}

inline
bool MatchHashEntry::start_lessthan(const MatchHashEntry& a, const MatchHashEntry& b){
	return start_lessthan_ptr(&a, &b);
}

class MheCompare {
public:
	bool operator()(const MatchHashEntry* a, const MatchHashEntry* b) const{
		if( a->FirstStart() > b->FirstStart() ){
			return true;
		}else if( a->FirstStart() == b->FirstStart() ){
			// check that the matches hit the same genomes
			for( size_t i = a->FirstStart(); i < a->SeqCount(); i++ )
			{
				if( a->LeftEnd(i) == NO_MATCH && b->LeftEnd(i) != NO_MATCH )
					return true;
				else if( a->LeftEnd(i) != NO_MATCH && b->LeftEnd(i) == NO_MATCH )
					return false;
			}
			//offsets are the same, check for containment...
			if(a->Contains(*b) || b->Contains(*a)){
				return false;
			}else
				return MatchHashEntry::strict_start_lessthan_ptr(a, b);
		}
		return false;
	}
};

}

#endif // __MatchHashEntry_h__