/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to breezy/plugins/stats/classify.py

  • Committer: Richard Wilbur
  • Date: 2016-02-04 19:07:28 UTC
  • mto: This revision was merged to the branch mainline in revision 6618.
  • Revision ID: richard.wilbur@gmail.com-20160204190728-p0zvfii6zase0fw7
Update COPYING.txt from the original http://www.gnu.org/licenses/gpl-2.0.txt  (Only differences were in whitespace.)  Thanks to Petr Stodulka for pointing out the discrepancy.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2008, 2010 Jelmer Vernooij <jelmer@samba.org>
2
 
 
3
 
# This program is free software; you can redistribute it and/or modify
4
 
# it under the terms of the GNU General Public License as published by
5
 
# the Free Software Foundation; either version 2 of the License, or
6
 
# (at your option) any later version.
7
 
 
8
 
# This program is distributed in the hope that it will be useful,
9
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
 
# GNU General Public License for more details.
12
 
 
13
 
# You should have received a copy of the GNU General Public License
14
 
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
 
"""Classify a commit based on the types of files it changed."""
17
 
 
18
 
from __future__ import absolute_import
19
 
 
20
 
import os.path
21
 
 
22
 
from ... import urlutils
23
 
from ...trace import mutter
24
 
 
25
 
 
26
 
def classify_filename(name):
27
 
    """Classify a file based on its name.
28
 
 
29
 
    :param name: File path.
30
 
    :return: One of code, documentation, translation or art.
31
 
        None if determining the file type failed.
32
 
    """
33
 
    # FIXME: Use mime types? Ohcount?
34
 
    # TODO: It will be better move those filters to properties file
35
 
        # and have possibility to determining own types !?
36
 
    extension = os.path.splitext(name)[1]
37
 
    if extension in (".c", ".h", ".py", ".cpp", ".rb", ".pm", ".pl", ".ac",
38
 
                        ".java", ".cc", ".proto", ".yy", ".l"):
39
 
        return "code"
40
 
    if extension in (".html", ".xml", ".txt", ".rst", ".TODO"):
41
 
        return "documentation"
42
 
    if extension in (".po",):
43
 
        return "translation"
44
 
    if extension in (".svg", ".png", ".jpg"):
45
 
        return "art"
46
 
    if not extension:
47
 
        basename = urlutils.basename(name)
48
 
        if basename in ("README", "NEWS", "TODO",
49
 
                        "AUTHORS", "COPYING"):
50
 
            return "documentation"
51
 
        if basename in ("Makefile",):
52
 
            return "code"
53
 
 
54
 
    mutter("don't know how to classify %s", name)
55
 
    return None
56
 
 
57
 
 
58
 
def classify_delta(delta):
59
 
    """Determine what sort of changes a delta contains.
60
 
 
61
 
    :param delta: A TreeDelta to inspect
62
 
    :return: List with classes found (see classify_filename)
63
 
    """
64
 
    # TODO: This is inaccurate, since it doesn't look at the
65
 
    # number of lines changed in a file.
66
 
    types = []
67
 
    for d in delta.added + delta.modified:
68
 
        types.append(classify_filename(d[0]))
69
 
    return types