-
Notifications
You must be signed in to change notification settings - Fork 561
/
interfaces_common.go
86 lines (76 loc) · 2.24 KB
/
interfaces_common.go
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
// -*- Mode: Go; indent-tabs-mode: t -*-
/*
* Copyright (C) 2014-2016 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package main
import (
"fmt"
"strings"
"github.com/snapcore/snapd/i18n"
)
// SnapAndName holds a snap name and a plug or slot name.
type SnapAndName struct {
Snap string
Name string
}
// UnmarshalFlag unmarshals the snap and plug or slot name. The following
// combinations are allowed:
// * <snap>:<plug/slot>
// * <snap>
// * :<plug/slot>
// Every other combination results in an error.
func (sn *SnapAndName) UnmarshalFlag(value string) error {
parts := strings.Split(value, ":")
sn.Snap = ""
sn.Name = ""
switch len(parts) {
case 1:
sn.Snap = parts[0]
case 2:
sn.Snap = parts[0]
sn.Name = parts[1]
// Reject "snap:" (that should be spelled as "snap")
if sn.Name == "" {
sn.Snap = ""
}
}
if sn.Snap == "" && sn.Name == "" {
return fmt.Errorf(i18n.G("invalid value: %q (want snap:name or snap)"), value)
}
return nil
}
// SnapAndNameStrict holds a plug or slot name and, optionally, a snap name.
// The following combinations are allowed:
// * <snap>:<plug/slot>
// * :<plug/slot>
// Every other combination results in an error.
type SnapAndNameStrict struct {
SnapAndName
}
// UnmarshalFlag unmarshals the snap and plug or slot name. The following
// combinations are allowed:
// * <snap>:<plug/slot>
// * :<plug/slot>
// Every other combination results in an error.
func (sn *SnapAndNameStrict) UnmarshalFlag(value string) error {
sn.Snap, sn.Name = "", ""
parts := strings.Split(value, ":")
if len(parts) != 2 || parts[1] == "" {
return fmt.Errorf(i18n.G("invalid value: %q (want snap:name or :name)"), value)
}
sn.Snap, sn.Name = parts[0], parts[1]
return nil
}