Merge remote-tracking branch 'origin/master' into mega_merge
This commit is contained in:
commit
3ad950e8d5
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
/secrets
|
||||
/configs/remmina
|
||||
__pycache__
|
35
.gitmodules
vendored
Normal file
35
.gitmodules
vendored
Normal file
@ -0,0 +1,35 @@
|
||||
[submodule "configs/nvim/pack/tpope/start/repeat"]
|
||||
path = configs/nvim/pack/tpope/start/repeat
|
||||
url = https://tpope.io/vim/repeat.git
|
||||
ignore = dirty
|
||||
[submodule "configs/nvim/pack/ggandor/start/leap.nvim"]
|
||||
path = configs/nvim/pack/ggandor/start/leap.nvim
|
||||
url = https://github.com/ggandor/leap.nvim
|
||||
ignore = dirty
|
||||
[submodule "configs/nvim/pack/tpope/start/commentary"]
|
||||
path = configs/nvim/pack/tpope/start/commentary
|
||||
url = https://tpope.io/vim/commentary.git
|
||||
ignore = dirty
|
||||
[submodule "configs/nvim/pack/jiangmiao/start/auto-pairs"]
|
||||
path = configs/nvim/pack/jiangmiao/start/auto-pairs
|
||||
url = https://github.com/jiangmiao/auto-pairs
|
||||
ignore = dirty
|
||||
[submodule "configs/nvim/pack/airblade/start/vim-gitgutter"]
|
||||
path = configs/nvim/pack/airblade/start/vim-gitgutter
|
||||
url = https://github.com/airblade/vim-gitgutter.git
|
||||
ignore = dirty
|
||||
[submodule "configs/nvim/third_party/usda-syntax"]
|
||||
path = configs/nvim/third_party/usda-syntax
|
||||
url = https://github.com/superfunc/usda-syntax
|
||||
[submodule "third_party/ufw-application-profiles"]
|
||||
path = third_party/ufw-application-profiles
|
||||
url = https://github.com/ageis/ufw-application-profiles
|
||||
[submodule "configs/nvim/pack/smolck/start/command-completion.nvim"]
|
||||
path = configs/nvim/pack/smolck/start/command-completion.nvim
|
||||
url = https://github.com/smolck/command-completion.nvim
|
||||
[submodule "configs/nvim/pack/echasnovski/start/mini.trailspace"]
|
||||
path = configs/nvim/pack/echasnovski/start/mini.trailspace
|
||||
url = https://github.com/echasnovski/mini.trailspace
|
||||
[submodule "configs/nvim/pack/neovim/start/nvim-lspconfig"]
|
||||
path = configs/nvim/pack/neovim/start/nvim-lspconfig
|
||||
url = https://github.com/neovim/nvim-lspconfig
|
15
.vscode/settings.json
vendored
Normal file
15
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
{
|
||||
"files.associations": {
|
||||
"*.json.liquid": "json",
|
||||
"*.yaml.liquid": "yaml",
|
||||
"*.md.liquid": "markdown",
|
||||
"*.js.liquid": "liquid-javascript",
|
||||
"*.css.liquid": "liquid-css",
|
||||
"*.scss.liquid": "liquid-scss"
|
||||
},
|
||||
// Add python_modules to the python path
|
||||
"python.analysis.extraPaths": [
|
||||
"./python_modules"
|
||||
],
|
||||
"python.formatting.provider": "black",
|
||||
}
|
16
.vscode/tasks.json
vendored
Normal file
16
.vscode/tasks.json
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
{
|
||||
// See https://go.microsoft.com/fwlink/?LinkId=733558
|
||||
// for the documentation about the tasks.json format
|
||||
"version": "2.0.0",
|
||||
"tasks": [
|
||||
{
|
||||
"label": "Run install script",
|
||||
"type": "shell",
|
||||
"command": "sh",
|
||||
"args": [
|
||||
"./install-linux.sh"
|
||||
],
|
||||
"problemMatcher": []
|
||||
}
|
||||
]
|
||||
}
|
674
LICENSE
Normal file
674
LICENSE
Normal file
@ -0,0 +1,674 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 3, 29 June 2007
|
||||
|
||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The GNU General Public License is a free, copyleft license for
|
||||
software and other kinds of works.
|
||||
|
||||
The licenses for most software and other practical works are designed
|
||||
to take away your freedom to share and change the works. By contrast,
|
||||
the GNU General Public License is intended to guarantee your freedom to
|
||||
share and change all versions of a program--to make sure it remains free
|
||||
software for all its users. We, the Free Software Foundation, use the
|
||||
GNU General Public License for most of our software; it applies also to
|
||||
any other work released this way by its authors. You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
them if you wish), that you receive source code or can get it if you
|
||||
want it, that you can change the software or use pieces of it in new
|
||||
free programs, and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to prevent others from denying you
|
||||
these rights or asking you to surrender the rights. Therefore, you have
|
||||
certain responsibilities if you distribute copies of the software, or if
|
||||
you modify it: responsibilities to respect the freedom of others.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must pass on to the recipients the same
|
||||
freedoms that you received. You must make sure that they, too, receive
|
||||
or can get the source code. And you must show them these terms so they
|
||||
know their rights.
|
||||
|
||||
Developers that use the GNU GPL protect your rights with two steps:
|
||||
(1) assert copyright on the software, and (2) offer you this License
|
||||
giving you legal permission to copy, distribute and/or modify it.
|
||||
|
||||
For the developers' and authors' protection, the GPL clearly explains
|
||||
that there is no warranty for this free software. For both users' and
|
||||
authors' sake, the GPL requires that modified versions be marked as
|
||||
changed, so that their problems will not be attributed erroneously to
|
||||
authors of previous versions.
|
||||
|
||||
Some devices are designed to deny users access to install or run
|
||||
modified versions of the software inside them, although the manufacturer
|
||||
can do so. This is fundamentally incompatible with the aim of
|
||||
protecting users' freedom to change the software. The systematic
|
||||
pattern of such abuse occurs in the area of products for individuals to
|
||||
use, which is precisely where it is most unacceptable. Therefore, we
|
||||
have designed this version of the GPL to prohibit the practice for those
|
||||
products. If such problems arise substantially in other domains, we
|
||||
stand ready to extend this provision to those domains in future versions
|
||||
of the GPL, as needed to protect the freedom of users.
|
||||
|
||||
Finally, every program is threatened constantly by software patents.
|
||||
States should not allow patents to restrict development and use of
|
||||
software on general-purpose computers, but in those that do, we wish to
|
||||
avoid the special danger that patents applied to a free program could
|
||||
make it effectively proprietary. To prevent this, the GPL assures that
|
||||
patents cannot be used to render the program non-free.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
TERMS AND CONDITIONS
|
||||
|
||||
0. Definitions.
|
||||
|
||||
"This License" refers to version 3 of the GNU General Public License.
|
||||
|
||||
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||
works, such as semiconductor masks.
|
||||
|
||||
"The Program" refers to any copyrightable work licensed under this
|
||||
License. Each licensee is addressed as "you". "Licensees" and
|
||||
"recipients" may be individuals or organizations.
|
||||
|
||||
To "modify" a work means to copy from or adapt all or part of the work
|
||||
in a fashion requiring copyright permission, other than the making of an
|
||||
exact copy. The resulting work is called a "modified version" of the
|
||||
earlier work or a work "based on" the earlier work.
|
||||
|
||||
A "covered work" means either the unmodified Program or a work based
|
||||
on the Program.
|
||||
|
||||
To "propagate" a work means to do anything with it that, without
|
||||
permission, would make you directly or secondarily liable for
|
||||
infringement under applicable copyright law, except executing it on a
|
||||
computer or modifying a private copy. Propagation includes copying,
|
||||
distribution (with or without modification), making available to the
|
||||
public, and in some countries other activities as well.
|
||||
|
||||
To "convey" a work means any kind of propagation that enables other
|
||||
parties to make or receive copies. Mere interaction with a user through
|
||||
a computer network, with no transfer of a copy, is not conveying.
|
||||
|
||||
An interactive user interface displays "Appropriate Legal Notices"
|
||||
to the extent that it includes a convenient and prominently visible
|
||||
feature that (1) displays an appropriate copyright notice, and (2)
|
||||
tells the user that there is no warranty for the work (except to the
|
||||
extent that warranties are provided), that licensees may convey the
|
||||
work under this License, and how to view a copy of this License. If
|
||||
the interface presents a list of user commands or options, such as a
|
||||
menu, a prominent item in the list meets this criterion.
|
||||
|
||||
1. Source Code.
|
||||
|
||||
The "source code" for a work means the preferred form of the work
|
||||
for making modifications to it. "Object code" means any non-source
|
||||
form of a work.
|
||||
|
||||
A "Standard Interface" means an interface that either is an official
|
||||
standard defined by a recognized standards body, or, in the case of
|
||||
interfaces specified for a particular programming language, one that
|
||||
is widely used among developers working in that language.
|
||||
|
||||
The "System Libraries" of an executable work include anything, other
|
||||
than the work as a whole, that (a) is included in the normal form of
|
||||
packaging a Major Component, but which is not part of that Major
|
||||
Component, and (b) serves only to enable use of the work with that
|
||||
Major Component, or to implement a Standard Interface for which an
|
||||
implementation is available to the public in source code form. A
|
||||
"Major Component", in this context, means a major essential component
|
||||
(kernel, window system, and so on) of the specific operating system
|
||||
(if any) on which the executable work runs, or a compiler used to
|
||||
produce the work, or an object code interpreter used to run it.
|
||||
|
||||
The "Corresponding Source" for a work in object code form means all
|
||||
the source code needed to generate, install, and (for an executable
|
||||
work) run the object code and to modify the work, including scripts to
|
||||
control those activities. However, it does not include the work's
|
||||
System Libraries, or general-purpose tools or generally available free
|
||||
programs which are used unmodified in performing those activities but
|
||||
which are not part of the work. For example, Corresponding Source
|
||||
includes interface definition files associated with source files for
|
||||
the work, and the source code for shared libraries and dynamically
|
||||
linked subprograms that the work is specifically designed to require,
|
||||
such as by intimate data communication or control flow between those
|
||||
subprograms and other parts of the work.
|
||||
|
||||
The Corresponding Source need not include anything that users
|
||||
can regenerate automatically from other parts of the Corresponding
|
||||
Source.
|
||||
|
||||
The Corresponding Source for a work in source code form is that
|
||||
same work.
|
||||
|
||||
2. Basic Permissions.
|
||||
|
||||
All rights granted under this License are granted for the term of
|
||||
copyright on the Program, and are irrevocable provided the stated
|
||||
conditions are met. This License explicitly affirms your unlimited
|
||||
permission to run the unmodified Program. The output from running a
|
||||
covered work is covered by this License only if the output, given its
|
||||
content, constitutes a covered work. This License acknowledges your
|
||||
rights of fair use or other equivalent, as provided by copyright law.
|
||||
|
||||
You may make, run and propagate covered works that you do not
|
||||
convey, without conditions so long as your license otherwise remains
|
||||
in force. You may convey covered works to others for the sole purpose
|
||||
of having them make modifications exclusively for you, or provide you
|
||||
with facilities for running those works, provided that you comply with
|
||||
the terms of this License in conveying all material for which you do
|
||||
not control copyright. Those thus making or running the covered works
|
||||
for you must do so exclusively on your behalf, under your direction
|
||||
and control, on terms that prohibit them from making any copies of
|
||||
your copyrighted material outside their relationship with you.
|
||||
|
||||
Conveying under any other circumstances is permitted solely under
|
||||
the conditions stated below. Sublicensing is not allowed; section 10
|
||||
makes it unnecessary.
|
||||
|
||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||
|
||||
No covered work shall be deemed part of an effective technological
|
||||
measure under any applicable law fulfilling obligations under article
|
||||
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||
similar laws prohibiting or restricting circumvention of such
|
||||
measures.
|
||||
|
||||
When you convey a covered work, you waive any legal power to forbid
|
||||
circumvention of technological measures to the extent such circumvention
|
||||
is effected by exercising rights under this License with respect to
|
||||
the covered work, and you disclaim any intention to limit operation or
|
||||
modification of the work as a means of enforcing, against the work's
|
||||
users, your or third parties' legal rights to forbid circumvention of
|
||||
technological measures.
|
||||
|
||||
4. Conveying Verbatim Copies.
|
||||
|
||||
You may convey verbatim copies of the Program's source code as you
|
||||
receive it, in any medium, provided that you conspicuously and
|
||||
appropriately publish on each copy an appropriate copyright notice;
|
||||
keep intact all notices stating that this License and any
|
||||
non-permissive terms added in accord with section 7 apply to the code;
|
||||
keep intact all notices of the absence of any warranty; and give all
|
||||
recipients a copy of this License along with the Program.
|
||||
|
||||
You may charge any price or no price for each copy that you convey,
|
||||
and you may offer support or warranty protection for a fee.
|
||||
|
||||
5. Conveying Modified Source Versions.
|
||||
|
||||
You may convey a work based on the Program, or the modifications to
|
||||
produce it from the Program, in the form of source code under the
|
||||
terms of section 4, provided that you also meet all of these conditions:
|
||||
|
||||
a) The work must carry prominent notices stating that you modified
|
||||
it, and giving a relevant date.
|
||||
|
||||
b) The work must carry prominent notices stating that it is
|
||||
released under this License and any conditions added under section
|
||||
7. This requirement modifies the requirement in section 4 to
|
||||
"keep intact all notices".
|
||||
|
||||
c) You must license the entire work, as a whole, under this
|
||||
License to anyone who comes into possession of a copy. This
|
||||
License will therefore apply, along with any applicable section 7
|
||||
additional terms, to the whole of the work, and all its parts,
|
||||
regardless of how they are packaged. This License gives no
|
||||
permission to license the work in any other way, but it does not
|
||||
invalidate such permission if you have separately received it.
|
||||
|
||||
d) If the work has interactive user interfaces, each must display
|
||||
Appropriate Legal Notices; however, if the Program has interactive
|
||||
interfaces that do not display Appropriate Legal Notices, your
|
||||
work need not make them do so.
|
||||
|
||||
A compilation of a covered work with other separate and independent
|
||||
works, which are not by their nature extensions of the covered work,
|
||||
and which are not combined with it such as to form a larger program,
|
||||
in or on a volume of a storage or distribution medium, is called an
|
||||
"aggregate" if the compilation and its resulting copyright are not
|
||||
used to limit the access or legal rights of the compilation's users
|
||||
beyond what the individual works permit. Inclusion of a covered work
|
||||
in an aggregate does not cause this License to apply to the other
|
||||
parts of the aggregate.
|
||||
|
||||
6. Conveying Non-Source Forms.
|
||||
|
||||
You may convey a covered work in object code form under the terms
|
||||
of sections 4 and 5, provided that you also convey the
|
||||
machine-readable Corresponding Source under the terms of this License,
|
||||
in one of these ways:
|
||||
|
||||
a) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by the
|
||||
Corresponding Source fixed on a durable physical medium
|
||||
customarily used for software interchange.
|
||||
|
||||
b) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by a
|
||||
written offer, valid for at least three years and valid for as
|
||||
long as you offer spare parts or customer support for that product
|
||||
model, to give anyone who possesses the object code either (1) a
|
||||
copy of the Corresponding Source for all the software in the
|
||||
product that is covered by this License, on a durable physical
|
||||
medium customarily used for software interchange, for a price no
|
||||
more than your reasonable cost of physically performing this
|
||||
conveying of source, or (2) access to copy the
|
||||
Corresponding Source from a network server at no charge.
|
||||
|
||||
c) Convey individual copies of the object code with a copy of the
|
||||
written offer to provide the Corresponding Source. This
|
||||
alternative is allowed only occasionally and noncommercially, and
|
||||
only if you received the object code with such an offer, in accord
|
||||
with subsection 6b.
|
||||
|
||||
d) Convey the object code by offering access from a designated
|
||||
place (gratis or for a charge), and offer equivalent access to the
|
||||
Corresponding Source in the same way through the same place at no
|
||||
further charge. You need not require recipients to copy the
|
||||
Corresponding Source along with the object code. If the place to
|
||||
copy the object code is a network server, the Corresponding Source
|
||||
may be on a different server (operated by you or a third party)
|
||||
that supports equivalent copying facilities, provided you maintain
|
||||
clear directions next to the object code saying where to find the
|
||||
Corresponding Source. Regardless of what server hosts the
|
||||
Corresponding Source, you remain obligated to ensure that it is
|
||||
available for as long as needed to satisfy these requirements.
|
||||
|
||||
e) Convey the object code using peer-to-peer transmission, provided
|
||||
you inform other peers where the object code and Corresponding
|
||||
Source of the work are being offered to the general public at no
|
||||
charge under subsection 6d.
|
||||
|
||||
A separable portion of the object code, whose source code is excluded
|
||||
from the Corresponding Source as a System Library, need not be
|
||||
included in conveying the object code work.
|
||||
|
||||
A "User Product" is either (1) a "consumer product", which means any
|
||||
tangible personal property which is normally used for personal, family,
|
||||
or household purposes, or (2) anything designed or sold for incorporation
|
||||
into a dwelling. In determining whether a product is a consumer product,
|
||||
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||
product received by a particular user, "normally used" refers to a
|
||||
typical or common use of that class of product, regardless of the status
|
||||
of the particular user or of the way in which the particular user
|
||||
actually uses, or expects or is expected to use, the product. A product
|
||||
is a consumer product regardless of whether the product has substantial
|
||||
commercial, industrial or non-consumer uses, unless such uses represent
|
||||
the only significant mode of use of the product.
|
||||
|
||||
"Installation Information" for a User Product means any methods,
|
||||
procedures, authorization keys, or other information required to install
|
||||
and execute modified versions of a covered work in that User Product from
|
||||
a modified version of its Corresponding Source. The information must
|
||||
suffice to ensure that the continued functioning of the modified object
|
||||
code is in no case prevented or interfered with solely because
|
||||
modification has been made.
|
||||
|
||||
If you convey an object code work under this section in, or with, or
|
||||
specifically for use in, a User Product, and the conveying occurs as
|
||||
part of a transaction in which the right of possession and use of the
|
||||
User Product is transferred to the recipient in perpetuity or for a
|
||||
fixed term (regardless of how the transaction is characterized), the
|
||||
Corresponding Source conveyed under this section must be accompanied
|
||||
by the Installation Information. But this requirement does not apply
|
||||
if neither you nor any third party retains the ability to install
|
||||
modified object code on the User Product (for example, the work has
|
||||
been installed in ROM).
|
||||
|
||||
The requirement to provide Installation Information does not include a
|
||||
requirement to continue to provide support service, warranty, or updates
|
||||
for a work that has been modified or installed by the recipient, or for
|
||||
the User Product in which it has been modified or installed. Access to a
|
||||
network may be denied when the modification itself materially and
|
||||
adversely affects the operation of the network or violates the rules and
|
||||
protocols for communication across the network.
|
||||
|
||||
Corresponding Source conveyed, and Installation Information provided,
|
||||
in accord with this section must be in a format that is publicly
|
||||
documented (and with an implementation available to the public in
|
||||
source code form), and must require no special password or key for
|
||||
unpacking, reading or copying.
|
||||
|
||||
7. Additional Terms.
|
||||
|
||||
"Additional permissions" are terms that supplement the terms of this
|
||||
License by making exceptions from one or more of its conditions.
|
||||
Additional permissions that are applicable to the entire Program shall
|
||||
be treated as though they were included in this License, to the extent
|
||||
that they are valid under applicable law. If additional permissions
|
||||
apply only to part of the Program, that part may be used separately
|
||||
under those permissions, but the entire Program remains governed by
|
||||
this License without regard to the additional permissions.
|
||||
|
||||
When you convey a copy of a covered work, you may at your option
|
||||
remove any additional permissions from that copy, or from any part of
|
||||
it. (Additional permissions may be written to require their own
|
||||
removal in certain cases when you modify the work.) You may place
|
||||
additional permissions on material, added by you to a covered work,
|
||||
for which you have or can give appropriate copyright permission.
|
||||
|
||||
Notwithstanding any other provision of this License, for material you
|
||||
add to a covered work, you may (if authorized by the copyright holders of
|
||||
that material) supplement the terms of this License with terms:
|
||||
|
||||
a) Disclaiming warranty or limiting liability differently from the
|
||||
terms of sections 15 and 16 of this License; or
|
||||
|
||||
b) Requiring preservation of specified reasonable legal notices or
|
||||
author attributions in that material or in the Appropriate Legal
|
||||
Notices displayed by works containing it; or
|
||||
|
||||
c) Prohibiting misrepresentation of the origin of that material, or
|
||||
requiring that modified versions of such material be marked in
|
||||
reasonable ways as different from the original version; or
|
||||
|
||||
d) Limiting the use for publicity purposes of names of licensors or
|
||||
authors of the material; or
|
||||
|
||||
e) Declining to grant rights under trademark law for use of some
|
||||
trade names, trademarks, or service marks; or
|
||||
|
||||
f) Requiring indemnification of licensors and authors of that
|
||||
material by anyone who conveys the material (or modified versions of
|
||||
it) with contractual assumptions of liability to the recipient, for
|
||||
any liability that these contractual assumptions directly impose on
|
||||
those licensors and authors.
|
||||
|
||||
All other non-permissive additional terms are considered "further
|
||||
restrictions" within the meaning of section 10. If the Program as you
|
||||
received it, or any part of it, contains a notice stating that it is
|
||||
governed by this License along with a term that is a further
|
||||
restriction, you may remove that term. If a license document contains
|
||||
a further restriction but permits relicensing or conveying under this
|
||||
License, you may add to a covered work material governed by the terms
|
||||
of that license document, provided that the further restriction does
|
||||
not survive such relicensing or conveying.
|
||||
|
||||
If you add terms to a covered work in accord with this section, you
|
||||
must place, in the relevant source files, a statement of the
|
||||
additional terms that apply to those files, or a notice indicating
|
||||
where to find the applicable terms.
|
||||
|
||||
Additional terms, permissive or non-permissive, may be stated in the
|
||||
form of a separately written license, or stated as exceptions;
|
||||
the above requirements apply either way.
|
||||
|
||||
8. Termination.
|
||||
|
||||
You may not propagate or modify a covered work except as expressly
|
||||
provided under this License. Any attempt otherwise to propagate or
|
||||
modify it is void, and will automatically terminate your rights under
|
||||
this License (including any patent licenses granted under the third
|
||||
paragraph of section 11).
|
||||
|
||||
However, if you cease all violation of this License, then your
|
||||
license from a particular copyright holder is reinstated (a)
|
||||
provisionally, unless and until the copyright holder explicitly and
|
||||
finally terminates your license, and (b) permanently, if the copyright
|
||||
holder fails to notify you of the violation by some reasonable means
|
||||
prior to 60 days after the cessation.
|
||||
|
||||
Moreover, your license from a particular copyright holder is
|
||||
reinstated permanently if the copyright holder notifies you of the
|
||||
violation by some reasonable means, this is the first time you have
|
||||
received notice of violation of this License (for any work) from that
|
||||
copyright holder, and you cure the violation prior to 30 days after
|
||||
your receipt of the notice.
|
||||
|
||||
Termination of your rights under this section does not terminate the
|
||||
licenses of parties who have received copies or rights from you under
|
||||
this License. If your rights have been terminated and not permanently
|
||||
reinstated, you do not qualify to receive new licenses for the same
|
||||
material under section 10.
|
||||
|
||||
9. Acceptance Not Required for Having Copies.
|
||||
|
||||
You are not required to accept this License in order to receive or
|
||||
run a copy of the Program. Ancillary propagation of a covered work
|
||||
occurring solely as a consequence of using peer-to-peer transmission
|
||||
to receive a copy likewise does not require acceptance. However,
|
||||
nothing other than this License grants you permission to propagate or
|
||||
modify any covered work. These actions infringe copyright if you do
|
||||
not accept this License. Therefore, by modifying or propagating a
|
||||
covered work, you indicate your acceptance of this License to do so.
|
||||
|
||||
10. Automatic Licensing of Downstream Recipients.
|
||||
|
||||
Each time you convey a covered work, the recipient automatically
|
||||
receives a license from the original licensors, to run, modify and
|
||||
propagate that work, subject to this License. You are not responsible
|
||||
for enforcing compliance by third parties with this License.
|
||||
|
||||
An "entity transaction" is a transaction transferring control of an
|
||||
organization, or substantially all assets of one, or subdividing an
|
||||
organization, or merging organizations. If propagation of a covered
|
||||
work results from an entity transaction, each party to that
|
||||
transaction who receives a copy of the work also receives whatever
|
||||
licenses to the work the party's predecessor in interest had or could
|
||||
give under the previous paragraph, plus a right to possession of the
|
||||
Corresponding Source of the work from the predecessor in interest, if
|
||||
the predecessor has it or can get it with reasonable efforts.
|
||||
|
||||
You may not impose any further restrictions on the exercise of the
|
||||
rights granted or affirmed under this License. For example, you may
|
||||
not impose a license fee, royalty, or other charge for exercise of
|
||||
rights granted under this License, and you may not initiate litigation
|
||||
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||
any patent claim is infringed by making, using, selling, offering for
|
||||
sale, or importing the Program or any portion of it.
|
||||
|
||||
11. Patents.
|
||||
|
||||
A "contributor" is a copyright holder who authorizes use under this
|
||||
License of the Program or a work on which the Program is based. The
|
||||
work thus licensed is called the contributor's "contributor version".
|
||||
|
||||
A contributor's "essential patent claims" are all patent claims
|
||||
owned or controlled by the contributor, whether already acquired or
|
||||
hereafter acquired, that would be infringed by some manner, permitted
|
||||
by this License, of making, using, or selling its contributor version,
|
||||
but do not include claims that would be infringed only as a
|
||||
consequence of further modification of the contributor version. For
|
||||
purposes of this definition, "control" includes the right to grant
|
||||
patent sublicenses in a manner consistent with the requirements of
|
||||
this License.
|
||||
|
||||
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||
patent license under the contributor's essential patent claims, to
|
||||
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||
propagate the contents of its contributor version.
|
||||
|
||||
In the following three paragraphs, a "patent license" is any express
|
||||
agreement or commitment, however denominated, not to enforce a patent
|
||||
(such as an express permission to practice a patent or covenant not to
|
||||
sue for patent infringement). To "grant" such a patent license to a
|
||||
party means to make such an agreement or commitment not to enforce a
|
||||
patent against the party.
|
||||
|
||||
If you convey a covered work, knowingly relying on a patent license,
|
||||
and the Corresponding Source of the work is not available for anyone
|
||||
to copy, free of charge and under the terms of this License, through a
|
||||
publicly available network server or other readily accessible means,
|
||||
then you must either (1) cause the Corresponding Source to be so
|
||||
available, or (2) arrange to deprive yourself of the benefit of the
|
||||
patent license for this particular work, or (3) arrange, in a manner
|
||||
consistent with the requirements of this License, to extend the patent
|
||||
license to downstream recipients. "Knowingly relying" means you have
|
||||
actual knowledge that, but for the patent license, your conveying the
|
||||
covered work in a country, or your recipient's use of the covered work
|
||||
in a country, would infringe one or more identifiable patents in that
|
||||
country that you have reason to believe are valid.
|
||||
|
||||
If, pursuant to or in connection with a single transaction or
|
||||
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||
covered work, and grant a patent license to some of the parties
|
||||
receiving the covered work authorizing them to use, propagate, modify
|
||||
or convey a specific copy of the covered work, then the patent license
|
||||
you grant is automatically extended to all recipients of the covered
|
||||
work and works based on it.
|
||||
|
||||
A patent license is "discriminatory" if it does not include within
|
||||
the scope of its coverage, prohibits the exercise of, or is
|
||||
conditioned on the non-exercise of one or more of the rights that are
|
||||
specifically granted under this License. You may not convey a covered
|
||||
work if you are a party to an arrangement with a third party that is
|
||||
in the business of distributing software, under which you make payment
|
||||
to the third party based on the extent of your activity of conveying
|
||||
the work, and under which the third party grants, to any of the
|
||||
parties who would receive the covered work from you, a discriminatory
|
||||
patent license (a) in connection with copies of the covered work
|
||||
conveyed by you (or copies made from those copies), or (b) primarily
|
||||
for and in connection with specific products or compilations that
|
||||
contain the covered work, unless you entered into that arrangement,
|
||||
or that patent license was granted, prior to 28 March 2007.
|
||||
|
||||
Nothing in this License shall be construed as excluding or limiting
|
||||
any implied license or other defenses to infringement that may
|
||||
otherwise be available to you under applicable patent law.
|
||||
|
||||
12. No Surrender of Others' Freedom.
|
||||
|
||||
If conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot convey a
|
||||
covered work so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you may
|
||||
not convey it at all. For example, if you agree to terms that obligate you
|
||||
to collect a royalty for further conveying from those to whom you convey
|
||||
the Program, the only way you could satisfy both those terms and this
|
||||
License would be to refrain entirely from conveying the Program.
|
||||
|
||||
13. Use with the GNU Affero General Public License.
|
||||
|
||||
Notwithstanding any other provision of this License, you have
|
||||
permission to link or combine any covered work with a work licensed
|
||||
under version 3 of the GNU Affero General Public License into a single
|
||||
combined work, and to convey the resulting work. The terms of this
|
||||
License will continue to apply to the part which is the covered work,
|
||||
but the special requirements of the GNU Affero General Public License,
|
||||
section 13, concerning interaction through a network will apply to the
|
||||
combination as such.
|
||||
|
||||
14. Revised Versions of this License.
|
||||
|
||||
The Free Software Foundation may publish revised and/or new versions of
|
||||
the GNU General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the
|
||||
Program specifies that a certain numbered version of the GNU General
|
||||
Public License "or any later version" applies to it, you have the
|
||||
option of following the terms and conditions either of that numbered
|
||||
version or of any later version published by the Free Software
|
||||
Foundation. If the Program does not specify a version number of the
|
||||
GNU General Public License, you may choose any version ever published
|
||||
by the Free Software Foundation.
|
||||
|
||||
If the Program specifies that a proxy can decide which future
|
||||
versions of the GNU General Public License can be used, that proxy's
|
||||
public statement of acceptance of a version permanently authorizes you
|
||||
to choose that version for the Program.
|
||||
|
||||
Later license versions may give you additional or different
|
||||
permissions. However, no additional obligations are imposed on any
|
||||
author or copyright holder as a result of your choosing to follow a
|
||||
later version.
|
||||
|
||||
15. Disclaimer of Warranty.
|
||||
|
||||
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
||||
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
||||
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
||||
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
||||
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||
|
||||
16. Limitation of Liability.
|
||||
|
||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
||||
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
||||
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
||||
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
||||
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
||||
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
||||
SUCH DAMAGES.
|
||||
|
||||
17. Interpretation of Sections 15 and 16.
|
||||
|
||||
If the disclaimer of warranty and limitation of liability provided
|
||||
above cannot be given local legal effect according to their terms,
|
||||
reviewing courts shall apply local law that most closely approximates
|
||||
an absolute waiver of all civil liability in connection with the
|
||||
Program, unless a warranty or assumption of liability accompanies a
|
||||
copy of the Program in return for a fee.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
state the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program 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 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
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 <https://www.gnu.org/licenses/>.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program does terminal interaction, make it output a short
|
||||
notice like this when it starts in an interactive mode:
|
||||
|
||||
<program> Copyright (C) <year> <name of author>
|
||||
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, your program's commands
|
||||
might be different; for a GUI interface, you would use an "about box".
|
||||
|
||||
You should also get your employer (if you work as a programmer) or school,
|
||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||
For more information on this, and how to apply and follow the GNU GPL, see
|
||||
<https://www.gnu.org/licenses/>.
|
||||
|
||||
The GNU General Public License does not permit incorporating your program
|
||||
into proprietary programs. If your program is a subroutine library, you
|
||||
may consider it more useful to permit linking proprietary applications with
|
||||
the library. If this is what you want to do, use the GNU Lesser General
|
||||
Public License instead of this License. But first, please read
|
||||
<https://www.gnu.org/licenses/why-not-lgpl.html>.
|
27
README.md
Normal file
27
README.md
Normal file
@ -0,0 +1,27 @@
|
||||
# *ew*pratten's *config* files
|
||||
|
||||
This repository stores most of my common config files. It is designed to be deployable to pretty much any system. Assuming ideal conditions, any machine is one `sh ./install-<os>` away from behaving like my personal workstation.
|
||||
|
||||
*I know its called ew**config**, but at this point, its more of a monorepo of scripts*
|
||||
|
||||
## Setup
|
||||
|
||||
The scripts in this repository have the following dependencies:
|
||||
|
||||
- Git (optional, extremely recommended)
|
||||
- ZSH (optional, recommended)
|
||||
- Neovim (optional, recommended)
|
||||
|
||||
Install and link everything with:
|
||||
|
||||
```sh
|
||||
mkdir -p ~/.config && cd ~/.config
|
||||
git clone https://github.com/ewpratten/ewconfig
|
||||
cd ewconfig
|
||||
|
||||
# Linux & BSD & probably MacOS (untested)
|
||||
sh ./install-linux.sh
|
||||
|
||||
# Windows, with GIT BASH
|
||||
sh ./install-windows.sh
|
||||
```
|
199
configs/Code/User/snippets/Unicode.code-snippets
Normal file
199
configs/Code/User/snippets/Unicode.code-snippets
Normal file
@ -0,0 +1,199 @@
|
||||
{
|
||||
// Symbols
|
||||
"Unicode: PI": {
|
||||
"prefix": "uni_pi",
|
||||
"body": "π"
|
||||
},
|
||||
"Unicode: Infinity": {
|
||||
"prefix": "uni_infinity",
|
||||
"body": "∞"
|
||||
},
|
||||
"Unicode: Square Root": {
|
||||
"prefix": "uni_sqrt",
|
||||
"body": "√"
|
||||
},
|
||||
"Unicode: Real": {
|
||||
"prefix": "uni_real",
|
||||
"body": "ℝ"
|
||||
},
|
||||
"Unicode: Natural": {
|
||||
"prefix": "uni_natural",
|
||||
"body": "ℕ"
|
||||
},
|
||||
"Unicode: Integer": {
|
||||
"prefix": "uni_integer",
|
||||
"body": "ℤ"
|
||||
},
|
||||
"Unicode: Rational": {
|
||||
"prefix": "uni_rational",
|
||||
"body": "ℚ"
|
||||
},
|
||||
"Unicode: Complex": {
|
||||
"prefix": "uni_complex",
|
||||
"body": "ℂ"
|
||||
},
|
||||
"Unicode: Plus or Minus": {
|
||||
"prefix": "uni_plus_minus",
|
||||
"body": "±"
|
||||
},
|
||||
"Unicode: Squared": {
|
||||
"prefix": "uni_squared",
|
||||
"body": "²"
|
||||
},
|
||||
"Unicode: Cubed": {
|
||||
"prefix": "uni_cubed",
|
||||
"body": "³"
|
||||
},
|
||||
"Unicode: Hypercubed": {
|
||||
"prefix": "uni_hypercubed",
|
||||
"body": "⁴"
|
||||
},
|
||||
"Unicode: Power of N": {
|
||||
"prefix": "uni_power_n",
|
||||
"body": "ⁿ"
|
||||
},
|
||||
"Unicode: Degree": {
|
||||
"prefix": "uni_degree",
|
||||
"body": "°"
|
||||
},
|
||||
"Unicode: Half": {
|
||||
"prefix": "uni_half",
|
||||
"body": "½"
|
||||
},
|
||||
"Unicode: Third": {
|
||||
"prefix": "uni_third",
|
||||
"body": "⅓"
|
||||
},
|
||||
"Unicode: Two Thirds": {
|
||||
"prefix": "uni_two_thirds",
|
||||
"body": "⅔"
|
||||
},
|
||||
"Unicode: Quarter": {
|
||||
"prefix": "uni_quarter",
|
||||
"body": "¼"
|
||||
},
|
||||
"Unicode: Three Quarters": {
|
||||
"prefix": "uni_three_quarters",
|
||||
"body": "¾"
|
||||
},
|
||||
|
||||
// Equality
|
||||
"Unicode: Not Equal To": {
|
||||
"prefix": "uni_neq",
|
||||
"body": "≠"
|
||||
},
|
||||
"Unicode: Approximately Equal To": {
|
||||
"prefix": "uni_approx",
|
||||
"body": "≈"
|
||||
},
|
||||
"Unicode: Greater Than or Equal To": {
|
||||
"prefix": "uni_gte",
|
||||
"body": "≥"
|
||||
},
|
||||
"Unicode: Less Than or Equal To": {
|
||||
"prefix": "uni_lte",
|
||||
"body": "≤"
|
||||
},
|
||||
|
||||
// Set Operations
|
||||
"Unicode: Union": {
|
||||
"prefix": "uni_union",
|
||||
"body": "∪"
|
||||
},
|
||||
"Unicode: Intersection": {
|
||||
"prefix": "uni_intersect",
|
||||
"body": "∩"
|
||||
},
|
||||
"Unicode: Element Of": {
|
||||
"prefix": "uni_element",
|
||||
"body": "∈"
|
||||
},
|
||||
"Unicode: Not Element Of": {
|
||||
"prefix": "uni_not_element",
|
||||
"body": "∉"
|
||||
},
|
||||
"Unicode: Subset Of": {
|
||||
"prefix": "uni_subset",
|
||||
"body": "⊂"
|
||||
},
|
||||
"Unicode: Superset Of": {
|
||||
"prefix": "uni_superset",
|
||||
"body": "⊃"
|
||||
},
|
||||
"Unicode: Subset Of or Equal To": {
|
||||
"prefix": "uni_subset_eq",
|
||||
"body": "⊆"
|
||||
},
|
||||
"Unicode: Superset Of or Equal To": {
|
||||
"prefix": "uni_superset_eq",
|
||||
"body": "⊇"
|
||||
},
|
||||
"Unicode: Empty Set": {
|
||||
"prefix": "uni_empty",
|
||||
"body": "∅"
|
||||
},
|
||||
|
||||
// Vectors
|
||||
"Unicode: Vector Multiplication": {
|
||||
"prefix": "uni_vector_mult",
|
||||
"body": "⋅"
|
||||
},
|
||||
"Unicode: Vector Cross Product": {
|
||||
"prefix": "uni_vector_cross",
|
||||
"body": "×"
|
||||
},
|
||||
"Unicode: Vector Dot Product": {
|
||||
"prefix": "uni_vector_dot",
|
||||
"body": "·"
|
||||
},
|
||||
"Unicode: Vector Diacritic": {
|
||||
"prefix": "uni_vector",
|
||||
"body": "$1\u20D7$2"
|
||||
},
|
||||
"Unicode: Unit Vector Diacritic": {
|
||||
"prefix": "uni_hat",
|
||||
"body": "$1\u0302$2"
|
||||
},
|
||||
|
||||
// Arrows
|
||||
"Unicode: Left Arrow": {
|
||||
"prefix": "uni_left_arrow",
|
||||
"body": "←"
|
||||
},
|
||||
"Unicode: Right Arrow": {
|
||||
"prefix": "uni_right_arrow",
|
||||
"body": "→"
|
||||
},
|
||||
"Unicode: Up Arrow": {
|
||||
"prefix": "uni_up_arrow",
|
||||
"body": "↑"
|
||||
},
|
||||
"Unicode: Down Arrow": {
|
||||
"prefix": "uni_down_arrow",
|
||||
"body": "↓"
|
||||
},
|
||||
"Unicode: Left Right Arrow": {
|
||||
"prefix": "uni_left_right_arrow",
|
||||
"body": "↔"
|
||||
},
|
||||
"Unicode: Up Down Arrow": {
|
||||
"prefix": "uni_up_down_arrow",
|
||||
"body": "↕"
|
||||
},
|
||||
"Unicode: Top Left Arrow": {
|
||||
"prefix": "uni_top_left_arrow",
|
||||
"body": "↖"
|
||||
},
|
||||
"Unicode: Top Right Arrow": {
|
||||
"prefix": "uni_top_right_arrow",
|
||||
"body": "↗"
|
||||
},
|
||||
"Unicode: Bottom Right Arrow": {
|
||||
"prefix": "uni_bottom_right_arrow",
|
||||
"body": "↘"
|
||||
},
|
||||
"Unicode: Bottom Left Arrow": {
|
||||
"prefix": "uni_bottom_left_arrow",
|
||||
"body": "↙"
|
||||
},
|
||||
}
|
12
configs/Code/User/snippets/json.json
Normal file
12
configs/Code/User/snippets/json.json
Normal file
@ -0,0 +1,12 @@
|
||||
{
|
||||
"Vector3": {
|
||||
"prefix": "vector3",
|
||||
"body": [
|
||||
"{",
|
||||
"\t\"x\": $1,",
|
||||
"\t\"y\": $2,",
|
||||
"\t\"z\": $3",
|
||||
"}",
|
||||
]
|
||||
}
|
||||
}
|
74
configs/Code/User/snippets/python.json
Normal file
74
configs/Code/User/snippets/python.json
Normal file
@ -0,0 +1,74 @@
|
||||
{
|
||||
"CLI App Skeleton": {
|
||||
"prefix": "cli_app",
|
||||
"body": [
|
||||
"import argparse",
|
||||
"import sys",
|
||||
"import logging",
|
||||
"",
|
||||
"logger = logging.getLogger(__name__)",
|
||||
"",
|
||||
"def main() -> int:",
|
||||
"\t# Handle program arguments",
|
||||
"\tap = argparse.ArgumentParser(prog='$1', description='$2')",
|
||||
"\t$3",
|
||||
"\tap.add_argument('-v', '--verbose', help='Enable verbose logging', action='store_true')"
|
||||
"\targs = ap.parse_args()",
|
||||
"",
|
||||
"\t# Configure logging",
|
||||
"\tlogging.basicConfig(",
|
||||
"\t\tlevel=logging.DEBUG if args.verbose else logging.INFO,",
|
||||
"\t\tformat='%(levelname)s:\t%(message)s',",
|
||||
"\t)",
|
||||
"",
|
||||
"\treturn 0",
|
||||
"",
|
||||
"if __name__ == \"__main__\":",
|
||||
"\tsys.exit(main())"
|
||||
]
|
||||
},
|
||||
"Request error handler": {
|
||||
"prefix": "rerror",
|
||||
"body": [
|
||||
"if int($1.status_code / 100) != 2:",
|
||||
"\treturn $2"
|
||||
]
|
||||
},
|
||||
"Path to the current file": {
|
||||
"prefix": "__filepath__",
|
||||
"body": "Path(__file__)"
|
||||
},
|
||||
"Path to the current file's parent directory": {
|
||||
"prefix": "__filedir__",
|
||||
"body": "Path(__file__).parent"
|
||||
},
|
||||
"Disable formatting for block": {
|
||||
"prefix": "nofmt",
|
||||
"body": [
|
||||
"# fmt: off",
|
||||
"$1",
|
||||
"# fmt: on",
|
||||
"$2"
|
||||
]
|
||||
},
|
||||
"Import Path from pathlib": {
|
||||
"prefix": "impath",
|
||||
"body": "from pathlib import Path"
|
||||
},
|
||||
"Get a logger instance": {
|
||||
"prefix": "logger",
|
||||
"body": "logger = logging.getLogger(${1|__name__,'werkzeug'|})"
|
||||
},
|
||||
"Import dataclass": {
|
||||
"prefix":"impdataclass",
|
||||
"body": "from dataclasses import dataclass${1:, field}"
|
||||
},
|
||||
"Import datetime": {
|
||||
"prefix":"impdatetime",
|
||||
"body": "from datetime import datetime"
|
||||
},
|
||||
"Import enums": {
|
||||
"prefix":"impenum",
|
||||
"body": "from enum import Enum${1:, auto}"
|
||||
}
|
||||
}
|
31
configs/Code/User/snippets/rust.json
Normal file
31
configs/Code/User/snippets/rust.json
Normal file
@ -0,0 +1,31 @@
|
||||
{
|
||||
"Constructor": {
|
||||
"prefix": "new",
|
||||
"body": [
|
||||
"/// Construct a new $1",
|
||||
"pub fn new($2) -> Self {",
|
||||
"\tSelf {",
|
||||
"\t\t$3",
|
||||
"\t}",
|
||||
"}"
|
||||
]
|
||||
},
|
||||
"Derive Macro": {
|
||||
"prefix": "derive",
|
||||
"body": "#[derive(Debug, $1)]$2"
|
||||
},
|
||||
"Unit Tests": {
|
||||
"prefix": "cfg: test",
|
||||
"body": [
|
||||
"#[cfg(test)]",
|
||||
"mod tests {",
|
||||
"\tuse super::*;",
|
||||
"\t",
|
||||
"\t#[test]",
|
||||
"\tfn test_$1() {",
|
||||
"\t\t$2",
|
||||
"\t}",
|
||||
"}"
|
||||
]
|
||||
}
|
||||
}
|
15
configs/Code/User/snippets/toml.json
Normal file
15
configs/Code/User/snippets/toml.json
Normal file
@ -0,0 +1,15 @@
|
||||
{
|
||||
"Inculde: Serde": {
|
||||
"prefix": "serde",
|
||||
"body": [
|
||||
"serde = { version = \"^1.0\", features = [\"derive\"] }",
|
||||
"serde_json = \"^1.0\""
|
||||
]
|
||||
},
|
||||
"Include: Tokio": {
|
||||
"prefix": "tokio",
|
||||
"body": [
|
||||
"tokio = { version = \"$1\", features = [\"macros\", \"rt-multi-thread\"] }$2"
|
||||
]
|
||||
},
|
||||
}
|
54
configs/blender/3.x/scripts/addons/y_aligned_camera.py
Normal file
54
configs/blender/3.x/scripts/addons/y_aligned_camera.py
Normal file
@ -0,0 +1,54 @@
|
||||
bl_info = {
|
||||
"name": "Evan's Y-aligned Camera Creator",
|
||||
"author": "Evan Pratten <evan@ewpratten.com>",
|
||||
"version": (1, 0),
|
||||
"blender": (3, 0, 0),
|
||||
"description": "Adds a camera that is aligned with the Y axis by default",
|
||||
"category": "General",
|
||||
}
|
||||
|
||||
import bpy
|
||||
from bpy.types import Operator
|
||||
from bpy_extras.object_utils import AddObjectHelper
|
||||
import math
|
||||
|
||||
|
||||
class OBJECT_OT_add_object(Operator, AddObjectHelper):
|
||||
"""Create a new Camera Object facing +Y"""
|
||||
|
||||
bl_idname = "mesh.add_y_camera"
|
||||
bl_label = "Add Camera Object facing +Y"
|
||||
bl_options = {"REGISTER", "UNDO"}
|
||||
|
||||
def execute(self, _):
|
||||
print("[+Y Camera] Creating new camera and adding to scene at origin")
|
||||
|
||||
# Create a new camera, facing +Y
|
||||
camera_data = bpy.data.cameras.new(name="Camera")
|
||||
camera_object = bpy.data.objects.new("Camera", camera_data)
|
||||
camera_object.rotation_euler[0] = math.radians(90)
|
||||
|
||||
# Add the camera to the scene
|
||||
bpy.context.scene.collection.objects.link(camera_object)
|
||||
|
||||
return {"FINISHED"}
|
||||
|
||||
|
||||
def blender_button_add_y_camera(obj, _):
|
||||
obj.layout.operator(
|
||||
OBJECT_OT_add_object.bl_idname, text="+Y Camera", icon="CAMERA_DATA"
|
||||
)
|
||||
|
||||
|
||||
def register():
|
||||
bpy.utils.register_class(OBJECT_OT_add_object)
|
||||
bpy.types.VIEW3D_MT_add.append(
|
||||
lambda obj, ctx: blender_button_add_y_camera(obj, ctx)
|
||||
)
|
||||
|
||||
|
||||
def unregister():
|
||||
bpy.utils.unregister_class(OBJECT_OT_add_object)
|
||||
bpy.types.VIEW3D_MT_add.remove(
|
||||
lambda obj, ctx: blender_button_add_y_camera(obj, ctx)
|
||||
)
|
2
configs/cargo/config.toml
Normal file
2
configs/cargo/config.toml
Normal file
@ -0,0 +1,2 @@
|
||||
[net]
|
||||
git-fetch-with-cli = true
|
52
configs/git/.gitconfig
Normal file
52
configs/git/.gitconfig
Normal file
@ -0,0 +1,52 @@
|
||||
[include]
|
||||
# NOTE: These paths are imported if they exist and ignored if they don't
|
||||
# This allows us to have a single config file for all our machines
|
||||
# and control the specifics by symlinking the relevant files per-machine
|
||||
path = ~/.config/git/config-fragments/global-mailmap.gitconfig
|
||||
path = ~/.config/git/config-fragments/personal-info.gitconfig
|
||||
path = ~/.config/git/config-fragments/enable-signing.gitconfig
|
||||
|
||||
[init]
|
||||
defaultBranch = master
|
||||
|
||||
[pull]
|
||||
rebase = false
|
||||
|
||||
[advice]
|
||||
detachedHead = true
|
||||
|
||||
[alias]
|
||||
authors = shortlog --summary --numbered --email
|
||||
tree = log --graph --decorate --abbrev-commit --all \
|
||||
--pretty=format:'%C(yellow)commit %h%C(auto)%d%n%C(cyan)Author:%Creset %aN %C(dim white)<%aE>%n%C(cyan)Date:%Creset %C(dim white)%ad (%ar)%n%s%n' \
|
||||
--date=format:'%b %d %Y %H:%M:%S %z'
|
||||
branches = branch -a -l -vv
|
||||
overview = log --all --pretty=format:'%C(green)commit %C(yellow)%h%C(green) by %C(reset)%C(yellow)%aN %C(dim white)(%ar) %n%C(dim white)%S%n%B%n'
|
||||
lscommits = ! ( echo -e "Commits\tFile" && git log --pretty=format: --name-only | sed '/^$/d' | sort | uniq -c | sort -g -r ) | less
|
||||
lsc = lscommits
|
||||
diff-against = diff --merge-base
|
||||
fix-recreated-branch = reset --hard @{u}
|
||||
fa = fetch --all
|
||||
pa = pull --all
|
||||
c = commit
|
||||
aa = add .
|
||||
|
||||
[filter "lfs"]
|
||||
clean = git-lfs clean -- %f
|
||||
smudge = git-lfs smudge -- %f
|
||||
process = git-lfs filter-process
|
||||
required = true
|
||||
|
||||
[url "ssh://git@github.com/"]
|
||||
pushInsteadOf = https://github.com/
|
||||
|
||||
[credential "https://github.com"]
|
||||
helper =
|
||||
helper = !/usr/bin/gh auth git-credential
|
||||
|
||||
[credential "https://gist.github.com"]
|
||||
helper =
|
||||
helper = !/usr/bin/gh auth git-credential
|
||||
|
||||
[push]
|
||||
autoSetupRemote = true
|
7
configs/git/.mailmap
Normal file
7
configs/git/.mailmap
Normal file
@ -0,0 +1,7 @@
|
||||
Evan Pratten <evan@ewpratten.com>
|
||||
Evan Pratten <evan@ewpratten.com> <ewpratten@gmail.com>
|
||||
William Meathrel <wcmeathrel@gmail.com> <Wcmeathrel@gmail.com>
|
||||
Carter Tomlenovich <cartertom@tuta.io>
|
||||
James Nickoli <jnick722547@gmail.com>
|
||||
Sam Lownie <slownie16@gmail.com>
|
||||
Sam Lownie <slownie16@gmail.com> <30960735+slownie@users.noreply.github.com>
|
6
configs/git/config-fragments/enable-signing.gitconfig
Normal file
6
configs/git/config-fragments/enable-signing.gitconfig
Normal file
@ -0,0 +1,6 @@
|
||||
[gpg]
|
||||
format = ssh
|
||||
|
||||
[gpg "ssh"]
|
||||
allowedSignersFile = ~/.ssh/allowed_signers
|
||||
defaultKeyCommand = ssh-add -L
|
4
configs/git/config-fragments/global-mailmap.gitconfig
Normal file
4
configs/git/config-fragments/global-mailmap.gitconfig
Normal file
@ -0,0 +1,4 @@
|
||||
# Feel free to overwrite this file. It is only copied once.
|
||||
|
||||
[mailmap]
|
||||
file = ~/.config/git/.mailmap
|
10
configs/git/config-fragments/personal-info.gitconfig
Normal file
10
configs/git/config-fragments/personal-info.gitconfig
Normal file
@ -0,0 +1,10 @@
|
||||
[user]
|
||||
email = evan@ewpratten.com
|
||||
name = Evan Pratten
|
||||
signingkey = ~/.ssh/id_ed25519_sk_rk_yk20572395
|
||||
|
||||
[sendemail]
|
||||
smtpserver = smtp.migadu.com
|
||||
smtpuser = evan@ewpratten.com
|
||||
smtpencryption = tls
|
||||
smtpserverport = 587
|
79
configs/gnome/desktop-settings.sh
Normal file
79
configs/gnome/desktop-settings.sh
Normal file
@ -0,0 +1,79 @@
|
||||
#! /bin/sh
|
||||
# This script configures GNOME to my liking
|
||||
set -e
|
||||
|
||||
# Require gsettings
|
||||
if ! command -v gsettings >/dev/null 2>&1; then
|
||||
echo "gsettings is not installed, skipping some GNOME configuration"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# Mouse settings
|
||||
gsettings set org.gnome.desktop.interface gtk-enable-primary-paste true # Middle click paste
|
||||
gsettings set org.gnome.desktop.peripherals.touchpad disable-while-typing false # Allow touchpad while typing
|
||||
gsettings set org.gnome.desktop.peripherals.touchpad natural-scroll false # Disable natural scrolling on touchpad
|
||||
gsettings set org.gnome.desktop.peripherals.touchpad tap-to-click true # Enable tap-to-click on touchpad
|
||||
gsettings set org.gnome.desktop.interface show-battery-percentage true # Show battery percentage
|
||||
|
||||
# Disable application switching with Super+num keyy
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-1 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-2 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-3 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-4 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-5 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-6 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-7 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-8 "[]"
|
||||
gsettings set org.gnome.shell.keybindings switch-to-application-9 "[]"
|
||||
|
||||
# Keyboard settings
|
||||
gsettings set org.gnome.desktop.wm.keybindings close "['<Super><Shift>q']" # Close windows with Mod+Shift+q
|
||||
gsettings set org.gnome.desktop.wm.keybindings move-to-workspace-1 "['<Shift><Super>exclam']" # Move a window to ws 1
|
||||
gsettings set org.gnome.desktop.wm.keybindings move-to-workspace-2 "['<Shift><Super>at']" # Move a window to ws 2
|
||||
gsettings set org.gnome.desktop.wm.keybindings move-to-workspace-3 "['<Shift><Super>numbersign']" # Move a window to ws 3
|
||||
gsettings set org.gnome.desktop.wm.keybindings move-to-workspace-4 "['<Shift><Super>dollar']" # Move a window to ws 4
|
||||
gsettings set org.gnome.desktop.wm.keybindings switch-to-workspace-1 "['<Super>1']" # Switch to ws 1
|
||||
gsettings set org.gnome.desktop.wm.keybindings switch-to-workspace-2 "['<Super>2']" # Switch to ws 2
|
||||
gsettings set org.gnome.desktop.wm.keybindings switch-to-workspace-3 "['<Super>3']" # Switch to ws 3
|
||||
gsettings set org.gnome.desktop.wm.keybindings switch-to-workspace-4 "['<Super>4']" # Switch to ws 4
|
||||
|
||||
# Match the Windows screenshot behavior while also allowing the regular print screen key to work
|
||||
gsettings set org.gnome.shell.keybindings show-screenshot-ui "['<Shift><Super>s', 'Print']"
|
||||
|
||||
# Generate custom keybinds if they do not yet exist
|
||||
keybindings=$(gsettings get org.gnome.settings-daemon.plugins.media-keys custom-keybindings)
|
||||
if [ "$keybindings" = "[]" ] || [ "$keybindings" = "@as []" ]; then
|
||||
# Define the list of custom keybindings
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys custom-keybindings "['/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom0/', '/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom1/' , '/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom2/']"
|
||||
|
||||
# Allow Mod+Enter to open a terminal
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom0/ name "Terminal"
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom0/ command "gnome-terminal"
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom0/ binding "<Super>Return"
|
||||
|
||||
# Allow Mod+d to launch rofi
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom1/ name "Rofi"
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom1/ command "rofi -show drun"
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom1/ binding "<Super>d"
|
||||
|
||||
# Allow Mod+Shift+Enter to open python
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom2/ name "Python REPL"
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom2/ command "gnome-terminal -- $EWCONFIG_ROOT/.config/ewconfig/scripts/tinker"
|
||||
gsettings set org.gnome.settings-daemon.plugins.media-keys.custom-keybinding:/org/gnome/settings-daemon/plugins/media-keys/custom-keybindings/custom2/ binding "<Super><Shift>Return"
|
||||
fi
|
||||
|
||||
# Top Bar settings
|
||||
gsettings set org.gnome.desktop.interface clock-format 24h # 24 hour clock
|
||||
gsettings set org.gnome.desktop.interface clock-show-date true # Show date in top bar
|
||||
gsettings set org.gnome.desktop.interface clock-show-weekday true # Show weekday in top bar
|
||||
|
||||
# Window settings
|
||||
gsettings set org.gnome.desktop.wm.preferences focus-mode 'sloppy' # Focus windows on mouse hover
|
||||
gsettings set org.gnome.desktop.wm.preferences auto-raise false # Don't auto-raise windows
|
||||
|
||||
# Desktop settings
|
||||
gsettings set org.gnome.desktop.interface enable-hot-corners false # Disable hot corners
|
||||
gsettings set org.gnome.mutter edge-tiling true # Enable edge tiling
|
||||
gsettings set org.gnome.mutter dynamic-workspaces false # Use a fixed number of workspaces
|
||||
gsettings set org.gnome.desktop.wm.preferences num-workspaces 4 # Use 4 workspaces
|
||||
gsettings set org.gnome.mutter workspaces-only-on-primary true # Only use workspaces on primary monitor
|
15
configs/gnome/gnome-terminal-settings.sh
Normal file
15
configs/gnome/gnome-terminal-settings.sh
Normal file
@ -0,0 +1,15 @@
|
||||
#! /bin/sh
|
||||
set -e
|
||||
|
||||
# Get the path to this script
|
||||
SCRIPT_PATH="$( cd "$(dirname "$0")" >/dev/null 2>&1 ; pwd -P )"
|
||||
|
||||
# Check if dconf is available
|
||||
if ! command -v dconf >/dev/null 2>&1; then
|
||||
echo "dconf is not installed, skipping GNOME configuration"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# Configure gnome-terminal
|
||||
echo "Writing gnome-terminal settings..."
|
||||
dconf load "/org/gnome/terminal/" < $SCRIPT_PATH/terminal/terminal.dconf
|
7
configs/gnome/terminal/terminal.dconf
Normal file
7
configs/gnome/terminal/terminal.dconf
Normal file
@ -0,0 +1,7 @@
|
||||
[legacy/profiles:/:b1dcc9dd-5262-4d8d-a863-c897e6d979b9]
|
||||
custom-command='/usr/bin/zsh'
|
||||
default-size-columns=100
|
||||
default-size-rows=40
|
||||
login-shell=true
|
||||
use-custom-command=true
|
||||
visible-name='Default'
|
13
configs/helix/config.toml
Normal file
13
configs/helix/config.toml
Normal file
@ -0,0 +1,13 @@
|
||||
[editor]
|
||||
mouse = true
|
||||
middle-click-paste = true
|
||||
line-number = "absolute"
|
||||
auto-completion = true
|
||||
auto-format = false
|
||||
|
||||
[editor.cursor-shape]
|
||||
normal = "block"
|
||||
insert = "bar"
|
||||
select = "block"
|
||||
|
||||
|
1
configs/houdini19.5/scripts/456.cmd
Normal file
1
configs/houdini19.5/scripts/456.cmd
Normal file
@ -0,0 +1 @@
|
||||
preference general.desk.val "Solaris"
|
17
configs/houdini19.5/scripts/post_frame_usdnc_to_usd.py
Normal file
17
configs/houdini19.5/scripts/post_frame_usdnc_to_usd.py
Normal file
@ -0,0 +1,17 @@
|
||||
from pxr import Usd
|
||||
from pathlib import Path
|
||||
|
||||
# Figure out what file just got exported
|
||||
# NOTE: The filename the user enters is not the actual filename due to the NC suffix
|
||||
output_file_field = Path(hou.pwd().parm("lopoutput").eval())
|
||||
rendered_file = output_file_field.with_suffix(".usdnc")
|
||||
print(f"[USDNC To USD]: Converting {rendered_file} to USD")
|
||||
|
||||
# Load the rendered stage
|
||||
print("[USDNC To USD]: Loading stage")
|
||||
stage = Usd.Stage.Open(str(rendered_file))
|
||||
|
||||
# Write it again with the appropriate extension
|
||||
output_file = rendered_file.with_suffix(output_file_field.suffix)
|
||||
print(f"[USDNC To USD]: Exporting to: {output_file}")
|
||||
stage.Export(str(output_file))
|
54
configs/logid/logid.cfg
Normal file
54
configs/logid/logid.cfg
Normal file
@ -0,0 +1,54 @@
|
||||
devices: (
|
||||
{
|
||||
name: "M720 Triathlon Multi-Device Mouse",
|
||||
hiresscroll: {
|
||||
hires: true,
|
||||
invert: false,
|
||||
target: false
|
||||
},
|
||||
dpi: 1000,
|
||||
|
||||
buttons: (
|
||||
# Back
|
||||
{
|
||||
cid: 0x53,
|
||||
action: {
|
||||
type: "None"
|
||||
}
|
||||
},
|
||||
|
||||
# Forward
|
||||
{
|
||||
cid: 0x56,
|
||||
action: {
|
||||
type: "None"
|
||||
}
|
||||
},
|
||||
|
||||
# Left Scroll
|
||||
{
|
||||
cid: 0x5b,
|
||||
action: {
|
||||
type: "Keypress",
|
||||
keys: [ "BTN_MIDDLE" ]
|
||||
}
|
||||
},
|
||||
|
||||
# Right Scroll
|
||||
{
|
||||
cid: 0x5d,
|
||||
action: {
|
||||
type: "None"
|
||||
}
|
||||
},
|
||||
|
||||
# Squeeze
|
||||
{
|
||||
cid: 0xd0,
|
||||
action: {
|
||||
type: "None"
|
||||
}
|
||||
},
|
||||
)
|
||||
}
|
||||
);
|
BIN
configs/memegen/fonts/impact.ttf
Normal file
BIN
configs/memegen/fonts/impact.ttf
Normal file
Binary file not shown.
17
configs/memegen/templates/bernie-asking/config.json
Normal file
17
configs/memegen/templates/bernie-asking/config.json
Normal file
@ -0,0 +1,17 @@
|
||||
{
|
||||
"font": "impact.ttf",
|
||||
"fill_color": [255, 255, 255],
|
||||
"stroke_color": [0, 0, 0],
|
||||
"stroke_width": 2,
|
||||
"zones": {
|
||||
"bottom": {
|
||||
"horizontal_align": "center",
|
||||
"horizontal_offset": 0,
|
||||
"vertical_align": "bottom",
|
||||
"vertical_offset": -50,
|
||||
"width": "80%",
|
||||
"max_line_height": 50,
|
||||
"line_spacing": 5
|
||||
}
|
||||
}
|
||||
}
|
BIN
configs/memegen/templates/bernie-asking/template.png
Normal file
BIN
configs/memegen/templates/bernie-asking/template.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 414 KiB |
34
configs/memegen/templates/hotline-bling/config.json
Normal file
34
configs/memegen/templates/hotline-bling/config.json
Normal file
@ -0,0 +1,34 @@
|
||||
{
|
||||
"font": "impact.ttf",
|
||||
"fill_color": [
|
||||
0,
|
||||
0,
|
||||
0
|
||||
],
|
||||
"stroke_color": [
|
||||
0,
|
||||
0,
|
||||
0
|
||||
],
|
||||
"stroke_width": 0,
|
||||
"zones": {
|
||||
"top": {
|
||||
"horizontal_align": "right",
|
||||
"horizontal_offset": -5,
|
||||
"vertical_align": "top",
|
||||
"vertical_offset": 75,
|
||||
"width": "45%",
|
||||
"max_line_height": 50,
|
||||
"line_spacing": 5
|
||||
},
|
||||
"bottom": {
|
||||
"horizontal_align": "right",
|
||||
"horizontal_offset": -5,
|
||||
"vertical_align": "bottom",
|
||||
"vertical_offset": -75,
|
||||
"width": "45%",
|
||||
"max_line_height": 50,
|
||||
"line_spacing": 5
|
||||
}
|
||||
}
|
||||
}
|
BIN
configs/memegen/templates/hotline-bling/template.png
Normal file
BIN
configs/memegen/templates/hotline-bling/template.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 107 KiB |
17
configs/memegen/templates/megamind/config.json
Normal file
17
configs/memegen/templates/megamind/config.json
Normal file
@ -0,0 +1,17 @@
|
||||
{
|
||||
"font": "impact.ttf",
|
||||
"fill_color": [255, 255, 255],
|
||||
"stroke_color": [0, 0, 0],
|
||||
"stroke_width": 2,
|
||||
"zones": {
|
||||
"top": {
|
||||
"horizontal_align": "center",
|
||||
"horizontal_offset": 0,
|
||||
"vertical_align": "top",
|
||||
"vertical_offset": 5,
|
||||
"width": "80%",
|
||||
"max_line_height": 80,
|
||||
"line_spacing": 5
|
||||
}
|
||||
}
|
||||
}
|
BIN
configs/memegen/templates/megamind/template.png
Normal file
BIN
configs/memegen/templates/megamind/template.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 166 KiB |
14
configs/minecraft/XaeroWaypoints/Multiplayer_[§§]/config.txt
Normal file
14
configs/minecraft/XaeroWaypoints/Multiplayer_[§§]/config.txt
Normal file
@ -0,0 +1,14 @@
|
||||
//waypoints config options
|
||||
usingMultiworldDetection:false
|
||||
ignoreServerLevelId:false
|
||||
defaultMultiworldId:mw-4,0,2
|
||||
teleportationEnabled:true
|
||||
usingDefaultTeleportCommand:true
|
||||
sortType:NONE
|
||||
sortReversed:false
|
||||
|
||||
//other config options
|
||||
ignoreHeightmaps:false
|
||||
|
||||
//dimension types (DO NOT EDIT)
|
||||
dimensionType:minecraft$overworld:minecraft$overworld
|
@ -0,0 +1,3 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:visibility_type:destination
|
||||
#
|
@ -0,0 +1,14 @@
|
||||
//waypoints config options
|
||||
usingMultiworldDetection:false
|
||||
ignoreServerLevelId:false
|
||||
defaultMultiworldId:mw-13,1,0
|
||||
teleportationEnabled:true
|
||||
usingDefaultTeleportCommand:true
|
||||
sortType:NONE
|
||||
sortReversed:false
|
||||
|
||||
//other config options
|
||||
ignoreHeightmaps:false
|
||||
|
||||
//dimension types (DO NOT EDIT)
|
||||
dimensionType:minecraft$overworld:minecraft$overworld
|
@ -0,0 +1,7 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:visibility_type:destination
|
||||
#
|
||||
waypoint:horse parking:H:970:68:2059:6:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Home:H:-1647:98:-339:2:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Village:V:-1575:64:-409:5:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Spawn:S:-762:77:77:0:false:0:gui.xaero_default:false:0:0:false
|
@ -0,0 +1,7 @@
|
||||
usingMultiworldDetection:true
|
||||
ignoreServerLevelId:false
|
||||
teleportationEnabled:true
|
||||
usingDefaultTeleportCommand:true
|
||||
sortType:NONE
|
||||
sortReversed:false
|
||||
|
@ -0,0 +1,17 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:global
|
||||
#
|
||||
waypoint:Anarchy:A:79:128:328:13:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Other roof hole:O:147:128:296:1:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Carter:C:-125:128:-164:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Percy:P:-42:132:223:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:cat:C:-51:128:536:5:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Mountain Base:M:-172:131:6:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:james:J:-63:131:-64:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Ladder to Top:L:-92:89:-30:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:te:T:6:38:251:4:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:ice portal:I:-650:128:-250:3:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:End:E:-213:131:-78:12:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Home:H:-24:132:128:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Spawn Portal:S:-74:83:2:0:false:0:gui.xaero_default:false:0:false
|
||||
|
@ -0,0 +1,6 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:global
|
||||
#
|
||||
waypoint:jake:J:-32:131:-110:9:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Home:H:-10:132:129:5:false:0:gui.xaero_default:false:0:false
|
||||
|
@ -0,0 +1,39 @@
|
||||
sets:gui.xaero_default:RemotePlayers_Temp:Bases
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:global
|
||||
#
|
||||
waypoint:Anarchy:A:687:32:2547:13:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Nice spot:N:257:81:319:14:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Carter:C:-994:65:-1305:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Ice portal:I:-5201:86:-1988:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Percy:P:-327:71:1801:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Cat's Secret Base:C:-450:64:4368:12:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Squid Farm:S:1140:64:-1625:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Chicken Farm:C:-267:55:150:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:t:T:-2391:80:1305:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Sally:S:-1439:64:-59:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Skeleton Farm:S:1718:70:384:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:CommonOctopus:C:1662:68:306:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Totem farm:T:-38:71:1656:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Wills monument:W:-1909:56:798:3:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Monument:M:2799:52:1376:3:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Will:W:-483:62:338:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Tyson:T:3298:178:-2820:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Sydney:S:-1748:110:320:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Ethan:E:-1447:67:-830:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Ian:I:162:105:-125:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Cat:C:-278:70:-290:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Turtles:T:-1761:65:40:15:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Trident Farm:T:97:200:-2280:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Test Site:T:-841:65:1421:15:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Zombie Farm:Z:-475:26:1021:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Mountain Base:M:-1304:79:-7:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Jake:J:-435:69:-851:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:James:J:-501:66:-514:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Nether Fortress:G:307:83:1452:6:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:End Portal:E:-1712:31:-622:6:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Large Village:V:331:63:1396:4:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Evan:H:-170:63:1038:10:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Community Centre:C:-499:67:79:12:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:test:T:-144:68:1024:5:false:0:Bases:false:0:false
|
||||
|
@ -0,0 +1,6 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:global
|
||||
#
|
||||
waypoint:gui.xaero_deathpoint:D:-471:65:76:0:false:1:gui.xaero_default:false:0:true
|
||||
waypoint:gui.xaero_deathpoint_old:D:-200:70:0:0:false:0:gui.xaero_default:false:0:true
|
||||
|
@ -0,0 +1,4 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:global
|
||||
#
|
||||
|
@ -0,0 +1,10 @@
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:global
|
||||
#
|
||||
waypoint:e:E:392:49:-2200:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:XP Farm:X:375:1:-8:0:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:Portal:P:0:68:0:5:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:another portal:A:289:60:1365:2:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:island:I:-576:62:1050:3:false:0:gui.xaero_default:false:0:false
|
||||
waypoint:island:I:-576:62:1050:12:false:0:gui.xaero_default:false:0:false
|
||||
|
@ -0,0 +1,17 @@
|
||||
//waypoints config options
|
||||
usingMultiworldDetection:false
|
||||
ignoreServerLevelId:false
|
||||
defaultMultiworldId:mw-3,1,-4
|
||||
teleportationEnabled:true
|
||||
usingDefaultTeleportCommand:false
|
||||
serverTeleportCommandFormat:^col^warp add {x},{y},{z}
|
||||
serverTeleportCommandRotationFormat:^col^warp add {x},{y},{z}
|
||||
sortType:NONE
|
||||
sortReversed:false
|
||||
|
||||
//other config options
|
||||
ignoreHeightmaps:false
|
||||
|
||||
//dimension types (DO NOT EDIT)
|
||||
dimensionType:minecraft$overworld:minecraft$overworld
|
||||
dimensionType:minecraft$the_end:minecraft$the_end
|
@ -0,0 +1,115 @@
|
||||
sets:gui.xaero_default:Buildings:Subway Stations
|
||||
#
|
||||
#waypoint:name:initials:x:y:z:color:disabled:type:set:rotate_on_tp:tp_yaw:visibility_type:destination
|
||||
#
|
||||
waypoint:Iron Farm:I:-186:57:-217:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Spawn Inn:S:-136:70:-233:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Kenny Rogers Roaster:K:-156:70:-233:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:ITC:I:-159:70:-223:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Dojo St Cafe:D:-239:67:-193:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Jacob's Residence:J:-221:69:-220:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Dojo St Subway Station:D:-235:69:-232:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Schwa Corp HQ:S:-238:71:-254:8:false:0:Buildings:false:0:0:false
|
||||
waypoint:Northern & Bee Station:S:-252:56:-433:8:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Monument Place Station:S:-220:95:-186:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[ZOG] Zombie Grinder Station:S:-236:3:-181:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[PMI] Prismarine Inn Station:S:-204:63:578:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[DSW] Dismal Swamp Station:S:-322:63:364:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[APY] Apiary Station:S:-322:63:41:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[APY] Apiary Station:S:-316:60:43:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Southwest Blvd:S:-270:64:5:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Southlands:S:-263:64:-45:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Three Sisters:S:-263:64:-85:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Small Hall Station:S:-268:65:-127:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Monument Place Station:S:-256:65:-151:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Zombie Grinder Station:S:-256:65:-180:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:DOJO St Station:S:-242:69:-227:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:New Cornick House Station:S:-202:66:-229:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Wintergarden Station:S:-184:62:-243:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[PRU] Pine Ruins Station:S:225:38:-293:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[CSD] Canalside Station:S:143:38:-291:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Central Station:S:-213:42:-264:15:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[SWL] Southwest Landing Station:S:-510:63:137:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[APY] Apiary Station:S:-326:63:41:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[ZOG] Zombie Grinder Station:S:-229:3:-181:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[WCP] Whitecaps Station:S:-27:83:63:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[MTV] Mountain Village Station:S:-27:38:7:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[ESJ] Eastside Transfer:S:-31:38:-237:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[SOU] Southlands Terminal:S:-245:42:-49:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Monument Place Station:S:-218:43:-137:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Central Station:S:-213:42:-252:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Mountain Station:S:-899:111:-607:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Mensa Club Station:S:-900:111:-4187:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-900:109:-2320:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Farmington Station:S:-1630:107:-2316:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Village Layover Station:S:-2143:97:-2315:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Twin Peaks Station:S:-2135:97:-1015:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Witchy Swamp Station:S:-2143:97:-1523:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Ocean Overlook Station:S:-2726:106:-186:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-2111:106:-186:8:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:End Portal Station:S:927:97:1223:12:false:0:Subway Stations:false:0:1:false
|
||||
waypoint:Craniumslows Station:S:-1048:97:-94:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-1048:97:-186:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-1375:97:-188:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Sheep Station:S:-1372:97:507:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Cow Station:S:-1372:97:659:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-1033:98:1087:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:South Station:S:-1372:98:1088:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:1567 Station:S:-1568:97:909:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Magenta Station:S:-1372:97:908:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-980:97:907:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Un-Named Interchange:I:-891:95:-187:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Dark Oak Station:S:-700:97:-185:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Cat Ave Station:S:-536:96:-187:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:End of Line:S:-220:97:1176:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Unknown Station:S:-220:97:6:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Glider Port Station:S:-219:97:-254:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Bell Bridge / Changa Station:S:-219:97:-375:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Eccentric Genius Station:S:-219:96:-481:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Xiled Station:S:-219:97:-552:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Nopantsistan Station:S:-219:98:-650:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[HLV] Highland Village Station:S:-220:97:-1797:12:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[MSW] Mid-Swamp Station:S:-187:41:-1254:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[JOT] Jotaku Station:S:-187:42:-782:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NSX] Northside Transfer Station:S:-197:42:-719:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Central Station:S:-217:56:-275:6:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NRV] North River Station:S:-245:38:-366:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[CMK] Central Market Station:S:-245:38:-258:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Monument Place Station:S:-219:35:-137:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Monument Place Station:S:-220:43:-137:10:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Survey Hall Station:S:-120:59:-481:10:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Inventory Station:S:-143:43:-304:10:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Square Station:S:-115:53:-256:10:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Tek Square Station:S:63:65:-215:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Manor Ave Station:S:-36:58:-225:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Square Station:S:-141:58:-225:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:DOJO St Station:S:-221:56:-226:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Mob St Station:S:-389:64:-222:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[CAT] Cat Ave Station:S:-491:64:-222:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Garfield Station:S:-624:73:310:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Castle Square Station:S:-616:61:-222:9:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[CHA] Changa Station:S:-187:42:-373:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[ECG] Eccentric Genius:S:-187:42:-477:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[XIL] Xiled Station:S:-187:42:-575:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NOP] Nopantsistan Station:S:-187:42:-662:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NSX] Northside Transfer:S:-187:42:-720:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NPN] Nopantsistan Station:S:-245:38:-665:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[LAY] Laydros Station:S:-245:38:-543:5:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Red Station:S:-900:109:-1992:8:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NSC] North Shore City Terminal:S:-72:42:-1946:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NSJ] North Shore Junction:J:-183:39:-1949:8:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[HLV] Highland Village Station:S:-187:41:-1736:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[NDK] North Docks Station:S:-187:41:-1519:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[BOH] Boathouse Station:S:-187:42:-839:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:[RST] Riverside Station:S:-189:42:-321:14:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Spawn Central Station:S:-213:42:-258:13:false:0:Subway Stations:false:0:0:false
|
||||
waypoint:Slime Farm:S:4975:4:5854:1:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Northern Village:N:37:74:-10056:8:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Creeper Farm:C:5092:5:5481:9:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Warp Room:W:-4328:7:-2168:14:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:New Base:N:-532:73:-2308:4:false:0:gui.xaero_default:false:0:1:false
|
||||
waypoint:Percy Home:X:-131:66:-102:9:false:0:gui.xaero_default:false:0:1:false
|
||||
waypoint:End Portal:E:921:23:1221:5:false:0:gui.xaero_default:false:0:0:false
|
||||
waypoint:Miwu Home:M:-287:77:-432:9:false:0:gui.xaero_default:false:0:1:false
|
||||
waypoint:Home:H:-198:69:-303:9:false:0:gui.xaero_default:false:0:1:false
|
||||
waypoint:Spawn:*:-137:70:-256:0:false:0:gui.xaero_default:false:0:1:false
|
@ -0,0 +1,14 @@
|
||||
//waypoints config options
|
||||
usingMultiworldDetection:false
|
||||
ignoreServerLevelId:false
|
||||
defaultMultiworldId:mw0,1,0
|
||||
teleportationEnabled:true
|
||||
usingDefaultTeleportCommand:true
|
||||
sortType:NONE
|
||||
sortReversed:false
|
||||
|
||||
//other config options
|
||||
ignoreHeightmaps:false
|
||||
|
||||
//dimension types (DO NOT EDIT)
|
||||
dimensionType:minecraft$overworld:minecraft$overworld
|
50
configs/minecraft/scripts/mc_postexit.py
Normal file
50
configs/minecraft/scripts/mc_postexit.py
Normal file
@ -0,0 +1,50 @@
|
||||
#! /usr/bin/env python
|
||||
import argparse
|
||||
import sys
|
||||
import os
|
||||
import shutil
|
||||
from pathlib import Path
|
||||
|
||||
MINECRAFT_DIR = Path(os.environ["INST_MC_DIR"])
|
||||
WAYPOINT_BASE_DIR = MINECRAFT_DIR / "XaeroWaypoints"
|
||||
GLOBAL_WAYPOINT_DIR = (
|
||||
Path(os.path.expanduser("~")) / ".config" / "minecraft" / "XaeroWaypoints"
|
||||
)
|
||||
|
||||
|
||||
def main() -> int:
|
||||
# Handle program arguments
|
||||
ap = argparse.ArgumentParser(description="Post-exit tasks for Minecraft")
|
||||
args = ap.parse_args()
|
||||
print("[EWCONFIG] Executing post-exit tasks for Minecraft")
|
||||
print(f"[EWCONFIG] Minecraft directory: {MINECRAFT_DIR}")
|
||||
|
||||
# If the waypoint base dir doesn't exist, we don't need to do anything
|
||||
if not WAYPOINT_BASE_DIR.exists():
|
||||
print("[EWCONFIG] No waypoints to sync")
|
||||
return 0
|
||||
|
||||
# Find all multiplayer waypoint dirs
|
||||
multiplayer_waypoints = [
|
||||
directory
|
||||
for directory in WAYPOINT_BASE_DIR.iterdir()
|
||||
if directory.is_dir() and directory.name.startswith("Multiplayer")
|
||||
]
|
||||
print(
|
||||
f"[EWCONFIG] Found {len(multiplayer_waypoints)} multiplayer waypoint directories"
|
||||
)
|
||||
|
||||
# Copy the contents of each multiplayer waypoint dir to the global storage
|
||||
for waypoint_dir in multiplayer_waypoints:
|
||||
dest_dir = GLOBAL_WAYPOINT_DIR / waypoint_dir.name
|
||||
print(f"[EWCONFIG] Copying {waypoint_dir} to {dest_dir}")
|
||||
|
||||
# Use shutil to copy the directory
|
||||
dest_dir.mkdir(parents=True, exist_ok=True)
|
||||
shutil.copytree(waypoint_dir, dest_dir, dirs_exist_ok=True)
|
||||
|
||||
return 0
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
sys.exit(main())
|
31
configs/minecraft/scripts/mc_prelaunch.py
Normal file
31
configs/minecraft/scripts/mc_prelaunch.py
Normal file
@ -0,0 +1,31 @@
|
||||
#! /usr/bin/env python
|
||||
import argparse
|
||||
import sys
|
||||
import os
|
||||
import shutil
|
||||
from pathlib import Path
|
||||
|
||||
MINECRAFT_DIR = Path(os.environ["INST_MC_DIR"])
|
||||
WAYPOINT_BASE_DIR = MINECRAFT_DIR / "XaeroWaypoints"
|
||||
GLOBAL_WAYPOINT_DIR = (
|
||||
Path(os.path.expanduser("~")) / ".config" / "minecraft" / "XaeroWaypoints"
|
||||
)
|
||||
|
||||
|
||||
def main() -> int:
|
||||
# Handle program arguments
|
||||
ap = argparse.ArgumentParser(description="Pre-launch tasks for Minecraft")
|
||||
args = ap.parse_args()
|
||||
print("[EWCONFIG] Executing pre-launch tasks for Minecraft")
|
||||
print(f"[EWCONFIG] Minecraft directory: {MINECRAFT_DIR}")
|
||||
|
||||
# Copy the global waypoint dir on top of the base waypoint dir
|
||||
print(f"[EWCONFIG] Copying {GLOBAL_WAYPOINT_DIR} to {WAYPOINT_BASE_DIR}")
|
||||
WAYPOINT_BASE_DIR.mkdir(parents=True, exist_ok=True)
|
||||
shutil.copytree(GLOBAL_WAYPOINT_DIR, WAYPOINT_BASE_DIR, dirs_exist_ok=True)
|
||||
|
||||
return 0
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
sys.exit(main())
|
36
configs/nautilus/scripts/Copy to web
Executable file
36
configs/nautilus/scripts/Copy to web
Executable file
@ -0,0 +1,36 @@
|
||||
#! /bin/bash
|
||||
set -e
|
||||
|
||||
WEBSERVER_PATH=$HOME/www
|
||||
|
||||
# If NAUTILUS_SCRIPT_SELECTED_FILE_PATHS is empty, error and exit
|
||||
if [ -z "$NAUTILUS_SCRIPT_SELECTED_FILE_PATHS" ]; then
|
||||
notify-send "Copy to web" "No local files selected"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# For every file in NAUTILUS_SCRIPT_SELECTED_FILE_PATHS
|
||||
echo "$NAUTILUS_SCRIPT_SELECTED_FILE_PATHS" | while read file; do
|
||||
# Get the last segment of the path
|
||||
filename=$(basename "$file")
|
||||
|
||||
# If the file comes from ~/Pictures/Screenshots, use a path in ~/$WEBSERVER_PATH/screenshots
|
||||
if [[ "$file" == "$HOME/Pictures/Screenshots/"* ]]; then
|
||||
OUTPUT_PATH="$WEBSERVER_PATH/screenshots/$filename"
|
||||
RES_PATH="/screenshots/$filename"
|
||||
mkdir -p "$WEBSERVER_PATH/screenshots"
|
||||
else
|
||||
OUTPUT_PATH="$WEBSERVER_PATH/$filename"
|
||||
RES_PATH="/$filename"
|
||||
fi
|
||||
|
||||
# Copy the file to the webserver
|
||||
cp -r "$file" "$OUTPUT_PATH"
|
||||
|
||||
# Write the resource path to the clipbaord
|
||||
echo -n "$RES_PATH" | xsel -i -b
|
||||
|
||||
done
|
||||
|
||||
# Show a success message
|
||||
notify-send "Copy to web" "Files copied to ~/www"
|
4
configs/nautilus/scripts/Open in Video Trimmer
Executable file
4
configs/nautilus/scripts/Open in Video Trimmer
Executable file
@ -0,0 +1,4 @@
|
||||
#! /bin/bash
|
||||
set -e
|
||||
|
||||
python3 ~/.config/ewconfig/scripts/video_trimmer
|
5
configs/nautilus/scripts/Open with USDView
Executable file
5
configs/nautilus/scripts/Open with USDView
Executable file
@ -0,0 +1,5 @@
|
||||
#! /bin/sh
|
||||
set -e
|
||||
|
||||
usdview $NAUTILUS_SCRIPT_SELECTED_FILE_PATHS
|
||||
|
2
configs/nvim/.gitignore
vendored
Normal file
2
configs/nvim/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
/spell
|
||||
|
57
configs/nvim/init.vim
Normal file
57
configs/nvim/init.vim
Normal file
@ -0,0 +1,57 @@
|
||||
source ~/.vimrc
|
||||
|
||||
" Configure the right-click menu
|
||||
if !exists('g:vscode')
|
||||
aunmenu PopUp
|
||||
vnoremenu PopUp.Cut "+x
|
||||
vnoremenu PopUp.Copy "+y
|
||||
anoremenu PopUp.Paste "+gP
|
||||
vnoremenu PopUp.Paste "+P
|
||||
vnoremenu PopUp.Delete "_x
|
||||
nnoremenu PopUp.Select\ All> ggVG
|
||||
vnoremenu PopUp.Select\ All> gg0oG$
|
||||
inoremenu PopUp.Select\ All <C-Home><C-O>VG
|
||||
endif
|
||||
|
||||
" Custom syntax highlighting
|
||||
au BufRead,BufNewFile *.usd set filetype=usda
|
||||
au BufRead,BufNewFile *.usda set filetype=usda
|
||||
autocmd FileType usda source ~/.config/nvim/third_party/usda-syntax/vim/usda.vim
|
||||
|
||||
" Disable the gitgutter background
|
||||
let g:gitgutter_override_sign_column_highlight = 1
|
||||
highlight clear SignColumn
|
||||
|
||||
" Make gitgutter update on file save
|
||||
if !exists('g:vscode')
|
||||
autocmd BufWritePost * GitGutter
|
||||
endif
|
||||
|
||||
" Enable Leap
|
||||
lua require('leap').add_default_mappings()
|
||||
|
||||
" Enable Helix-style command suggestions
|
||||
"lua require('command-completion').setup()
|
||||
|
||||
" Enable trailing space detection
|
||||
lua require('mini.trailspace').setup()
|
||||
|
||||
" Configure floating window colours
|
||||
highlight Pmenu ctermbg=none ctermfg=white
|
||||
|
||||
" VSCode-style comment toggling
|
||||
nnoremap <C-_> :Commentary<CR>
|
||||
vnoremap <C-_> :Commentary<CR>
|
||||
inoremap <C-_> <C-O>:Commentary<CR>
|
||||
|
||||
" Custom functions
|
||||
function! MkdirAndWrite()
|
||||
let dir = expand('%:p:h')
|
||||
exec '!mkdir -p ' . dir
|
||||
exec 'w'
|
||||
endfunction
|
||||
command Wmk call MkdirAndWrite()
|
||||
|
||||
" LSP Support
|
||||
"lua require "lspconfig".rust_analyzer.setup {}
|
||||
"lua vim.keymap.set('n', '<space>e', vim.diagnostic.open_float)
|
1
configs/nvim/pack/airblade/start/vim-gitgutter
Submodule
1
configs/nvim/pack/airblade/start/vim-gitgutter
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit f7b97666ae36c7b3f262f3190dbcd7033845d985
|
@ -0,0 +1 @@
|
||||
Subproject commit 60d0eca6703b55285e33b0da00105cde50d188df
|
1
configs/nvim/pack/ggandor/start/leap.nvim
Submodule
1
configs/nvim/pack/ggandor/start/leap.nvim
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 5efe985cf68fac3b6a6dfe7a75fbfaca8db2af9c
|
1
configs/nvim/pack/jiangmiao/start/auto-pairs
Submodule
1
configs/nvim/pack/jiangmiao/start/auto-pairs
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 39f06b873a8449af8ff6a3eee716d3da14d63a76
|
1
configs/nvim/pack/neovim/start/nvim-lspconfig
Submodule
1
configs/nvim/pack/neovim/start/nvim-lspconfig
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 8917d2c830e04bf944a699b8c41f097621283828
|
@ -0,0 +1 @@
|
||||
Subproject commit 56c98f8d59a88ed96a80d43abca74a60ba31ea3a
|
1
configs/nvim/pack/tpope/start/commentary
Submodule
1
configs/nvim/pack/tpope/start/commentary
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit e87cd90dc09c2a203e13af9704bd0ef79303d755
|
1
configs/nvim/pack/tpope/start/repeat
Submodule
1
configs/nvim/pack/tpope/start/repeat
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 24afe922e6a05891756ecf331f39a1f6743d3d5a
|
1
configs/nvim/third_party/usda-syntax
vendored
Submodule
1
configs/nvim/third_party/usda-syntax
vendored
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit deb110f0224235fcc19325b20885e566f911f84b
|
95
configs/python/python_startup.py
Normal file
95
configs/python/python_startup.py
Normal file
@ -0,0 +1,95 @@
|
||||
"""Python Startup file. Used to customize the Python REPL"""
|
||||
import sys
|
||||
import os
|
||||
|
||||
# Global stuff
|
||||
IS_IN_TINKER_MODE = bool(os.environ.get("PYTHON_TINKER_MODE"))
|
||||
COLOR_ALLOWED = not bool(os.environ.get("NO_COLOR"))
|
||||
|
||||
|
||||
def colored_string(text: str, color: str) -> str:
|
||||
if COLOR_ALLOWED:
|
||||
return "\033[" + color + "m" + text + "\033[0m"
|
||||
else:
|
||||
return text
|
||||
|
||||
|
||||
# Configure the prompt
|
||||
class Prompt:
|
||||
def __init__(self):
|
||||
self.prompt = colored_string(">>> ", "36")
|
||||
|
||||
def __str__(self):
|
||||
return self.prompt
|
||||
|
||||
|
||||
class MultiLinePrompt:
|
||||
def __str__(self):
|
||||
return colored_string("... ", "33")
|
||||
# return " "
|
||||
|
||||
|
||||
# Hook up the prompts
|
||||
sys.ps1 = Prompt()
|
||||
sys.ps2 = MultiLinePrompt()
|
||||
|
||||
# "Tinker mode" - automatically import common things
|
||||
if IS_IN_TINKER_MODE:
|
||||
print(
|
||||
colored_string(
|
||||
"Running in tinker mode. Additional modules are available.", "33"
|
||||
)
|
||||
)
|
||||
|
||||
# Basics
|
||||
import time
|
||||
import json
|
||||
from pathlib import Path
|
||||
from dataclasses import dataclass
|
||||
from typing import (
|
||||
List,
|
||||
Dict,
|
||||
Tuple,
|
||||
Set,
|
||||
Optional,
|
||||
Union,
|
||||
Any,
|
||||
Callable,
|
||||
Iterable,
|
||||
Generator,
|
||||
)
|
||||
from pprint import pprint
|
||||
from datetime import datetime
|
||||
from textwrap import dedent
|
||||
from base64 import b64encode, b64decode
|
||||
|
||||
# Math stuff
|
||||
try:
|
||||
import numpy as np
|
||||
|
||||
np.set_printoptions(suppress=True)
|
||||
_vec = lambda *fields: np.array([*fields])
|
||||
pi = np.pi
|
||||
except ImportError:
|
||||
pass
|
||||
try:
|
||||
from pyquaternion import Quaternion
|
||||
except ImportError:
|
||||
pass
|
||||
try:
|
||||
import matplotlib.pyplot as plt
|
||||
except ImportError:
|
||||
pass
|
||||
|
||||
|
||||
# If we aren't in tinker mode, un-import sys and os
|
||||
if not IS_IN_TINKER_MODE:
|
||||
del sys
|
||||
del os
|
||||
|
||||
# Clean up other stuff
|
||||
del IS_IN_TINKER_MODE
|
||||
del COLOR_ALLOWED
|
||||
del colored_string
|
||||
del Prompt
|
||||
del MultiLinePrompt
|
4
configs/rofi/config.rasi
Normal file
4
configs/rofi/config.rasi
Normal file
@ -0,0 +1,4 @@
|
||||
configuration {
|
||||
show-icons: false;
|
||||
}
|
||||
@theme "dmenu"
|
20
configs/shells/bash/.bashrc
Normal file
20
configs/shells/bash/.bashrc
Normal file
@ -0,0 +1,20 @@
|
||||
# This is a somewhat hacky bashrc that is used to provide some of the conveniences from my zshrc on machines that I can't get zsh on
|
||||
export EWCONFIG_ROOT="$HOME/.config/ewconfig"
|
||||
|
||||
# Show some host info
|
||||
. $EWCONFIG_ROOT/configs/shells/bash/info.sh
|
||||
|
||||
# Load macros
|
||||
. $EWCONFIG_ROOT/configs/shells/bash/macros.sh
|
||||
|
||||
# I always want my ~/bin to be in my PATH
|
||||
export PATH="$HOME/bin:$PATH"
|
||||
export PATH="$EWCONFIG_ROOT/scripts:$PATH"
|
||||
export PATH="$HOME/.local/bin:$PATH"
|
||||
|
||||
# I want to be able to load my custom python modules
|
||||
export PYTHONPATH="$EWCONFIG_ROOT/python_modules:$PYTHONPATH"
|
||||
export PYTHONSTARTUP="$EWCONFIG_ROOT/configs/python/python_startup.py"
|
||||
|
||||
# A basic prompt to display user@host dir sign
|
||||
export PS1="(${PS1_CTX:-bash}) \[\e[0;32m\]\u@\h \[\e[0;36m\]\w \[\e[0;36m\]\$ \[\e[0m\]"
|
33
configs/shells/bash/info.sh
Normal file
33
configs/shells/bash/info.sh
Normal file
@ -0,0 +1,33 @@
|
||||
|
||||
# Define red and green based on the shell
|
||||
if [ -n "$BASH_VERSION" ]; then
|
||||
red='\033[0;31m'
|
||||
green='\033[0;32m'
|
||||
reset_color='\033[0m'
|
||||
elif [ -n "$ZSH_VERSION" ]; then
|
||||
red="$fg[red]"
|
||||
green="$fg[green]"
|
||||
fi
|
||||
|
||||
# Different OSes have different ways of displaying info
|
||||
if [ $(uname -s | grep -c BSD) -gt 0 ]; then # BSD
|
||||
echo -e "${green}Platform:$reset_color $(uname -s) $(uname -r) $(uname -p)"
|
||||
|
||||
elif [ $(uname -o | grep -c Msys) -gt 0 ]; then # Windows
|
||||
echo -e "${green}Platform:$reset_color $(uname -o) $(uname -r)"
|
||||
|
||||
else # Linux-y things
|
||||
echo -e "${green}Platform:$reset_color $(uname -o) $(uname -r)"
|
||||
echo -e "${green}Uptime:$reset_color $(uptime -p)"
|
||||
fi
|
||||
|
||||
# Determine if $EWCONFIG_ROOT contains uncommitted changes
|
||||
# Skip this if on Windows
|
||||
if [ -d $EWCONFIG_ROOT/.git ]; then
|
||||
if [ $(uname -o | grep -c Msys) -eq 0 ]; then
|
||||
if [ -n "$(git -C $EWCONFIG_ROOT status --porcelain)" ]; then
|
||||
echo -e "${red}ewconfig contains uncommitted changes$reset_color"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
283
configs/shells/bash/macros.sh
Normal file
283
configs/shells/bash/macros.sh
Normal file
@ -0,0 +1,283 @@
|
||||
# If ls has `--color` support
|
||||
if ls --color > /dev/null 2>&1; then
|
||||
alias ls="ls --color=auto"
|
||||
fi
|
||||
|
||||
# Main aliases
|
||||
alias ll="ls -l"
|
||||
alias la="ls -a"
|
||||
alias :q="exit"
|
||||
alias :wq="exit"
|
||||
alias cls=clear
|
||||
alias bashreload="source ~/.bashrc"
|
||||
alias wg-easykeys="wg genkey | tee >(wg pubkey)"
|
||||
alias nvim-tmp="nvim $(mktemp)"
|
||||
alias flush-dns="sudo systemd-resolve --flush-caches"
|
||||
alias showsizes="du -h --max-depth=1"
|
||||
alias lsgrep="ls | grep"
|
||||
alias sheridan-rdp='firefox --new-window "ext+container:name=College&url=https://client.wvd.microsoft.com/arm/webclient/index.html"'
|
||||
alias git-diff-nvim="git diff | nvim -R -d -c 'set filetype=diff' -"
|
||||
alias yk-totp="ykman oath accounts code"
|
||||
alias flush-dns-cache="sudo systemd-resolve --flush-caches"
|
||||
alias which-ls="ls -la $(which ls)"
|
||||
alias rdns="dig +short -x"
|
||||
alias ufw-status="sudo ufw status numbered"
|
||||
alias genuuid="python -c 'import uuid; print(uuid.uuid4())'"
|
||||
alias clipboard="xclip -selection clipboard"
|
||||
alias filesize="du -hs"
|
||||
alias arp-watch="sudo tcpdump -nn -tt -q \"arp and arp[6:2] == 2\""
|
||||
alias snvim="sudoedit"
|
||||
|
||||
# WHOIS macros
|
||||
alias whois-afrinic="whois -h whois.afrinic.net"
|
||||
alias whois-altdb="whois -h whois.altdb.net"
|
||||
alias whois-aoltw="whois -h whois.aoltw.net"
|
||||
alias whois-ampr="whois -h whois.ampr.org"
|
||||
alias whois-apnic="whois -h whois.apnic.net"
|
||||
alias whois-arin="whois -h rr.arin.net"
|
||||
alias whois-bell="whois -h whois.in.bell.ca"
|
||||
alias whois-bboi="whois -h irr.bboi.net"
|
||||
alias whois-bgptools="whois -h bgp.tools"
|
||||
alias whois-canarie="whois -h whois.canarie.ca"
|
||||
alias whois-epoch="whois -h whois.epoch.net"
|
||||
alias whois-jpirr="whois -h jpirr.nic.ad.jp"
|
||||
alias whois-lacnic="whois -h irr.lacnic.net"
|
||||
alias whois-level3="whois -h rr.level3.net"
|
||||
alias whois-nestegg="whois -h whois.nestegg.net"
|
||||
alias whois-panix="whois -h rrdb.access.net"
|
||||
alias whois-radb="whois -h whois.radb.net"
|
||||
alias whois-reach="whois -h rr.telstraglobal.net"
|
||||
alias whois-ripe="whois -h whois.ripe.net"
|
||||
|
||||
# Neo-aliases
|
||||
if [ -x "$(command -v nvim)" ]; then alias vim="nvim"; fi
|
||||
if [ -x "$(command -v neomutt)" ]; then alias mutt="neomutt"; fi
|
||||
|
||||
# If python exists, configure an alias for python3 if needed
|
||||
if [ -x "$(command -v python)" ]; then
|
||||
# If `python --version` starts with `Python 3`
|
||||
if [[ $(python --version) == Python\ 3* ]]; then
|
||||
# If we don't have python3 in our path
|
||||
if ! command -v python3 &> /dev/null; then
|
||||
# Make an alias for python3
|
||||
alias python3=python
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# If we are running in a studio environment
|
||||
if [ ! -z "$EWP_IN_GURU_ENVIRONMENT" ]; then
|
||||
alias guru_launcher3="python $GURU_PYTHON_ROOT/env/guru_launcher3.py"
|
||||
alias cd-dev="cd /s/development/epratten"
|
||||
fi
|
||||
|
||||
# Kill via pgrep
|
||||
nkill() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: nkill <name>"
|
||||
else
|
||||
kill -9 $(pgrep $1)
|
||||
fi
|
||||
}
|
||||
|
||||
# Makes a directory, then moves into it
|
||||
mkcd() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: mkcd <dir>"
|
||||
else
|
||||
mkdir -p $1 && cd $1
|
||||
fi
|
||||
}
|
||||
|
||||
# Sources a .env
|
||||
source_env() {
|
||||
env=${1:-.env}
|
||||
[ ! -f "${env}" ] && { echo "Env file ${env} doesn't exist"; return 1; }
|
||||
eval $(sed -e '/^\s*$/d' -e '/^\s*#/d' -e 's/=/="/' -e 's/$/"/' -e 's/^/export /' "${env}")
|
||||
}
|
||||
|
||||
# Auto-extract anything
|
||||
extract() {
|
||||
if [ -f $1 ]; then
|
||||
case $1 in
|
||||
*.tar.bz2) tar xvjf $1 ;;
|
||||
*.tar.gz) tar xvzf $1 ;;
|
||||
*.bz2) bunzip2 $1 ;;
|
||||
*.rar) unrar x $1 ;;
|
||||
*.gz) gunzip $1 ;;
|
||||
*.tar) tar xvf $1 ;;
|
||||
*.tbz2) tar xvjf $1 ;;
|
||||
*.tgz) tar xvzf $1 ;;
|
||||
*.zip) unzip $1 ;;
|
||||
*.Z) uncompress $1 ;;
|
||||
*.7z) 7z x $1 ;;
|
||||
*.tar.zst) tar --use-compress-program=unzstd -xvf $1 ;;
|
||||
*.zst) zstd -d $1 ;;
|
||||
*) echo "don't know how to extract '$1'..." ;;
|
||||
esac
|
||||
else
|
||||
echo "'$1' is not a valid file!"
|
||||
fi
|
||||
}
|
||||
|
||||
# Generate a password
|
||||
genpass() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: genpass <len>"
|
||||
else
|
||||
echo $(openssl rand -base64 $1 | tr -d "\n")
|
||||
fi
|
||||
|
||||
}
|
||||
|
||||
# Sign a file with an SSH key
|
||||
ssh-sign(){
|
||||
if [ $# != 2 ]; then
|
||||
echo "Usage: ssh-sign <key_file> <file>"
|
||||
else
|
||||
if [ -f $2 ]; then
|
||||
cat $2 | ssh-keygen -Y sign -f $1 -n file -
|
||||
else
|
||||
>&2 echo "File not found: $2"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
# Verify a file, using the ~/.ssh/allowed_signers file
|
||||
ssh-verify(){
|
||||
if [ $# != 3 ]; then
|
||||
echo "Usage: ssh-verify <author> <sigfile> <file>"
|
||||
else
|
||||
ssh-keygen -Y verify -f ~/.ssh/allowed_signers -n file -I $1 -s $2 < $3
|
||||
fi
|
||||
}
|
||||
|
||||
# Fully restart a wireguard link
|
||||
wg-restart() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: wg-restart <interface>"
|
||||
else
|
||||
wg-quick down $1 || true;
|
||||
wg-quick up $1
|
||||
fi
|
||||
}
|
||||
|
||||
# Reload a wireguard link without stopping it
|
||||
wg-reload() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: wg-reload <interface>"
|
||||
else
|
||||
sudo wg syncconf $1 <(sudo wg-quick strip $1)
|
||||
fi
|
||||
}
|
||||
|
||||
# Edit a wireguard config file
|
||||
wg-edit() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: wg-edit <interface>"
|
||||
else
|
||||
sudoedit /etc/wireguard/$1.conf
|
||||
fi
|
||||
}
|
||||
|
||||
# Print a wireguard config file
|
||||
wg-cat() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: wg-cat <interface>"
|
||||
else
|
||||
sudo cat /etc/wireguard/$1.conf
|
||||
fi
|
||||
}
|
||||
|
||||
# Updates ewconfig
|
||||
ewconfig-pull() {
|
||||
cwd=$(pwd)
|
||||
cd ~/.config/ewconfig
|
||||
git pull ewp master
|
||||
cd $cwd
|
||||
}
|
||||
|
||||
# Updates the ewconfig on machines that don't have git
|
||||
ewconfig-pull-zip(){
|
||||
cwd=$(pwd)
|
||||
# If $EWCONFIG_ROOT/.git exists, don't let the user run this
|
||||
if [ -d $EWCONFIG_ROOT/.git ]; then
|
||||
echo "You can't run this command when ~/.config/ewconfig is a git repo!"
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Download the latest zip
|
||||
cd ~/Downloads
|
||||
curl -L https://ewp.fyi/config.zip -o ewconfig.zip
|
||||
rm -rf ~/.config/ewconfig
|
||||
unzip ewconfig.zip
|
||||
mv ewconfig-master ~/.config/ewconfig
|
||||
rm ewconfig.zip
|
||||
|
||||
# Return to the original directory
|
||||
cd $cwd
|
||||
}
|
||||
|
||||
# Temporairly hop to the ewconfig directory to run a command
|
||||
ewconfig-run() {
|
||||
cwd=$(pwd)
|
||||
cd ~/.config/ewconfig
|
||||
$@
|
||||
cd $cwd
|
||||
}
|
||||
|
||||
# Re-run the install script from anywhere
|
||||
ewconfig-reinstall() {
|
||||
# Require an argument (linux, windows)
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: ewconfig-reinstall <platform>"
|
||||
return 1
|
||||
fi
|
||||
|
||||
# Execute through ewconfig-run
|
||||
ewconfig-run sh ./install-$1.sh
|
||||
}
|
||||
|
||||
# Define a function to emulate gh
|
||||
gh-emulated() {
|
||||
if [ $# != 3 ]; then
|
||||
echo "You don't have gh installed. Emulating its functionality."
|
||||
echo "Usage: gh repo clone <user>/<repo>"
|
||||
else
|
||||
git clone https://github.com/$3
|
||||
fi
|
||||
}
|
||||
|
||||
# Only if `gh` is not installed
|
||||
if ! command -v gh &> /dev/null; then
|
||||
alias gh=gh-emulated
|
||||
fi
|
||||
|
||||
# Convert an SVG to a PNG
|
||||
svg2png() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: svg2png <file>"
|
||||
else
|
||||
inkscape -z "$1.png" "$1" --export-type=png
|
||||
fi
|
||||
}
|
||||
|
||||
# Get the AS Path to an IP
|
||||
aspath() {
|
||||
# There must be at least one argument (cab be more)
|
||||
if [ $# -lt 1 ]; then
|
||||
echo "Usage: aspath <ip> [args]"
|
||||
else
|
||||
mtr $@ -z -rw -c1 -G0.25 | tail -n +3 | awk '{print $2}' | grep -v AS\?\?\? | uniq | cut -c 3- | tr '\n' ',' | sed 's/,/ -> /g' | rev | cut -c 5- | rev
|
||||
fi
|
||||
}
|
||||
|
||||
# Get the AS Path to an IP (include unknown hops)
|
||||
aspath-long() {
|
||||
# There must be at least one argument (cab be more)
|
||||
if [ $# -lt 1 ]; then
|
||||
echo "Usage: aspath-long <ip> [args]"
|
||||
else
|
||||
mtr $@ -z -rw -c1 -G0.25 | tail -n +3 | awk '{print $2}' | uniq | cut -c 3- | tr '\n' ',' | sed 's/,/ -> /g' | rev | cut -c 5- | rev
|
||||
fi
|
||||
}
|
58
configs/shells/zsh/.zshrc
Normal file
58
configs/shells/zsh/.zshrc
Normal file
@ -0,0 +1,58 @@
|
||||
|
||||
# There are some important env vars that need to exist
|
||||
export EWCONFIG_ROOT="$HOME/.config/ewconfig"
|
||||
|
||||
# Load my custom prompt and macros
|
||||
. $EWCONFIG_ROOT/configs/shells/zsh/prompt.sh
|
||||
. $EWCONFIG_ROOT/configs/shells/zsh/macros.sh
|
||||
. $EWCONFIG_ROOT/configs/shells/zsh/keybinds.sh
|
||||
. $EWCONFIG_ROOT/configs/shells/zsh/autocomplete.sh
|
||||
|
||||
# Load per-host configuration
|
||||
if [ -f $EWCONFIG_ROOT/configs/zsh/by_host/$HOSTNAME.sh ]; then
|
||||
. $EWCONFIG_ROOT/configs/shells/zsh/by_host/$HOSTNAME.sh
|
||||
fi
|
||||
|
||||
# Show some host info
|
||||
. $EWCONFIG_ROOT/configs/shells/bash/info.sh
|
||||
|
||||
# I always want my ~/bin to be in my PATH
|
||||
export PATH="$HOME/bin:$PATH"
|
||||
export PATH="$EWCONFIG_ROOT/scripts:$PATH"
|
||||
export PATH="$HOME/.local/bin:$PATH"
|
||||
|
||||
# Make sure libs can be found
|
||||
export LD_LIBRARY_PATH="/usr/local/lib:$LD_LIBRARY_PATH"
|
||||
export LD_LIBRARY_PATH="/usr/local/lib64:$LD_LIBRARY_PATH"
|
||||
|
||||
# I want to be able to load my custom python modules
|
||||
export PYTHONPATH="$EWCONFIG_ROOT/python_modules:$PYTHONPATH"
|
||||
export PYTHONSTARTUP="$EWCONFIG_ROOT/configs/python/python_startup.py"
|
||||
|
||||
# Configure a sane default editor
|
||||
if type -p nvim > /dev/null; then
|
||||
export EDITOR="nvim"
|
||||
elif type -p vim > /dev/null; then
|
||||
export EDITOR="vim"
|
||||
elif type -p vi > /dev/null; then
|
||||
export EDITOR="vi"
|
||||
elif type -p nano > /dev/null; then
|
||||
export EDITOR="nano"
|
||||
fi
|
||||
|
||||
# If we have neovim, use it as the manpage viewer
|
||||
if type -p nvim > /dev/null; then
|
||||
export MANPAGER="nvim +Man!"
|
||||
export MANWIDTH=80
|
||||
fi
|
||||
|
||||
# SDKMAN!
|
||||
export SDKMAN_DIR="$HOME/.sdkman"
|
||||
[[ -s "$HOME/.sdkman/bin/sdkman-init.sh" ]] && source "$HOME/.sdkman/bin/sdkman-init.sh"
|
||||
|
||||
# Flutter
|
||||
[[ -s "$HOME/pkg/flutter/bin" ]] && export PATH="$HOME/pkg/flutter/bin:$PATH"
|
||||
|
||||
# Rye
|
||||
[[ -s "$HOME/.rye/env" ]] && source "$HOME/.rye/env"
|
||||
. "$HOME/.cargo/env"
|
46
configs/shells/zsh/autocomplete.sh
Normal file
46
configs/shells/zsh/autocomplete.sh
Normal file
@ -0,0 +1,46 @@
|
||||
# Allow programs to write their own autocomplete functions to ~/.zfunc
|
||||
mkdir -p ~/.zfunc
|
||||
fpath+=~/.zfunc
|
||||
|
||||
# Make all shells append to history file instantly
|
||||
setopt INC_APPEND_HISTORY
|
||||
|
||||
# If we have rustup, it can be used to generate completeions for itself and cargo
|
||||
if type -p rustup >/dev/null; then
|
||||
# Only generate if the files don't already exist
|
||||
if [[ ! -f ~/.zfunc/_rustup ]]; then
|
||||
rustup completions zsh > ~/.zfunc/_rustup
|
||||
fi
|
||||
if [[ ! -f ~/.zfunc/_cargo ]]; then
|
||||
rustup completions zsh cargo > ~/.zfunc/_cargo
|
||||
fi
|
||||
fi
|
||||
|
||||
# Enable auto-complete
|
||||
autoload -Uz compinit && compinit
|
||||
|
||||
# Handles case-insensitive completion
|
||||
zstyle ':completion:*' matcher-list 'm:{a-z}={A-Za-z}'
|
||||
|
||||
# Configure command history
|
||||
HISTFILE=~/.histfile
|
||||
HISTSIZE=100000
|
||||
SAVEHIST=100000
|
||||
|
||||
# Ignore duplicates in history search, and dont't write them either
|
||||
setopt HIST_FIND_NO_DUPS
|
||||
setopt HIST_IGNORE_ALL_DUPS
|
||||
|
||||
# Ignore commands starting with a space
|
||||
setopt HIST_IGNORE_SPACE
|
||||
|
||||
# Allow up arrow to be used to go back in history based on current line contents
|
||||
autoload -U up-line-or-beginning-search
|
||||
autoload -U down-line-or-beginning-search
|
||||
zle -N up-line-or-beginning-search
|
||||
zle -N down-line-or-beginning-search
|
||||
bindkey "^[[A" up-line-or-beginning-search # Up
|
||||
bindkey "^[[B" down-line-or-beginning-search # Down
|
||||
bindkey "^[OA" up-line-or-beginning-search # Up over SSH connection
|
||||
bindkey "^[OB" down-line-or-beginning-search # Down over SSH connection
|
||||
|
26
configs/shells/zsh/keybinds.sh
Normal file
26
configs/shells/zsh/keybinds.sh
Normal file
@ -0,0 +1,26 @@
|
||||
### ctrl+arrows
|
||||
bindkey "\e[1;5C" forward-word
|
||||
bindkey "\e[1;5D" backward-word
|
||||
# urxvt
|
||||
bindkey "\eOc" forward-word
|
||||
bindkey "\eOd" backward-word
|
||||
|
||||
### ctrl+delete
|
||||
bindkey "\e[3;5~" kill-word
|
||||
# urxvt
|
||||
bindkey "\e[3^" kill-word
|
||||
|
||||
### ctrl+backspace
|
||||
bindkey '^H' backward-kill-word
|
||||
|
||||
### ctrl+shift+delete
|
||||
bindkey "\e[3;6~" kill-line
|
||||
# urxvt
|
||||
bindkey "\e[3@" kill-line
|
||||
|
||||
# Home and end
|
||||
bindkey "^[[H" beginning-of-line
|
||||
bindkey "^[[F" end-of-line
|
||||
|
||||
# Delete
|
||||
bindkey "^[[3~" delete-char
|
14
configs/shells/zsh/macros.sh
Normal file
14
configs/shells/zsh/macros.sh
Normal file
@ -0,0 +1,14 @@
|
||||
# We are compatible with bash, so first load the bash-specific macros
|
||||
. $EWCONFIG_ROOT/configs/shells/bash/macros.sh
|
||||
|
||||
# Aliases
|
||||
alias zshreload="source ~/.zshrc"
|
||||
|
||||
# Search for a process
|
||||
proc-grep() {
|
||||
if [ $# != 1 ]; then
|
||||
echo "Usage: proc-grep <regex>"
|
||||
else
|
||||
ps aux | { head -1; grep $1 }
|
||||
fi
|
||||
}
|
48
configs/shells/zsh/prompt.sh
Normal file
48
configs/shells/zsh/prompt.sh
Normal file
@ -0,0 +1,48 @@
|
||||
# This is some kind of dark magic.
|
||||
# I have no memory of whats going on here, but this has been my config since 2015-ish, so it shall not be touched.
|
||||
# This was origionally written for crosh, so that may be part of the problem...
|
||||
|
||||
autoload -U colors && colors
|
||||
NEWLINE=$'\n'
|
||||
USER_ICON="$"
|
||||
|
||||
# Use colors to signal the current connection / user privs
|
||||
if [[ $(id -u) = 0 ]]; then
|
||||
HOST_COLOR="red"
|
||||
USER_ICON="#"
|
||||
elif [ -n "$SSH_CLIENT" ] || [ -n "$SSH_TTY" ]; then
|
||||
HOST_COLOR="yellow"
|
||||
elif [ "$EWCONFIG_IN_DOCKER" = "1" ]; then
|
||||
HOST_COLOR="blue"
|
||||
else
|
||||
HOST_COLOR="green"
|
||||
fi
|
||||
|
||||
# Clear the prompt
|
||||
export PROMPT=""
|
||||
|
||||
# If we are *NOT* in Termux, show the host and username
|
||||
if ! command -v termux-setup-storage; then
|
||||
export PROMPT="%{$fg[$HOST_COLOR]%}%n@%M "
|
||||
fi
|
||||
|
||||
# Add the common prompt parts
|
||||
export PROMPT="${PROMPT}%{$fg[cyan]%}%~ ${USER_ICON} %{$reset_color%}"
|
||||
setopt prompt_subst
|
||||
autoload -Uz vcs_info
|
||||
zstyle ':vcs_info:*' actionformats \
|
||||
'%F{5}(%f%s%F{5})%F{3}-%F{5}[%F{2}%b%F{3}|%F{1}%a%F{5}]%f '
|
||||
zstyle ':vcs_info:*' formats \
|
||||
'%F{5}(%f%s%F{5})%F{3}-%F{5}[%F{2}%b%F{5}]%f '
|
||||
zstyle ':vcs_info:(sv[nk]|bzr):*' branchformat '%b%F{1}:%F{3}%r'
|
||||
|
||||
zstyle ':vcs_info:*' enable git cvs svn
|
||||
|
||||
# or use pre_cmd, see man zshcontrib
|
||||
vcs_info_wrapper() {
|
||||
vcs_info
|
||||
if [ -n "$vcs_info_msg_0_" ]; then
|
||||
echo "%{$fg[grey]%}${vcs_info_msg_0_}%{$reset_color%}$del"
|
||||
fi
|
||||
}
|
||||
export RPROMPT=$'%T $(vcs_info_wrapper)%?'
|
4
configs/ssh/allowed_signers
Normal file
4
configs/ssh/allowed_signers
Normal file
@ -0,0 +1,4 @@
|
||||
evan@ewpratten.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBMbNW3x0Cx04MybxQo5FptZhdjiFJjKITtq67KqrDXAN+jepJwdIG6TUJzuJddztuYIsvPAoQPpiQVSPyC8y51Y=
|
||||
evan@ewpratten.com sk-ssh-ed25519@openssh.com AAAAGnNrLXNzaC1lZDI1NTE5QG9wZW5zc2guY29tAAAAIAkdmKF1cYQTW7cfK7TYC5iVBsAg5g3SRJqlqo2NixHdAAAABHNzaDo=
|
||||
evan@ewpratten.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGBaSKoWYuR43fxRPy31P/X/2Ri2hYUZTjKiLBRDoa1F
|
||||
evan@ewpratten.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGEqeWe+pVp3rTsmHr9v5Qcb+niHXihJxwVKcc7p6EXz
|
116
configs/ssh/config
Normal file
116
configs/ssh/config
Normal file
@ -0,0 +1,116 @@
|
||||
# vim: nospell
|
||||
# Global Rules
|
||||
Host * !*.github.com !github.com
|
||||
IdentityFile %d/.ssh/id_ed25519_sk_rk_yk20572395
|
||||
IdentityFile %d/.ssh/id_ed25519
|
||||
IdentityFile %d/.ssh/id_rsa
|
||||
# VisualHostKey yes
|
||||
#VerifyHostKeyDNS ask
|
||||
|
||||
|
||||
# Github SSH adapter for restricted networks
|
||||
Host github.com gist.github.com
|
||||
HostName ssh.github.com
|
||||
Port 443
|
||||
# This solves a VSCode bug
|
||||
IdentityFile %d/.ssh/id_ed25519
|
||||
IdentityFile %d/.ssh/id_ed25519_sk_rk_yk20572395
|
||||
# IdentityFile %d/.ssh/id_rsa
|
||||
|
||||
# Home network
|
||||
Host unifi
|
||||
HostName dreammachinepro.local
|
||||
User root
|
||||
PreferredAuthentications password
|
||||
PubkeyAuthentication no
|
||||
|
||||
Host ewpratten-steamdeck
|
||||
HostName ewpratten-steamdeck.local
|
||||
User deck
|
||||
ForwardX11 yes
|
||||
|
||||
Host 10.80.0.218
|
||||
User root
|
||||
PreferredAuthentications password
|
||||
PubkeyAuthentication no
|
||||
PubkeyAcceptedKeyTypes +ssh-rsa
|
||||
HostKeyAlgorithms=+ssh-rsa
|
||||
|
||||
# Default hostnames I may encounter in the wild
|
||||
Host openrepeater.local
|
||||
HostName openrepeater.local
|
||||
User root
|
||||
StrictHostKeyChecking no
|
||||
|
||||
Host raspberrypi.local
|
||||
StrictHostKeyChecking no
|
||||
User pi
|
||||
|
||||
Host 192.168.8.1
|
||||
User root
|
||||
PreferredAuthentications password
|
||||
PubkeyAuthentication no
|
||||
PubkeyAcceptedKeyTypes +ssh-rsa
|
||||
HostKeyAlgorithms=+ssh-rsa
|
||||
|
||||
# Raider Robotics
|
||||
Host 10.50.24.2
|
||||
StrictHostKeyChecking no
|
||||
User admin
|
||||
|
||||
# Sheridan College
|
||||
Host db6.fast.sheridanc.on.ca
|
||||
User user03
|
||||
Host dbr.fast.sheridanc.on.ca
|
||||
User DataIntegrator
|
||||
Host *.fast.sheridanc.on.ca
|
||||
ProxyJump prattene@atlas.sheridanc.on.ca
|
||||
Host atlas.sheridanc.on.ca
|
||||
User prattene
|
||||
Host *.sheridanc.on.ca
|
||||
User prattene
|
||||
RequestTTY yes
|
||||
PubkeyAcceptedKeyTypes +ssh-rsa
|
||||
HostKeyAlgorithms +ssh-rsa
|
||||
|
||||
# NLNOG
|
||||
Host *.ring.nlnog.net
|
||||
User ewpratten
|
||||
IdentitiesOnly yes
|
||||
|
||||
# SDF.org
|
||||
Host sdf.org *.sdf.org
|
||||
User ewpratten
|
||||
Host sdf
|
||||
HostName sdf.org
|
||||
Host otaku
|
||||
HostName otaku.sdf.org
|
||||
|
||||
# Guru
|
||||
Host *.gurustudio.com
|
||||
User "guru-domain\\epratten"
|
||||
Host td-prod td-prod2 td-prod3 td-prod4
|
||||
User guru
|
||||
Host w6421
|
||||
User "guru-domain\\epratten"
|
||||
#RequestTTY yes
|
||||
# RemoteCommand "C:\Program Files\Git\bin\bash.exe" --login
|
||||
|
||||
# Personal Infra
|
||||
Host oci-arm
|
||||
HostName oci-arm.vpn.ewp.fyi
|
||||
User ubuntu
|
||||
|
||||
# Pratten Machines
|
||||
Host warren-desktop
|
||||
HostName workstation.warren.vpn
|
||||
|
||||
Host gianna-desktop
|
||||
HostName workstation.gianna.vpn
|
||||
|
||||
# Various Aliases
|
||||
Host desktop
|
||||
HostName ewpratten-desktop.home
|
||||
|
||||
Host laptop
|
||||
HostName ewpratten-laptop.home
|
1
configs/tabset/devices/huion-kamvas-13/name
Executable file
1
configs/tabset/devices/huion-kamvas-13/name
Executable file
@ -0,0 +1 @@
|
||||
Huion Kamvas 13
|
2
configs/tabset/devices/huion-kamvas-13/peripherals
Executable file
2
configs/tabset/devices/huion-kamvas-13/peripherals
Executable file
@ -0,0 +1,2 @@
|
||||
Tablet Monitor stylus
|
||||
Tablet Monitor Pad pad
|
18
configs/tabset/devices/huion-kamvas-13/profiles/blender.sh
Executable file
18
configs/tabset/devices/huion-kamvas-13/profiles/blender.sh
Executable file
@ -0,0 +1,18 @@
|
||||
# Top three buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 1 "key +ctrl +z -z -ctrl"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 2 "key +ctrl +tab -tab -ctrl"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 3 "key x"
|
||||
|
||||
# Middle two buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 8 "key shift"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 9 "key ctrl"
|
||||
|
||||
# Bottom three buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 10 "key 1"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 11 "key 3"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 12 "key 0"
|
||||
|
||||
# Pen buttons
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "1" "button +1 "
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "2" "button +2 "
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "3" "button +3 "
|
1
configs/tabset/devices/huion-kamvas-13/profiles/default.sh
Symbolic link
1
configs/tabset/devices/huion-kamvas-13/profiles/default.sh
Symbolic link
@ -0,0 +1 @@
|
||||
blender.sh
|
18
configs/tabset/devices/huion-kamvas-13/profiles/disabled.sh
Executable file
18
configs/tabset/devices/huion-kamvas-13/profiles/disabled.sh
Executable file
@ -0,0 +1,18 @@
|
||||
# Top three buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 1 "button 0"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 2 "button 0"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 3 "button 0"
|
||||
|
||||
# Middle two buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 8 "button 0"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 9 "button 0"
|
||||
|
||||
# Bottom three buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 10 "button 0"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 11 "button 0"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 12 "button 0"
|
||||
|
||||
# Pen buttons
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "1" "button +1 "
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "2" "button +2 "
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "3" "button +3 "
|
18
configs/tabset/devices/huion-kamvas-13/profiles/gimp.sh
Executable file
18
configs/tabset/devices/huion-kamvas-13/profiles/gimp.sh
Executable file
@ -0,0 +1,18 @@
|
||||
# Top three buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 1 "key +ctrl +z -z -ctrl"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 2 "key +ctrl +shift +a -a -shift -ctrl"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 3 "key del"
|
||||
|
||||
# Middle two buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 8 "key shift"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 9 "key ctrl"
|
||||
|
||||
# Bottom three buttons
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 10 "key +shift +e -e -shift"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 11 "key p"
|
||||
xsetwacom --set "Tablet Monitor Pad pad" Button 12 "key f"
|
||||
|
||||
# Pen buttons
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "1" "button +1 "
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "2" "button +2 "
|
||||
xsetwacom set "Tablet Monitor stylus" "Button" "3" "button +3 "
|
7
configs/termux/termux.properties
Normal file
7
configs/termux/termux.properties
Normal file
@ -0,0 +1,7 @@
|
||||
# Terminal behaviour
|
||||
bell-character=vibrate
|
||||
|
||||
# Keyboard
|
||||
extra-keys-style = default
|
||||
extra-keys = [['ESC', 'TAB', 'CTRL', 'ALT', 'LEFT', 'DOWN', 'UP', 'RIGHT']]
|
||||
|
1
configs/tmux/.tmux.conf
Normal file
1
configs/tmux/.tmux.conf
Normal file
@ -0,0 +1 @@
|
||||
set -g mouse on
|
1
configs/user-tmpfiles.d/discord-rpc.conf
Normal file
1
configs/user-tmpfiles.d/discord-rpc.conf
Normal file
@ -0,0 +1 @@
|
||||
L %t/discord-ipc-0 - - - - app/com.discordapp.Discord/discord-ipc-0
|
80
configs/vim/.vimrc
Normal file
80
configs/vim/.vimrc
Normal file
@ -0,0 +1,80 @@
|
||||
" Syntax highlighting
|
||||
syntax on
|
||||
|
||||
" Enable modeline
|
||||
set modeline
|
||||
|
||||
" Enable mouse usage
|
||||
set mouse=a
|
||||
|
||||
" Tab size
|
||||
set tabstop=4
|
||||
set shiftwidth=4
|
||||
set expandtab
|
||||
|
||||
" VSCode-style selection indenting
|
||||
nnoremap <Tab> >>_
|
||||
nnoremap <S-Tab> <<_
|
||||
inoremap <S-Tab> <C-D>
|
||||
vnoremap <Tab> >gv
|
||||
vnoremap <S-Tab> <gv
|
||||
|
||||
" VSCode-style shift-arrow for selection
|
||||
set keymodel=startsel,stopsel
|
||||
|
||||
" VSCode-style word deletion
|
||||
inoremap <C-BS> <C-W>
|
||||
inoremap <C-Del> <Esc>lcw
|
||||
nnoremap <C-Del> cw<Esc>l
|
||||
|
||||
" Force VIM to use system clipboard
|
||||
set clipboard=unnamedplus
|
||||
|
||||
" Enable per-project vimrc files
|
||||
set exrc
|
||||
set secure
|
||||
|
||||
" Enable filetype plugins
|
||||
set nocompatible
|
||||
filetype plugin on
|
||||
syntax on
|
||||
|
||||
" Hide the intro message
|
||||
set shortmess+=I
|
||||
|
||||
" Force help documents into new tabs
|
||||
cnoreabbrev <expr> help getcmdtype() == ":" && getcmdline() == 'help' ? 'tab help' : 'help'
|
||||
cnoreabbrev <expr> h getcmdtype() == ":" && getcmdline() == 'h' ? 'tab help' : 'h'
|
||||
|
||||
" Configure netrw
|
||||
let g:netrw_liststyle = 3
|
||||
let g:netrw_banner = 0
|
||||
let g:netrw_browse_split = 3
|
||||
|
||||
" Enable spell checking
|
||||
if !exists('g:vscode')
|
||||
set spell
|
||||
set spelllang=en_ca,en_us
|
||||
set spelloptions=camel
|
||||
|
||||
" Hide spellcheck highlights I don't care about
|
||||
hi clear SpellCap
|
||||
hi clear SpellRare
|
||||
|
||||
" Change the spellcheck highlight to an underline
|
||||
hi clear SpellBad
|
||||
hi SpellBad cterm=underline ctermfg=DarkRed
|
||||
|
||||
" Disable spellcheck for some file formats
|
||||
autocmd FileType man setlocal nospell
|
||||
autocmd FileType diff setlocal nospell
|
||||
autocmd FileType usda setlocal nospell
|
||||
endif
|
||||
|
||||
" Configure Diff rendering
|
||||
hi DiffText ctermfg=White ctermbg=none
|
||||
hi DiffFile ctermfg=White ctermbg=none cterm=bold
|
||||
hi DiffIndexLine ctermfg=White ctermbg=none cterm=bold
|
||||
hi DiffAdd ctermfg=DarkGreen ctermbg=none
|
||||
hi DiffChange ctermfg=DarkRed ctermbg=none
|
||||
hi DiffDelete ctermfg=DarkRed ctermbg=none
|
80
configs/windows-terminal/settings.json
Normal file
80
configs/windows-terminal/settings.json
Normal file
@ -0,0 +1,80 @@
|
||||
{
|
||||
"$help": "https://aka.ms/terminal-documentation",
|
||||
"$schema": "https://aka.ms/terminal-profiles-schema",
|
||||
"actions": [
|
||||
{
|
||||
"command": {
|
||||
"action": "copy",
|
||||
"singleLine": false
|
||||
},
|
||||
"keys": "ctrl+shift+c"
|
||||
},
|
||||
{
|
||||
"command": "paste",
|
||||
"keys": "ctrl+shift+v"
|
||||
}
|
||||
],
|
||||
"copyFormatting": "none",
|
||||
"copyOnSelect": false,
|
||||
"defaultProfile": "{2ece5bfe-50ed-5f3a-ab87-5cd4baafed2b}",
|
||||
"newTabMenu": [
|
||||
{
|
||||
"type": "remainingProfiles"
|
||||
}
|
||||
],
|
||||
"profiles": {
|
||||
"defaults": {
|
||||
"useAtlasEngine": true
|
||||
},
|
||||
"list": [
|
||||
{
|
||||
"commandline": "%SystemRoot%\\System32\\WindowsPowerShell\\v1.0\\powershell.exe",
|
||||
"guid": "{61c54bbd-c2c6-5271-96e7-009a87ff44bf}",
|
||||
"font": {
|
||||
"face": "Consolas"
|
||||
},
|
||||
"hidden": false,
|
||||
"name": "Windows PowerShell"
|
||||
},
|
||||
{
|
||||
"commandline": "%SystemRoot%\\System32\\cmd.exe",
|
||||
"guid": "{0caa0dad-35be-5f56-a8ff-afceeeaa6101}",
|
||||
"font": {
|
||||
"face": "Consolas"
|
||||
},
|
||||
"hidden": false,
|
||||
"name": "Command Prompt"
|
||||
},
|
||||
{
|
||||
"guid": "{2ece5bfe-50ed-5f3a-ab87-5cd4baafed2b}",
|
||||
"commandline": "C:/Program Files/Git/bin/bash.exe --login",
|
||||
"font": {
|
||||
"face": "Consolas"
|
||||
},
|
||||
"hidden": false,
|
||||
"name": "Git Bash",
|
||||
"source": "Git"
|
||||
},
|
||||
{
|
||||
"guid": "{2c4de342-38b7-51cf-b940-2309a097f518}",
|
||||
"font": {
|
||||
"face": "Consolas"
|
||||
},
|
||||
"hidden": true,
|
||||
"name": "Ubuntu",
|
||||
"source": "Windows.Terminal.Wsl"
|
||||
},
|
||||
{
|
||||
"guid": "{51855cb2-8cce-5362-8f54-464b92b32386}",
|
||||
"font": {
|
||||
"face": "Consolas"
|
||||
},
|
||||
"hidden": false,
|
||||
"name": "Ubuntu",
|
||||
"source": "CanonicalGroupLimited.Ubuntu_79rhkp1fndgsc"
|
||||
}
|
||||
]
|
||||
},
|
||||
"schemes": [],
|
||||
"themes": []
|
||||
}
|
154
install-linux.sh
Normal file
154
install-linux.sh
Normal file
@ -0,0 +1,154 @@
|
||||
#! /bin/sh
|
||||
set -e
|
||||
export EWCONFIG_ROOT=$(dirname $(readlink -f $0))
|
||||
|
||||
# -- Ensure that deps exist --
|
||||
|
||||
# Pull git submodules if needed
|
||||
if type -p git > /dev/null; then
|
||||
# If we have permission to run git
|
||||
if [ -d "$EWCONFIG_ROOT/.git" ]; then
|
||||
echo "Syncing git submodules..."
|
||||
git submodule update --init --recursive
|
||||
|
||||
# Make sure that the `ewp` upstream exists
|
||||
if ! git remote | grep -q ewp; then
|
||||
echo "Adding secondary git remote"
|
||||
git remote add ewp git://git.ewpratten.com/ewconfig
|
||||
git remote set-url --push ewp ssh://ewpratten@git.ewpratten.com:/srv/git/ewconfig
|
||||
echo "Remotes are:"
|
||||
git remote -v
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# Make sure scripts are all executable
|
||||
chmod +x $EWCONFIG_ROOT/scripts/*
|
||||
chmod +x $EWCONFIG_ROOT/configs/nautilus/scripts/*
|
||||
|
||||
# -- Directory Setup --
|
||||
set -x
|
||||
|
||||
# Ensure that needed directories exist
|
||||
mkdir -p ~/Downloads # For downloads
|
||||
mkdir -p ~/bin # Personal bin dir. Reduces the risk of breaking ~/.local/bin
|
||||
mkdir -p ~/projects # For my projects
|
||||
mkdir -p ~/src # For compiling other people's projects
|
||||
mkdir -p ~/services # Service dir for servers mostly
|
||||
|
||||
# Build the directory structure if ~/.config
|
||||
mkdir -p ~/.config/nvim
|
||||
mkdir -p ~/.config/termux
|
||||
mkdir -p ~/.config/logid
|
||||
mkdir -p ~/.config/systemd/user
|
||||
mkdir -p ~/.config/git
|
||||
mkdir -p ~/.config/git/config-fragments
|
||||
mkdir -p ~/.config/user-tmpfiles.d
|
||||
mkdir -p ~/.cargo
|
||||
mkdir -p ~/.ssh
|
||||
|
||||
# Build directory structure for program plugins
|
||||
mkdir -p ~/.local/share/nautilus/scripts/
|
||||
|
||||
# -- Config Linking --
|
||||
|
||||
# Configure the shell
|
||||
ln -sf $EWCONFIG_ROOT/configs/shells/zsh/.zshrc ~/.zshrc
|
||||
ln -sf $EWCONFIG_ROOT/configs/shells/bash/.bashrc ~/.bashrc
|
||||
|
||||
# Configure Git
|
||||
ln -sf $EWCONFIG_ROOT/configs/git/.gitconfig ~/.gitconfig
|
||||
ln -sf $EWCONFIG_ROOT/configs/sssh/allowed_signers ~/.ssh/allowed_signers
|
||||
ln -sf $EWCONFIG_ROOT/configs/git/.mailmap ~/.config/git/.mailmap
|
||||
|
||||
# Copy the global mailmap file once
|
||||
if [ ! -f ~/.config/git/config-fragments/global-mailmap.gitconfig ]; then
|
||||
cp $EWCONFIG_ROOT/configs/git/config-fragments/global-mailmap.gitconfig ~/.config/git/config-fragments/global-mailmap.gitconfig
|
||||
fi
|
||||
|
||||
# Check if GIT is installed > 2.34
|
||||
set +x
|
||||
if type -p git > /dev/null; then
|
||||
# If sort has a -V option
|
||||
if man sort | grep -q -- -V; then
|
||||
# If GIT has SSH signing support, enable it
|
||||
git_version=$(git --version | cut -d' ' -f3 | cut -d'.' -f1-2)
|
||||
minimum_version=2.34
|
||||
if [ "$(printf '%s\n' "$minimum_version" "$git_version" | sort -V | head -n1)" = "$minimum_version" ]; then
|
||||
set -x
|
||||
ln -sf $EWCONFIG_ROOT/configs/git/config-fragments/enable-signing.gitconfig ~/.config/git/config-fragments/enable-signing.gitconfig
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# Configure SSH
|
||||
ln -sf $EWCONFIG_ROOT/configs/ssh/config ~/.ssh/config
|
||||
chmod 644 "$HOME/.ssh/config"
|
||||
if type -p chown > /dev/null; then chown "$USER:$USER" "$HOME/.ssh/config"; fi
|
||||
|
||||
# Configure (neo)Vim
|
||||
ln -sf $EWCONFIG_ROOT/configs/vim/.vimrc ~/.vimrc
|
||||
ln -sf $EWCONFIG_ROOT/configs/nvim/init.vim ~/.config/nvim/init.vim
|
||||
ln -snf $EWCONFIG_ROOT/configs/nvim/pack ~/.config/nvim/pack
|
||||
ln -snf $EWCONFIG_ROOT/configs/nvim/third_party ~/.config/nvim/third_party
|
||||
|
||||
# Nautilus right-click scripts
|
||||
ln -sf $EWCONFIG_ROOT/configs/nautilus/scripts/* ~/.local/share/nautilus/scripts/
|
||||
|
||||
# Tabset configs
|
||||
ln -nsf $EWCONFIG_ROOT/configs/tabset ~/.config/tabset
|
||||
|
||||
# Rofi configs
|
||||
ln -nsf $EWCONFIG_ROOT/configs/rofi ~/.config/rofi
|
||||
|
||||
# Cargo
|
||||
ln -sf $EWCONFIG_ROOT/configs/cargo/config.toml ~/.cargo/config.toml
|
||||
|
||||
# Termux
|
||||
ln -sf $EWCONFIG_ROOT/configs/termux/termux.properties ~/.config/termux/termux.properties
|
||||
|
||||
# Set up user-tempfiles configs
|
||||
ln -sf $EWCONFIG_ROOT/configs/user-tmpfiles.d/* ~/.config/user-tmpfiles.d/
|
||||
|
||||
# Logid config
|
||||
ln -sf $EWCONFIG_ROOT/configs/logid/logid.cfg ~/.config/logid/logid.cfg
|
||||
|
||||
# Minecraft global configs
|
||||
ln -nsf $EWCONFIG_ROOT/configs/minecraft ~/.config/minecraft
|
||||
if [ -d ~/.var/app/org.prismlauncher.PrismLauncher ]; then
|
||||
flatpak override --user --filesystem=~/.config/minecraft org.prismlauncher.PrismLauncher
|
||||
fi
|
||||
|
||||
# Memegen
|
||||
ln -nsf $EWCONFIG_ROOT/configs/memegen ~/.config/memegen
|
||||
|
||||
# Tmux
|
||||
ln -sf $EWCONFIG_ROOT/configs/tmux/.tmux.conf ~/.tmux.conf
|
||||
|
||||
# -- Optional Configs --
|
||||
set +x
|
||||
|
||||
# If ~/.config/git/config-fragments/personal-info.gitconfig does not exist
|
||||
if [ ! -f ~/.config/git/config-fragments/personal-info.gitconfig ]; then
|
||||
# Ask if the user wants to install personal GIT config
|
||||
echo -n "Do you want to install the personal GIT config? (y/n) "
|
||||
read -r install_git_config
|
||||
if [ "$install_git_config" = "y" ]; then
|
||||
ln -sf $EWCONFIG_ROOT/configs/git/config-fragments/personal-info.gitconfig ~/.config/git/config-fragments/personal-info.gitconfig
|
||||
fi
|
||||
fi
|
||||
|
||||
# Link houdini scripts for appropriate versions
|
||||
if [ -d ~/houdini19.5 ]; then mkdir -p ~/houdini19.5/scripts; ln -sf $EWCONFIG_ROOT/configs/houdini19.5/scripts/* ~/houdini19.5/scripts; fi
|
||||
|
||||
# Link blender scripts for appropriate versions
|
||||
if [ -d ~/.config/blender/3.6 ]; then ln -sf $EWCONFIG_ROOT/configs/blender/3.x/scripts/addons/* ~/.config/blender/3.6/scripts/addons/; fi
|
||||
|
||||
# -- Finalization --
|
||||
|
||||
# On systems that need it, configure Gnome
|
||||
sh ./configs/gnome/gnome-terminal-settings.sh || true
|
||||
sh ./configs/gnome/desktop-settings.sh || true
|
||||
|
||||
# Attempt to force a termux settings reload on Android devices
|
||||
termux-reload-settings || true
|
63
install-windows.sh
Normal file
63
install-windows.sh
Normal file
@ -0,0 +1,63 @@
|
||||
#! /bin/sh
|
||||
set -e
|
||||
export EWCONFIG_ROOT=$(dirname $(readlink -f $0))
|
||||
|
||||
# Pull git submodules if needed
|
||||
echo "Syncing git submodules..."
|
||||
git submodule update --init --recursive
|
||||
|
||||
# Make sure that the `ewp` upstream exists
|
||||
if ! git remote | grep -q ewp; then
|
||||
echo "Adding secondary git remote"
|
||||
git remote add ewp git://git.ewpratten.com/ewconfig
|
||||
git remote set-url --push ewp ssh://ewpratten@git.ewpratten.com:/srv/git/ewconfig
|
||||
echo "Remotes are:"
|
||||
git remote -v
|
||||
fi
|
||||
|
||||
# Make sure scripts are all executable
|
||||
chmod +x $EWCONFIG_ROOT/scripts/*
|
||||
chmod +x $EWCONFIG_ROOT/configs/nautilus/scripts/*
|
||||
|
||||
# -- Directory Setup --
|
||||
set -x
|
||||
|
||||
# Ensure that needed directories exist
|
||||
mkdir -p ~/bin # Personal bin dir. Reduces the risk of breaking ~/.local/bin
|
||||
mkdir -p ~/projects # For my projects
|
||||
|
||||
# Build the directory structure if ~/.config
|
||||
mkdir -p ~/.config/git
|
||||
mkdir -p ~/.config/git/config-fragments
|
||||
mkdir -p ~/.cargo
|
||||
mkdir -p ~/.ssh
|
||||
|
||||
# -- Config Linking --
|
||||
|
||||
# Configure the shell
|
||||
ln -sf $EWCONFIG_ROOT/configs/shells/zsh/.zshrc ~/.zshrc
|
||||
ln -sf $EWCONFIG_ROOT/configs/shells/bash/.bashrc ~/.bashrc
|
||||
mkdir -p $LOCALAPPDATA/Packages/Microsoft.WindowsTerminal_8wekyb3d8bbwe/LocalState
|
||||
ln -sf $EWCONFIG_ROOT/configs/windows-terminal/settings.json $LOCALAPPDATA/Packages/Microsoft.WindowsTerminal_8wekyb3d8bbwe/LocalState/settings.json
|
||||
|
||||
# Configure Git
|
||||
ln -sf $EWCONFIG_ROOT/configs/git/.gitconfig ~/.gitconfig
|
||||
ln -sf $EWCONFIG_ROOT/configs/sssh/allowed_signers ~/.ssh/allowed_signers || true
|
||||
ln -sf $EWCONFIG_ROOT/configs/git/.mailmap ~/.config/git/.mailmap
|
||||
|
||||
# Configure Vim
|
||||
ln -sf $EWCONFIG_ROOT/configs/vim/.vimrc ~/.vimrc
|
||||
|
||||
# Remove Microsoft's fake python executables
|
||||
rm $LOCALAPPDATA/Microsoft/WindowsApps/python.exe || true
|
||||
rm $LOCALAPPDATA/Microsoft/WindowsApps/python3.exe || true
|
||||
|
||||
# Copy the global mailmap file once
|
||||
if [ ! -f ~/.config/git/config-fragments/global-mailmap.gitconfig ]; then
|
||||
cp $EWCONFIG_ROOT/configs/git/config-fragments/global-mailmap.gitconfig ~/.config/git/config-fragments/global-mailmap.gitconfig
|
||||
fi
|
||||
|
||||
# Configure SSH
|
||||
ln -sf $EWCONFIG_ROOT/configs/ssh/config ~/.ssh/config
|
||||
chmod 644 "$HOME/.ssh/config"
|
||||
chown "$USER:$USER" "$HOME/.ssh/config"
|
87
keyboards/qmk/keymaps/ferris/combos.c
Normal file
87
keyboards/qmk/keymaps/ferris/combos.c
Normal file
@ -0,0 +1,87 @@
|
||||
#include QMK_KEYBOARD_H
|
||||
|
||||
|
||||
#define MAKE_COMBO_INPUTS(name, inputs...) const uint16_t PROGMEM combo_inputs_##name[] = {inputs, COMBO_END};
|
||||
|
||||
|
||||
// Combo tokens. These are used to identify combos for later processing if needed.
|
||||
enum combos {
|
||||
// Combo that uses both pinky fingers to produce an <enter> keypress
|
||||
COMBO_PINKY_ENTER,
|
||||
// Combo that uses both ring fingers to produce a <backspace> keypress
|
||||
// COMBO_RING_BACKSPC,
|
||||
// Combo that uses the ring fingers to send a semicolon
|
||||
COMBO_RING_SCLN,
|
||||
// Copbo that uses the pinky fingers to send escape
|
||||
COMBO_PINKY_ESC,
|
||||
|
||||
// ASETNIOP
|
||||
ASETNIOP_AE_Q,
|
||||
ASETNIOP_RA_W,
|
||||
ASETNIOP_RE_Z,
|
||||
ASETNIOP_SA_X,
|
||||
ASETNIOP_SR_F,
|
||||
ASETNIOP_TA_P,
|
||||
ASETNIOP_TR_C,
|
||||
ASETNIOP_TS_D,
|
||||
ASETNIOP_TN_B,
|
||||
ASETNIOP_TE_V,
|
||||
ASETNIOP_TI_G,
|
||||
ASETNIOP_NA_J,
|
||||
ASETNIOP_NR_K,
|
||||
ASETNIOP_NS_M,
|
||||
ASETNIOP_NE_H,
|
||||
ASETNIOP_NO_L,
|
||||
ASETNIOP_EI_U,
|
||||
ASETNIOP_IN_Y,
|
||||
};
|
||||
|
||||
// Define all the input combinations needed for the combos
|
||||
MAKE_COMBO_INPUTS(COMBO_PINKY_ENTER, KC_A, KC_O)
|
||||
MAKE_COMBO_INPUTS(COMBO_RING_SCLN, KC_R, KC_I)
|
||||
MAKE_COMBO_INPUTS(COMBO_PINKY_ESC, KC_Q, KC_BSPC)
|
||||
// MAKE_COMBO_INPUTS(COMBO_RING_BACKSPC, KC_R, KC_I)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_AE_Q, KC_A, KC_E)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_RA_W, KC_R, KC_A)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_RE_Z, KC_R, KC_E)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_SA_X, KC_S, KC_A)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_SR_F, KC_S, KC_R)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_TA_P, KC_T, KC_A)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_TR_C, KC_T, KC_R)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_TS_D, KC_T, KC_S)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_TN_B, KC_T, KC_N)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_TE_V, KC_T, KC_E)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_TI_G, KC_T, KC_I)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_NA_J, KC_N, KC_A)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_NR_K, KC_N, KC_R)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_NS_M, KC_N, KC_S)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_NE_H, KC_N, KC_E)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_NO_L, KC_N, KC_O)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_EI_U, KC_E, KC_I)
|
||||
MAKE_COMBO_INPUTS(ASETNIOP_IN_Y, KC_I, KC_N)
|
||||
|
||||
// Map everything together
|
||||
combo_t key_combos[COMBO_COUNT] = {
|
||||
[COMBO_PINKY_ENTER] = COMBO(combo_inputs_COMBO_PINKY_ENTER, KC_ENT),
|
||||
[COMBO_RING_SCLN] = COMBO(combo_inputs_COMBO_RING_SCLN, KC_SCLN),
|
||||
[COMBO_PINKY_ESC] = COMBO(combo_inputs_COMBO_PINKY_ESC, KC_ESC),
|
||||
// [COMBO_RING_BACKSPC] = COMBO(combo_inputs_COMBO_RING_BACKSPC, KC_BSPC),
|
||||
[ASETNIOP_AE_Q] = COMBO(combo_inputs_ASETNIOP_AE_Q, KC_Q),
|
||||
[ASETNIOP_RA_W] = COMBO(combo_inputs_ASETNIOP_RA_W, KC_W),
|
||||
[ASETNIOP_RE_Z] = COMBO(combo_inputs_ASETNIOP_RE_Z, KC_Z),
|
||||
[ASETNIOP_SA_X] = COMBO(combo_inputs_ASETNIOP_SA_X, KC_X),
|
||||
[ASETNIOP_SR_F] = COMBO(combo_inputs_ASETNIOP_SR_F, KC_F),
|
||||
[ASETNIOP_TA_P] = COMBO(combo_inputs_ASETNIOP_TA_P, KC_P),
|
||||
[ASETNIOP_TR_C] = COMBO(combo_inputs_ASETNIOP_TR_C, KC_C),
|
||||
[ASETNIOP_TS_D] = COMBO(combo_inputs_ASETNIOP_TS_D, KC_D),
|
||||
[ASETNIOP_TN_B] = COMBO(combo_inputs_ASETNIOP_TN_B, KC_B),
|
||||
[ASETNIOP_TE_V] = COMBO(combo_inputs_ASETNIOP_TE_V, KC_V),
|
||||
[ASETNIOP_TI_G] = COMBO(combo_inputs_ASETNIOP_TI_G, KC_G),
|
||||
[ASETNIOP_NA_J] = COMBO(combo_inputs_ASETNIOP_NA_J, KC_J),
|
||||
[ASETNIOP_NR_K] = COMBO(combo_inputs_ASETNIOP_NR_K, KC_K),
|
||||
[ASETNIOP_NS_M] = COMBO(combo_inputs_ASETNIOP_NS_M, KC_M),
|
||||
[ASETNIOP_NE_H] = COMBO(combo_inputs_ASETNIOP_NE_H, KC_H),
|
||||
[ASETNIOP_NO_L] = COMBO(combo_inputs_ASETNIOP_NO_L, KC_L),
|
||||
[ASETNIOP_EI_U] = COMBO(combo_inputs_ASETNIOP_EI_U, KC_U),
|
||||
[ASETNIOP_IN_Y] = COMBO(combo_inputs_ASETNIOP_IN_Y, KC_Y),
|
||||
};
|
28
keyboards/qmk/keymaps/ferris/config.h
Normal file
28
keyboards/qmk/keymaps/ferris/config.h
Normal file
@ -0,0 +1,28 @@
|
||||
#pragma once
|
||||
|
||||
// Tapdance settings
|
||||
#define TAPPING_TERM 50
|
||||
#define TAPPING_TERM_PER_KEY
|
||||
#define RETRO_TAPPING // https://docs.qmk.fm/#/tap_hold?id=retro-tapping
|
||||
|
||||
// Space cadet on control key
|
||||
#define LCPO_KEYS KC_LCTL, KC_LSFT, KC_0
|
||||
|
||||
// // Force constant-speed controls for mouse movement
|
||||
// #define MK_3_SPEED
|
||||
// #define MK_MOMENTARY_ACCEL
|
||||
|
||||
// // Override the mode-2 speed
|
||||
// #define MK_C_OFFSET_1 4 // Defaut: 4
|
||||
|
||||
// Bootloader settings
|
||||
#define BOOTMAGIC_LITE_ROW 0
|
||||
#define BOOTMAGIC_LITE_COLUMN 0
|
||||
|
||||
// Chording config
|
||||
#define FORCE_NKRO
|
||||
// #define COMBO_COUNT 3
|
||||
#define COMBO_COUNT 21
|
||||
|
||||
// Settings for enabling experiments
|
||||
#define ENABLE_ASETNIOP
|
99
keyboards/qmk/keymaps/ferris/keymap.c
Normal file
99
keyboards/qmk/keymaps/ferris/keymap.c
Normal file
@ -0,0 +1,99 @@
|
||||
#include QMK_KEYBOARD_H
|
||||
|
||||
// Combo magic
|
||||
#include "combos.c"
|
||||
|
||||
// Layer definitions
|
||||
enum ferris_layers {
|
||||
// _HOME,
|
||||
// _QWERTY,
|
||||
_MODMAK,
|
||||
// _NUMERIC,
|
||||
// _UTILITY,
|
||||
// _MACROS,
|
||||
// _RAINBOW,
|
||||
};
|
||||
|
||||
// Shorthands
|
||||
#define LD_TERM LGUI(KC_ENT)
|
||||
#define CC_QUIT LGUI(LSFT(KC_Q))
|
||||
#define CC_COMM LCTL(KC_SLSH)
|
||||
#define CC_FMT LCTL(LSFT(KC_I))
|
||||
|
||||
// clang-format off
|
||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
|
||||
// [_HOME] = LAYOUT(
|
||||
// KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_BSPC,
|
||||
// KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O,
|
||||
// KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
// KC_LSFT, KC_LCTL, KC_SPACE, KC_NO
|
||||
// ),
|
||||
|
||||
// [_QWERTY] = LAYOUT(
|
||||
// KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,
|
||||
// KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN,
|
||||
// KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_NO,
|
||||
// KC_LCTL, KC_SPACE, KC_SPACE, KC_LSFT
|
||||
// )
|
||||
|
||||
[_MODMAK] = LAYOUT(
|
||||
KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_BSPC,
|
||||
KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O,
|
||||
KC_LCTL, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_M, KC_K, KC_COMM, KC_DOT,
|
||||
KC_LSFT, KC_LCTL, KC_SPACE, KC_SPACE
|
||||
// KC_LSFT, MO(_MACROS), LT(_UTILITY, KC_SPACE), LT(_NUMERIC, KC_SPACE)
|
||||
),
|
||||
|
||||
// [_NUMERIC] = LAYOUT(
|
||||
// KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, /**/ KC_F6, KC_F7, KC_F8, KC_F9, KC_F10,
|
||||
// KC_1, KC_2, KC_3, KC_4, KC_5, /**/ KC_6, KC_7, KC_8, KC_9, KC_0,
|
||||
// KC_LALT, KC_NO, KC_NO, KC_NO, TO(_MODMAK), /**/ KC_LGUI, KC_EQL, KC_MINS, KC_F11, KC_F12,
|
||||
// KC_LSFT, KC_LCTL, /**/ KC_NO, KC_NO
|
||||
// ),
|
||||
|
||||
// [_UTILITY] = LAYOUT(
|
||||
// KC_Q, KC_VOLD, KC_VOLU, KC_NO, KC_PSCR, /**/ LD_TERM, KC_HOME, KC_PGUP, KC_PGDN, KC_DEL,
|
||||
// KC_MPRV, KC_MPLY, KC_MNXT, KC_NO, KC_TAB, /**/ KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT, KC_END,
|
||||
// KC_NO, KC_NO, KC_NO, CC_FMT, CC_COMM, /**/ KC_QUOTE, KC_SLSH, KC_LBRC, KC_RBRC, KC_BSLS,
|
||||
// KC_LSFT, KC_LCTL, /**/ KC_NO, KC_LGUI
|
||||
// ),
|
||||
|
||||
// [_MACROS] = LAYOUT(
|
||||
// KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, TO(_RAINBOW),
|
||||
// KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
// KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
// KC_NO, KC_NO, KC_NO, KC_NO
|
||||
// ),
|
||||
|
||||
// [_RAINBOW] = LAYOUT(
|
||||
// KC_ESC, KC_Q, KC_W, KC_E, KC_5, TO(_MODMAK), KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
// KC_LSFT, KC_A, KC_S, KC_D, KC_G, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
// KC_LCTL, KC_Z, KC_X, KC_C, KC_V, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
// KC_SPACE, KC_X, KC_NO, KC_NO
|
||||
// )
|
||||
};
|
||||
// clang-format on
|
||||
|
||||
/** THIS IS FOR CREATING A NEW KEYMAP **
|
||||
[_UNSET_] = LAYOUT(
|
||||
KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO,
|
||||
KC_NO, KC_NO, KC_NO, KC_NO
|
||||
)
|
||||
*/
|
||||
|
||||
// Overrides for the tapping terms.
|
||||
uint16_t get_tapping_term(uint16_t keycode, keyrecord_t *record) {
|
||||
switch (keycode) {
|
||||
// Space cadet needs to be much slower than my default
|
||||
// case SC_LSPO:
|
||||
// case SC_LCPO:
|
||||
// return 200;
|
||||
// case LT(_NUMERIC, KC_SPACE):
|
||||
// return 1000;
|
||||
default:
|
||||
return TAPPING_TERM;
|
||||
}
|
||||
}
|
9
keyboards/qmk/keymaps/ferris/rules.mk
Normal file
9
keyboards/qmk/keymaps/ferris/rules.mk
Normal file
@ -0,0 +1,9 @@
|
||||
# Override the default bootloader since I am using a non-standard MCU
|
||||
BOOTLOADER = qmk-dfu
|
||||
|
||||
# Enable bootloader keys
|
||||
BOOTMAGIC_ENABLE = yes
|
||||
|
||||
# Set up chording support
|
||||
FORCE_NKRO = yes
|
||||
COMBO_ENABLE = yes
|
26
keyboards/qmk/keymaps/tg4x/config.h
Normal file
26
keyboards/qmk/keymaps/tg4x/config.h
Normal file
@ -0,0 +1,26 @@
|
||||
#pragma once
|
||||
|
||||
// Threshold for things considered a "tap"
|
||||
#define TAPPING_TERM 300
|
||||
|
||||
// Use Linux unicode mode
|
||||
#define UNICODE_SELECTED_MODES UNICODE_MODE_LINUX
|
||||
|
||||
// Custom USB HID info
|
||||
// #undef VENDOR_ID
|
||||
// #undef PRODUCT_ID
|
||||
// #undef DEVICE_VER
|
||||
// #undef MANUFACTURER
|
||||
// #undef PRODUCT
|
||||
// #define VENDOR_ID 0x6570 // "ep"
|
||||
// #define PRODUCT_ID 0x0458 // 4 "X"
|
||||
// #define DEVICE_VER 0x0021
|
||||
// #define MANUFACTURER ewpratten
|
||||
// #define PRODUCT tg4x
|
||||
|
||||
// Lighting settings
|
||||
#define RGBLIGHT_DEFAULT_MODE RGBLIGHT_MODE_STATIC_LIGHT
|
||||
#define RGBLIGHT_DEFAULT_HUE 0
|
||||
#define RGBLIGHT_DEFAULT_SAT 255
|
||||
#define RGBLIGHT_DEFAULT_VAL 255
|
||||
#define RGBLIGHT_DEFAULT_ON true
|
47
keyboards/qmk/keymaps/tg4x/keymap.c
Normal file
47
keyboards/qmk/keymaps/tg4x/keymap.c
Normal file
@ -0,0 +1,47 @@
|
||||
// Pull in the QMK lib
|
||||
#include QMK_KEYBOARD_H
|
||||
|
||||
/* Trickery to make VSCode happy */
|
||||
#include <stdint.h>
|
||||
#define _____ KC_NO
|
||||
#define _PASS KC_TRNS
|
||||
|
||||
/* Layer Definitions */
|
||||
// clang-format off
|
||||
enum tg4x_layers {
|
||||
QWERTY,
|
||||
NUMERIC,
|
||||
ACTIONS,
|
||||
};
|
||||
// clang-format on
|
||||
|
||||
/* Layers */
|
||||
// clang-format off
|
||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
|
||||
// QWERTY
|
||||
[QWERTY] = LAYOUT(
|
||||
KC_ESC, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_DEL, KC_BSPC,
|
||||
KC_TAB, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_ENT,
|
||||
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_RSFT, MO(NUMERIC),
|
||||
KC_LCTL, KC_LALT, KC_LGUI, KC_SPACE, KC_SPACE, MO(ACTIONS), _____, _____, _____
|
||||
),
|
||||
|
||||
// NUMERIC
|
||||
[NUMERIC] = LAYOUT(
|
||||
KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12,
|
||||
KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL,
|
||||
_PASS, _____, _____, _____, _____, KC_QUOTE, KC_SLSH, KC_LBRC, KC_RBRC, KC_BSLS, _____, _____,
|
||||
_PASS, _PASS, _PASS, KC_SPACE, KC_SPACE, _____, _____, _____, _____
|
||||
),
|
||||
|
||||
// ACTIONS
|
||||
[ACTIONS] = LAYOUT(
|
||||
_____, KC_VOLD, KC_VOLU, KC_MUTE, _____, _____, _____, KC_PGUP, _____, KC_PGDN, KC_PSCR, KC_SCRL, KC_PAUS,
|
||||
KC_CAPS, KC_MPRV, KC_MPLY, KC_MNXT, _____, _____, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT, KC_INS, _____,
|
||||
_PASS, RGB_TOG, _____, _____, _____, KC_HOME, KC_END, _____, _____, _____, _PASS, _____,
|
||||
_PASS, _PASS, _PASS, KC_SPACE, UC(0x00A0), _____, _____, _____, _____
|
||||
),
|
||||
|
||||
};
|
||||
// clang-format on
|
12
keyboards/qmk/keymaps/tg4x/rules.mk
Normal file
12
keyboards/qmk/keymaps/tg4x/rules.mk
Normal file
@ -0,0 +1,12 @@
|
||||
# Override the default bootloader since I am using a non-standard MCU
|
||||
BOOTLOADER = qmk-dfu
|
||||
|
||||
# Enable bootloader keys
|
||||
BOOTMAGIC_ENABLE = yes
|
||||
|
||||
# Enable Unicode
|
||||
UNICODE_COMMON = yes
|
||||
UNICODE_ENABLE = yes
|
||||
|
||||
# Enable RGB lighting
|
||||
RGBLIGHT_ENABLE = yes
|
24
python_modules/ewconfig/secret_manager.py
Normal file
24
python_modules/ewconfig/secret_manager.py
Normal file
@ -0,0 +1,24 @@
|
||||
import logging
|
||||
from pathlib import Path
|
||||
from typing import Optional
|
||||
|
||||
SEMI_SECRET_BASE_PATH = Path("~/.config/ewconfig/secrets/semi-secret").expanduser()
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
def get_semi_secret_string(name: str, namespace: Optional[str] = None) -> str:
|
||||
logger.debug(f"Attempting to load secret: {name} (ns: {namespace})")
|
||||
|
||||
# Construct file path
|
||||
file = SEMI_SECRET_BASE_PATH
|
||||
if namespace:
|
||||
file = file / namespace
|
||||
file = file / name
|
||||
|
||||
# Make sure it exists
|
||||
if not file.exists():
|
||||
raise FileNotFoundError(f"Could not load secret from: {file}")
|
||||
|
||||
# Read the value
|
||||
with open(file, "r") as f:
|
||||
return f.read().strip()
|
8
python_modules/ewconfig/trello/__init__.py
Normal file
8
python_modules/ewconfig/trello/__init__.py
Normal file
@ -0,0 +1,8 @@
|
||||
from ..secret_manager import get_semi_secret_string
|
||||
|
||||
TRELLO_API_KEY = "fba640a85f15c91e93e6b3f88e59489c"
|
||||
"""Public api key to do things to personal Trello"""
|
||||
|
||||
|
||||
def get_trello_api_token() -> str:
|
||||
return get_semi_secret_string("trello_api_token")
|
20
python_modules/ewconfig/trello/boards.py
Normal file
20
python_modules/ewconfig/trello/boards.py
Normal file
@ -0,0 +1,20 @@
|
||||
from dataclasses import dataclass
|
||||
from typing import Dict
|
||||
|
||||
|
||||
@dataclass
|
||||
class TrelloBoardInfo:
|
||||
id: str
|
||||
lists: Dict[str, str]
|
||||
tags: Dict[str, str]
|
||||
|
||||
|
||||
PERSONAL_TASKS_BOARD = TrelloBoardInfo(
|
||||
id="tw3Cn3L6",
|
||||
lists={"To Do": "6348a3ce5208f505b61d29bf"},
|
||||
tags={
|
||||
"GURU": "64e03ac77d27032282436d28",
|
||||
"Github: Issue": "64eb5d72fb694cd8f0ba7a8d",
|
||||
"Github: Pull Request": "652d4b775f5c59a8e6308216",
|
||||
},
|
||||
)
|
80
python_modules/ewconfig/trello/cards.py
Normal file
80
python_modules/ewconfig/trello/cards.py
Normal file
@ -0,0 +1,80 @@
|
||||
import requests
|
||||
import logging
|
||||
from typing import Any, Dict, List, Optional
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
def get_all_trello_cards(
|
||||
board_id: str, api_key: str, api_token: str
|
||||
) -> List[Dict[str, Any]]:
|
||||
# Get a list of cards on the board
|
||||
logger.debug(f"Getting all cards on board: {board_id}")
|
||||
response = requests.get(
|
||||
f"https://api.trello.com/1/boards/{board_id}/cards",
|
||||
params={
|
||||
"key": api_key,
|
||||
"token": api_token,
|
||||
},
|
||||
)
|
||||
response.raise_for_status()
|
||||
cards = response.json()
|
||||
logger.debug(f"Found {len(cards)} cards on board: {board_id}")
|
||||
return cards
|
||||
|
||||
|
||||
def create_card(
|
||||
list_id: str,
|
||||
name: str,
|
||||
api_key: str,
|
||||
api_token: str,
|
||||
description: Optional[str] = None,
|
||||
label_ids: Optional[List[str]] = None,
|
||||
position: str = "top",
|
||||
) -> str:
|
||||
logger.debug(f"Creating card: {name}")
|
||||
|
||||
# Build out params
|
||||
params = {
|
||||
"idList": list_id,
|
||||
"name": name,
|
||||
"key": api_key,
|
||||
"token": api_token,
|
||||
"pos": position,
|
||||
}
|
||||
if description:
|
||||
params["desc"] = description
|
||||
if label_ids:
|
||||
params["idLabels"] = ",".join(label_ids)
|
||||
|
||||
# Make a new card
|
||||
response = requests.post(
|
||||
"https://api.trello.com/1/cards",
|
||||
params=params,
|
||||
)
|
||||
response.raise_for_status()
|
||||
|
||||
# Get the new card's id
|
||||
card_id = response.json()["id"]
|
||||
|
||||
logger.debug(f"Created card: {card_id}")
|
||||
return card_id
|
||||
|
||||
|
||||
def add_attachment(
|
||||
card_id: str, api_key: str, api_token: str, url: Optional[str] = None
|
||||
) -> None:
|
||||
logger.debug(f"Adding attachment to card: {card_id}")
|
||||
params = {
|
||||
"key": api_key,
|
||||
"token": api_token,
|
||||
}
|
||||
if url:
|
||||
params["url"] = url
|
||||
|
||||
response = requests.post(
|
||||
f"https://api.trello.com/1/cards/{card_id}/attachments",
|
||||
params=params,
|
||||
)
|
||||
response.raise_for_status()
|
||||
logger.debug(f"Added attachment to card: {card_id}")
|
13
python_modules/ewpipe/common/dirs.py
Normal file
13
python_modules/ewpipe/common/dirs.py
Normal file
@ -0,0 +1,13 @@
|
||||
from pathlib import Path
|
||||
|
||||
DCC_DATA_BASE_DIR = Path.home() / "Videos" / "DCC"
|
||||
"""The base directory for storing data across DCCs"""
|
||||
|
||||
HOUDINI_BASE_DIR = DCC_DATA_BASE_DIR / "Houdini"
|
||||
"""The base directory for storing Houdini data"""
|
||||
|
||||
HOUDINI_PROJECTS_DIR = HOUDINI_BASE_DIR / "Projects"
|
||||
"""The base directory for storing Houdini projects"""
|
||||
|
||||
BLENDER_BASE_DIR = DCC_DATA_BASE_DIR / "Blender"
|
||||
"""The base directory for storing Blender data"""
|
31
python_modules/ewpipe/common/env.py
Normal file
31
python_modules/ewpipe/common/env.py
Normal file
@ -0,0 +1,31 @@
|
||||
import os
|
||||
from typing import Dict
|
||||
|
||||
|
||||
def diff_environments(env_1: Dict[str, str], env_2: Dict[str, str]) -> Dict[str, str]:
|
||||
"""Diff two environments.
|
||||
|
||||
Args:
|
||||
env_1 (Dict[str,str]): First environment
|
||||
env_2 (Dict[str,str]): Second environment
|
||||
|
||||
Returns:
|
||||
Dict[str,str]: Difference between the two environments
|
||||
"""
|
||||
return {
|
||||
key: value
|
||||
for key, value in env_1.items()
|
||||
if key not in env_2 or env_2[key] != value
|
||||
}
|
||||
|
||||
|
||||
def diff_from_current_env(new_env: Dict[str, str]) -> Dict[str, str]:
|
||||
"""Diff the current environment from the given environment.
|
||||
|
||||
Args:
|
||||
new_env (Dict[str, str]): New environment
|
||||
|
||||
Returns:
|
||||
Dict[str, str]: Difference between the current environment and the given environment
|
||||
"""
|
||||
return diff_environments(os.environ, new_env) # type: ignore
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user