Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
dms3
go-dms3
Commits
eebb4375
Commit
eebb4375
authored
10 years ago
by
Matt Bell
Committed by
Juan Batiz-Benet
10 years ago
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
commands: Added list of option definitions to Request, so Option can lookup values by all aliases
parent
ce28fa36
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
44 additions
and
12 deletions
+44
-12
commands/cli/parse.go
commands/cli/parse.go
+6
-1
commands/http/parse.go
commands/http/parse.go
+6
-1
commands/request.go
commands/request.go
+32
-10
No files found.
commands/cli/parse.go
View file @
eebb4375
...
...
@@ -45,7 +45,12 @@ func Parse(input []string, roots ...*cmds.Command) (cmds.Request, *cmds.Command,
return
nil
,
root
,
cmd
,
path
,
err
}
req
:=
cmds
.
NewRequest
(
path
,
opts
,
args
,
cmd
)
optDefs
,
err
:=
root
.
GetOptions
(
path
)
if
err
!=
nil
{
return
nil
,
root
,
cmd
,
path
,
err
}
req
:=
cmds
.
NewRequest
(
path
,
opts
,
args
,
cmd
,
optDefs
)
err
=
cmd
.
CheckArguments
(
req
)
if
err
!=
nil
{
...
...
This diff is collapsed.
Click to expand it.
commands/http/parse.go
View file @
eebb4375
...
...
@@ -90,7 +90,12 @@ func Parse(r *http.Request, root *cmds.Command) (cmds.Request, error) {
args
=
append
(
args
,
make
([]
interface
{},
valCount
-
1
))
}
req
:=
cmds
.
NewRequest
(
path
,
opts
,
args
,
cmd
)
optDefs
,
err
:=
root
.
GetOptions
(
path
)
if
err
!=
nil
{
return
nil
,
err
}
req
:=
cmds
.
NewRequest
(
path
,
opts
,
args
,
cmd
,
optDefs
)
err
=
cmd
.
CheckArguments
(
req
)
if
err
!=
nil
{
...
...
This diff is collapsed.
Click to expand it.
commands/request.go
View file @
eebb4375
...
...
@@ -33,11 +33,12 @@ type Request interface {
}
type
request
struct
{
path
[]
string
options
optMap
arguments
[]
interface
{}
cmd
*
Command
ctx
Context
path
[]
string
options
optMap
arguments
[]
interface
{}
cmd
*
Command
ctx
Context
optionDefs
map
[
string
]
Option
}
// Path returns the command path of this request
...
...
@@ -47,8 +48,26 @@ func (r *request) Path() []string {
// Option returns the value of the option for given name.
func
(
r
*
request
)
Option
(
name
string
)
(
interface
{},
bool
)
{
val
,
err
:=
r
.
options
[
name
]
return
val
,
err
val
,
found
:=
r
.
options
[
name
]
if
found
{
return
val
,
found
}
// if a value isn't defined for that name, we will try to look it up by its aliases
// find the option with the specified name
option
,
found
:=
r
.
optionDefs
[
name
]
if
found
{
// try all the possible names, break if we find a value
for
_
,
n
:=
range
option
.
Names
{
val
,
found
:=
r
.
options
[
n
]
if
found
{
return
val
,
found
}
}
}
return
nil
,
false
}
// Options returns a copy of the option map
...
...
@@ -152,11 +171,11 @@ func (r *request) ConvertOptions(options map[string]Option) error {
// NewEmptyRequest initializes an empty request
func
NewEmptyRequest
()
Request
{
return
NewRequest
(
nil
,
nil
,
nil
,
nil
)
return
NewRequest
(
nil
,
nil
,
nil
,
nil
,
nil
)
}
// NewRequest returns a request initialized with given arguments
func
NewRequest
(
path
[]
string
,
opts
optMap
,
args
[]
interface
{},
cmd
*
Command
)
Request
{
func
NewRequest
(
path
[]
string
,
opts
optMap
,
args
[]
interface
{},
cmd
*
Command
,
optDefs
map
[
string
]
Option
)
Request
{
if
path
==
nil
{
path
=
make
([]
string
,
0
)
}
...
...
@@ -166,5 +185,8 @@ func NewRequest(path []string, opts optMap, args []interface{}, cmd *Command) Re
if
args
==
nil
{
args
=
make
([]
interface
{},
0
)
}
return
&
request
{
path
,
opts
,
args
,
cmd
,
Context
{}}
if
optDefs
==
nil
{
optDefs
=
make
(
map
[
string
]
Option
)
}
return
&
request
{
path
,
opts
,
args
,
cmd
,
Context
{},
optDefs
}
}
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment