summaryrefslogtreecommitdiff
path: root/gr-utils/python/modtool/modtool_base.py
diff options
context:
space:
mode:
authorSwapnil Negi <swapnil.negi09@gmail.com>2019-01-04 18:29:50 +0100
committerAndrej Rode <mail@andrejro.de>2019-01-04 18:58:02 +0100
commit055287896c8c97eb0cdda825559e217d8db54a14 (patch)
tree613262f5ed45ba4eaadf1bd76009aa16ad22806f /gr-utils/python/modtool/modtool_base.py
parent2fcf3b8afe51092003b7f916edb9e5d6372d4842 (diff)
modtool: gr-modtool overhaul GSoC 2018
This commit contains all the changes done during the 2018 GSoC "gr-modtool overhaul". Changes include: - Rewrite of gr-modtool based on Python Click - Split of gr-modtool in cli and core - Adherence to new GNU Radio 3.8 API for OOTs - Pylint improvements - Py3k and Py2k compatibility This feature is merged in a squash-merge due to big refactoring on the head and base branch and the impossibility to unclutter both.
Diffstat (limited to 'gr-utils/python/modtool/modtool_base.py')
-rw-r--r--gr-utils/python/modtool/modtool_base.py212
1 files changed, 0 insertions, 212 deletions
diff --git a/gr-utils/python/modtool/modtool_base.py b/gr-utils/python/modtool/modtool_base.py
deleted file mode 100644
index 41d83ccafb..0000000000
--- a/gr-utils/python/modtool/modtool_base.py
+++ /dev/null
@@ -1,212 +0,0 @@
-#
-# Copyright 2013,2018 Free Software Foundation, Inc.
-#
-# This file is part of GNU Radio
-#
-# GNU Radio 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 3, or (at your option)
-# any later version.
-#
-# GNU Radio 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 GNU Radio; see the file COPYING. If not, write to
-# the Free Software Foundation, Inc., 51 Franklin Street,
-# Boston, MA 02110-1301, USA.
-#
-""" Base class for the modules """
-
-from __future__ import print_function
-from __future__ import absolute_import
-from __future__ import unicode_literals
-
-import os
-import re
-from argparse import ArgumentParser, RawDescriptionHelpFormatter
-
-from gnuradio import gr
-from .util_functions import get_modname
-from .scm import SCMRepoFactory
-
-class ModToolException(BaseException):
- """ Standard exception for modtool classes. """
- pass
-
-class ModTool(object):
- """ Base class for all modtool command classes. """
- name = 'base'
- description = None
-
- def __init__(self):
- self._subdirs = ['lib', 'include', 'python', 'swig', 'grc'] # List subdirs where stuff happens
- self._has_subdirs = {}
- self._skip_subdirs = {}
- self._info = {}
- self._file = {}
- for subdir in self._subdirs:
- self._has_subdirs[subdir] = False
- self._skip_subdirs[subdir] = False
- self._dir = None
- self.scm = None
-
- @staticmethod
- def setup_parser(parser):
- """Override in child class."""
- pass
-
- @staticmethod
- def setup_parser_block(parser):
- """Setup options specific for block manipulating modules."""
- parser.add_argument("blockname", nargs="?", metavar="BLOCK_NAME",
- help="Name of the block/module")
-
- @staticmethod
- def get_parser():
- """Init the option parser."""
- parser = ArgumentParser(
- description='Manipulate with GNU Radio modules source code tree. ' + \
- 'Call it withou options to run specified command interactively',
- formatter_class=RawDescriptionHelpFormatter)
- parser.add_argument("-d", "--directory", default=".",
- help="Base directory of the module. Defaults to the cwd.")
- parser.add_argument("--skip-lib", action="store_true",
- help="Don't do anything in the lib/ subdirectory.")
- parser.add_argument("--skip-swig", action="store_true",
- help="Don't do anything in the swig/ subdirectory.")
- parser.add_argument("--skip-python", action="store_true",
- help="Don't do anything in the python/ subdirectory.")
- parser.add_argument("--skip-grc", action="store_true",
- help="Don't do anything in the grc/ subdirectory.")
- parser.add_argument("--scm-mode", choices=('yes', 'no', 'auto'),
- default=gr.prefs().get_string('modtool', 'scm_mode', 'no'),
- help="Use source control management [ yes | no | auto ]).")
- parser.add_argument("-y", "--yes", action="store_true",
- help="Answer all questions with 'yes'. This can overwrite and delete your files, so be careful.")
- return parser
-
- def setup(self, options):
- """ Initialise all internal variables, such as the module name etc. """
- self._dir = options.directory
- if not self._check_directory(self._dir):
- raise ModToolException('No GNU Radio module found in the given directory.')
- if hasattr(options, 'module_name') and options.module_name is not None:
- self._info['modname'] = options.module_name
- else:
- self._info['modname'] = get_modname()
- if self._info['modname'] is None:
- raise ModToolException('No GNU Radio module found in the given directory.')
- print("GNU Radio module name identified: " + self._info['modname'])
- if self._info['version'] == '36' and (
- os.path.isdir(os.path.join('include', self._info['modname'])) or
- os.path.isdir(os.path.join('include', 'gnuradio', self._info['modname']))
- ):
- self._info['version'] = '37'
- if not os.path.isfile(os.path.join('cmake', 'Modules', 'FindCppUnit.cmake')):
- self._info['version'] = '38'
- if options.skip_lib or not self._has_subdirs['lib']:
- self._skip_subdirs['lib'] = True
- if options.skip_python or not self._has_subdirs['python']:
- self._skip_subdirs['python'] = True
- if options.skip_swig or self._get_mainswigfile() is None or not self._has_subdirs['swig']:
- self._skip_subdirs['swig'] = True
- if options.skip_grc or not self._has_subdirs['grc']:
- self._skip_subdirs['grc'] = True
- self._info['blockname'] = options.blockname
- self._setup_files()
- self._info['yes'] = options.yes
- self.options = options
- self._setup_scm()
-
- def _setup_files(self):
- """ Initialise the self._file[] dictionary """
- if not self._skip_subdirs['swig']:
- self._file['swig'] = os.path.join('swig', self._get_mainswigfile())
- self._info['pydir'] = 'python'
- if os.path.isdir(os.path.join('python', self._info['modname'])):
- self._info['pydir'] = os.path.join('python', self._info['modname'])
- self._file['qalib'] = os.path.join('lib', 'qa_%s.cc' % self._info['modname'])
- self._file['pyinit'] = os.path.join(self._info['pydir'], '__init__.py')
- self._file['cmlib'] = os.path.join('lib', 'CMakeLists.txt')
- self._file['cmgrc'] = os.path.join('grc', 'CMakeLists.txt')
- self._file['cmpython'] = os.path.join(self._info['pydir'], 'CMakeLists.txt')
- if self._info['is_component']:
- self._info['includedir'] = os.path.join('include', 'gnuradio', self._info['modname'])
- elif self._info['version'] in ('37', '38'):
- self._info['includedir'] = os.path.join('include', self._info['modname'])
- else:
- self._info['includedir'] = 'include'
- self._file['cminclude'] = os.path.join(self._info['includedir'], 'CMakeLists.txt')
- self._file['cmswig'] = os.path.join('swig', 'CMakeLists.txt')
- self._file['cmfind'] = os.path.join('cmake', 'Modules', 'howtoConfig.cmake')
-
-
- def _setup_scm(self, mode='active'):
- """ Initialize source control management. """
- if mode == 'active':
- self.scm = SCMRepoFactory(self.options, '.').make_active_scm_manager()
- else:
- self.scm = SCMRepoFactory(self.options, '.').make_empty_scm_manager()
- if self.scm is None:
- print("Error: Can't set up SCM.")
- exit(1)
-
- def _check_directory(self, directory):
- """ Guesses if dir is a valid GNU Radio module directory by looking for
- CMakeLists.txt and at least one of the subdirs lib/, python/ and swig/.
- Changes the directory, if valid. """
- has_makefile = False
- try:
- files = os.listdir(directory)
- os.chdir(directory)
- except OSError:
- print("Can't read or chdir to directory %s." % directory)
- return False
- self._info['is_component'] = False
- for f in files:
- if os.path.isfile(f) and f == 'CMakeLists.txt':
- if re.search(r'find_package\(Gnuradio', open(f).read()) is not None:
- self._info['version'] = '36' # Might be 37, check that later
- has_makefile = True
- elif re.search('GR_REGISTER_COMPONENT', open(f).read()) is not None:
- self._info['version'] = '36' # Might be 37, check that later
- self._info['is_component'] = True
- has_makefile = True
- # TODO search for autofoo
- elif os.path.isdir(f):
- if (f in list(self._has_subdirs.keys())):
- self._has_subdirs[f] = True
- else:
- self._skip_subdirs[f] = True
- return bool(has_makefile and (list(self._has_subdirs.values())))
-
- def _get_mainswigfile(self):
- """ Find out which name the main SWIG file has. In particular, is it
- a MODNAME.i or a MODNAME_swig.i? Returns None if none is found. """
- modname = self._info['modname']
- swig_files = (modname + '.i',
- modname + '_swig.i')
- for fname in swig_files:
- if os.path.isfile(os.path.join(self._dir, 'swig', fname)):
- return fname
- return None
-
- def run(self, options):
- """ Override this. """
- raise NotImplementedError('Module implementation missing')
-
-
-def get_modtool_modules(all_objects):
- """Return list with all modtool modules."""
- modules = []
- for o in all_objects:
- try:
- if issubclass(o, ModTool) and o != ModTool:
- modules.append(o)
- except (TypeError, AttributeError):
- pass
- return modules
-