File: XRef.py

package info (click to toggle)
synopsis 0.8.0-5
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 10,112 kB
  • ctags: 12,996
  • sloc: cpp: 34,254; ansic: 33,620; python: 10,975; sh: 7,261; xml: 6,369; makefile: 773; asm: 445
file content (87 lines) | stat: -rw-r--r-- 2,847 bytes parent folder | download | duplicates (2)
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
# $Id: XRef.py,v 1.6 2003/12/09 21:03:44 stefan Exp $
#
# Copyright (C) 2000 Stefan Seefeld
# Copyright (C) 2000 Stephen Davies
# All rights reserved.
# Licensed to the public under the terms of the GNU LGPL (>= 2),
# see the file COPYING for details.
#

import string, cPickle

class CrossReferencer:
   """Handle cross-reference files"""

   def __init__(self):

      self.__data = {}
      self.__index = {}
      self.__file_map = {}
      self.__file_info = []

   def load(self, filename):
      """Loads data from the given filename"""

      f = open(filename, 'rb')
      self.__data, self.__index = cPickle.load(f)
      f.close()
      # Split the data into multiple files based on size
      page = 0
      count = 0
      self.__file_info.append([])
      names = self.__data.keys()
      names.sort()
      for name in names:
         if count > 200:
            count = 0
            page = page + 1
            self.__file_info.append([])
         self.__file_info[page].append(name)
         self.__file_map[name] = page
         target_data = self.__data[name]
         l0, l1, l2 = len(target_data[0]), len(target_data[1]), len(target_data[2])
         count = count + 1 + l0 + l1 + l2
         if l0: count = count + 1
         if l1: count = count + 1
         if l2: count = count + 1

   def get_info(self, name):
      """Retrieves the info for the give name. The info is returned as a
      3-tuple of [list of definitions], [list of calls], [list of
      other references]. The element of each list is another 3-tuple of
      (file, line, scope of reference). The last element is the scope in
      which the reference was made, which is often a function scope, denoted
      as starting with a backtick, eg: Builder::`add_operation(std::string).
      Returns None if there is no xref info for the given name.
      """

      if not self.__data.has_key(name): return None
      return self.__data[name]

   def get_possible_names(self, name):
      """Returns a list of possible scoped names that end with the given
      name. These scoped names can be passed to get_info(). Returns None if
      there is no scoped name ending with the given name."""

      if not self.__index.has_key(name): return None
      return self.__index[name]

   def get_page_for(self, name):
      """Returns the number of the page that the xref info for the given
      name is on, or None if not found."""

      if not self.__file_map.has_key(name): return None
      return self.__file_map[name]

   def get_page_info(self):
      """Returns a list of pages, each consisting of a list of names on that
      page. This method is intended to be used by whatever generates the
      files..."""

      return self.__file_info

   def get_all_names(self):
      """Returns a list of all names"""

      return self.__data.keys()