blob: 7214b8f576b220140e1a86d68682ca2e3e7c271b [file] [log] [blame]
Alex Kleinda35fcf2019-03-07 16:01:15 -07001# -*- coding: utf-8 -*-
2# Copyright 2019 The Chromium OS Authors. All rights reserved.
3# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6"""Build target class and related functionality."""
7
8from __future__ import print_function
9
10import os
11
12
13class Error(Exception):
14 """Base module error class."""
15
16
Alex Kleindf4a4482019-09-04 15:31:17 -060017class InvalidNameError(Error):
Alex Kleinda35fcf2019-03-07 16:01:15 -070018 """Error for invalid target name argument."""
19
20
21class BuildTarget(object):
22 """Class to handle the build target information."""
23
24 def __init__(self, name, profile=None, build_root=None):
25 """Build Target init.
26
27 Args:
28 name (str): The full name of the target.
29 profile (str): The profile name.
30 build_root (str): The path to the buildroot.
31 """
32 if not name:
33 raise InvalidNameError('Name is required.')
34
Alex Klein171da612019-08-06 14:00:42 -060035 self._name = name
Alex Kleinda35fcf2019-03-07 16:01:15 -070036 self.board, _, self.variant = name.partition('_')
37 self.profile = profile
38
39 if build_root:
40 self.root = os.path.normpath(build_root)
41 else:
42 self.root = GetDefaultSysrootPath(self.name)
43
Alex Klein171da612019-08-06 14:00:42 -060044 def __eq__(self, other):
45 if self.__class__ is other.__class__:
46 return (self.name == other.name and self.profile == other.profile and
47 self.root == other.root)
48
49 return NotImplemented
50
51 def __hash__(self):
52 return hash(self.name)
53
Alex Kleinaf0e0452019-06-03 18:10:01 -060054 def __str__(self):
55 return self.name
56
Alex Klein171da612019-08-06 14:00:42 -060057 @property
58 def name(self):
59 return self._name
Alex Kleinda35fcf2019-03-07 16:01:15 -070060
Alex Klein309c7572020-01-27 10:55:01 -070061 def get_command(self, base_command):
62 """Get the build target's variant of the given base command.
63
64 We create wrappers for many scripts that handle the build target's
65 arguments. Build the target-specific variant for such a command.
66 e.g. emerge -> emerge-eve.
67
68 TODO: Add optional validation the command exists.
69
70 Args:
71 base_command (str): The wrapped command.
72
73 Returns:
74 str: The build target's command wrapper.
75 """
76 return '%s-%s' % (base_command, self.name)
Alex Kleine1abe2c2019-08-14 10:29:46 -060077
Alex Kleinda35fcf2019-03-07 16:01:15 -070078def GetDefaultSysrootPath(target_name):
79 if target_name:
80 return os.path.join('/build', target_name)
81 else:
82 raise InvalidNameError('Target name is required.')