Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
P
Printrun
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
machinery
Printrun
Commits
cde671a6
Commit
cde671a6
authored
Jun 01, 2011
by
kliment
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #4 from k-eex/alias
'alias' command implemented
parents
41c4f604
cb2ddfbc
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
56 additions
and
1 deletion
+56
-1
.pronsolerc
.pronsolerc
+1
-1
pronsole.py
pronsole.py
+55
-0
No files found.
.pronsolerc
View file @
cde671a6
# Sample .pronsolerc file - copy this into your home directory
# Sample .pronsolerc file - copy this into your home directory
!self.do_alias = lambda aarg,self=self: setattr(self,"do_"+aarg.split()[0],lambda arg,self=self,a=aarg.split(None,1)[1]:self.onecmd(" ".join((a,arg))))
alias up move Z 10
alias up move Z 10
alias loud !self.loud = 1
alias loud !self.loud = 1
alias quiet !self.loud = 0
alias quiet !self.loud = 0
alias home_all G28
pronsole.py
View file @
cde671a6
...
@@ -39,6 +39,7 @@ class pronsole(cmd.Cmd):
...
@@ -39,6 +39,7 @@ class pronsole(cmd.Cmd):
self
.
bedtemps
=
{
"pla"
:
"60"
,
"abs"
:
"110"
,
"off"
:
"0"
}
self
.
bedtemps
=
{
"pla"
:
"60"
,
"abs"
:
"110"
,
"off"
:
"0"
}
self
.
percentdone
=
0
self
.
percentdone
=
0
self
.
tempreadings
=
""
self
.
tempreadings
=
""
self
.
aliases
=
{}
def
scanserial
(
self
):
def
scanserial
(
self
):
"""scan for available ports. return a list of device names."""
"""scan for available ports. return a list of device names."""
...
@@ -69,6 +70,60 @@ class pronsole(cmd.Cmd):
...
@@ -69,6 +70,60 @@ class pronsole(cmd.Cmd):
def
help_gcodes
(
self
):
def
help_gcodes
(
self
):
print
"Gcodes are passed through to the printer as they are"
print
"Gcodes are passed through to the printer as they are"
def
do_alias
(
self
,
l
):
if
l
==
""
:
# list aliases
if
len
(
self
.
aliases
):
self
.
print_topics
(
"Aliases, to display type: alias <name>"
,
self
.
aliases
.
keys
(),
15
,
80
)
else
:
print
"No aliases defined, to define see: help alias"
return
alias_l
=
l
.
split
(
None
,
1
)
alias_name
=
alias_l
[
0
]
if
len
(
alias_l
)
<
2
:
# display alias
if
alias_name
in
self
.
aliases
.
keys
():
print
"Alias '"
+
alias_name
+
"' stands for '"
+
self
.
aliases
[
alias_name
]
+
"'"
else
:
print
"Alias '"
+
alias_name
+
"' is not defined"
return
alias_name
,
alias_def
=
alias_l
if
alias_def
.
lower
()
==
"/d"
:
# delete alias
if
alias_name
in
self
.
aliases
.
keys
():
delattr
(
self
.
__class__
,
"do_"
+
alias_name
)
del
self
.
aliases
[
alias_name
]
print
"Alias '"
+
alias_name
+
"' removed"
return
else
:
print
"Alias '"
+
alias_name
+
"' is not defined"
return
# (re)define an alias
if
alias_name
not
in
self
.
aliases
.
keys
()
and
hasattr
(
self
.
__class__
,
"do_"
+
alias_name
):
print
"Name '"
+
alias_name
+
"' is already being used by built-in command"
return
func
=
lambda
self
,
args
,
alias_def
=
alias_def
:
self
.
onecmd
(
" "
.
join
((
alias_def
,
args
)))
self
.
aliases
[
alias_name
]
=
alias_def
setattr
(
self
.
__class__
,
"do_"
+
alias_name
,
func
)
setattr
(
self
.
__class__
,
"help_"
+
alias_name
,
lambda
self
=
self
,
alias_name
=
alias_name
:
self
.
subhelp_alias
(
alias_name
))
def
help_alias
(
self
):
print
"Create/modify/view aliases: alias <name> [<command>]"
print
"if <command> is not specified, displays the alias definition"
print
"without arguments, displays list of all defined aliases"
print
"To remove an alias: alias <name> /d"
def
complete_alias
(
self
,
text
,
line
,
begidx
,
endidx
):
if
(
len
(
line
.
split
())
==
2
and
line
[
-
1
]
!=
" "
)
or
(
len
(
line
.
split
())
==
1
and
line
[
-
1
]
==
" "
):
return
[
i
for
i
in
self
.
aliases
.
keys
()
if
i
.
startswith
(
text
)]
elif
(
len
(
line
.
split
())
==
3
or
(
len
(
line
.
split
())
==
2
and
line
[
-
1
]
==
" "
)):
return
self
.
completenames
(
text
)
else
:
return
[]
def
subhelp_alias
(
self
,
alias_name
):
print
"'"
+
alias_name
+
"' is alias for '"
+
self
.
aliases
[
alias_name
]
+
"'"
def
postloop
(
self
):
def
postloop
(
self
):
self
.
p
.
disconnect
()
self
.
p
.
disconnect
()
cmd
.
Cmd
.
postloop
(
self
)
cmd
.
Cmd
.
postloop
(
self
)
...
...
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