TL;DR:
sudo -iis not an interactive logon torootsudo -i bashis interactive and *does* execute/root/.bashrc
Source: [WayBack] sudo command doesn’t source /root/.bashrc – Unix & Linux Stack Exchange
–jeroen
Posted by jpluimers on 2019/03/08
TL;DR:
sudo -i is not an interactive logon to rootsudo -i bash is interactive and *does* execute /root/.bashrcSource: [WayBack] sudo command doesn’t source /root/.bashrc – Unix & Linux Stack Exchange
–jeroen
Posted in *nix, *nix-tools, bash, Power User | Leave a Comment »
Posted by jpluimers on 2019/03/08
I agree: [WayBack] It’s so obvious I hadn’t thought about this.. – Roderick Gadellaa – Google+.
[WayBack] Reminder tip: Disable Wi-Fi during sleep to dramatically increase idle battery life on tablets and devices you don’t often use
–jeroen
Posted in Android Devices, LifeHacker, Power User | Leave a Comment »
Posted by jpluimers on 2019/03/07
Wow, I totally forgot I had done this xslt trick eons ago: [WayBack] detect availability of node-set() function in xslt implementation of icecast server – Stack Overflow
–jeroen
Posted in Development, Software Development, XML/XSD, XSLT | Leave a Comment »
Posted by jpluimers on 2019/03/07
SourceTree does not like it when by accident two git stash entries have exactly the same name.
To work around that, you have to rename one.
The easiest way to do this is on the console using the tips from [WayBack] How can I rename a git stash? – Stack Overflow (thanks [WayBack] qzb):
$ git stash list
stash@{0}: WIP on master: Add some very important feature
stash@{1}: WIP on master: Fix some silly bugFirst, you must remove stash entry which you want to rename:
$ git stash drop stash@{1}
Dropped stash@{1} (af8fdeee49a03d1b4609f294635e7f0d622e03db)Now just add it again with new message using sha of commit returned after dropping:
$ git stash store -m "Very descriptive message" af8fdeee49a03d1b4609f294635e7f0d622e03dbAnd that’s it:
$ git stash list
stash@{0}: Very descriptive message
stash@{1}: WIP on master: Add some very important featureThis solution requires git 1.8.4 or later, and yes, it works with dirty working directory too.
Some other useful git stash commands:
{0} and prior {1} stash:
git stash show -pgit stash show -p{1}git stash list --date=localgit stash list --date=relative–jeroen
Posted in Development, DVCS - Distributed Version Control, git, Software Development, Source Code Management, SourceTree | Leave a Comment »
Posted by jpluimers on 2019/03/07
If you get a message like this in Atom when using plantuml-preview:
then you need to change the PlantUML Jar setting from your old version (in my case /usr/local/Cellar/plantuml/1.2017.13/libexec/plantuml.jar:
Then you have to save your .plantuml file so the preview re-renders.
This finds the homebrew installed PlantUML versions:
$ find /usr/local/Cellar/plantuml | grep plantuml.jar
/usr/local/Cellar/plantuml/1.2017.13/libexec/plantuml.jar
/usr/local/Cellar/plantuml/1.2017.14/libexec/plantuml.jar
–jeroen
Posted in Development, Diagram, PlantUML, Software Development, UML | Leave a Comment »
Posted by jpluimers on 2019/03/06
Delphi and FPC have different language boundaries, so it is always good to read a thread discussing how to get near-the-edge cases work in both.
This case is about Smart Pointers (here called auto pointers, maybe because auto_ptr is what they used to be called in C++): [WayBack] Hi all, I am trying to make a certain piece of code cross compile between Delphi and FPC. On FPC, it compiles fine but on Delphi I get a [dcc32 Error] P… – Ugochukwu Mmaduekwe – Google+
In the end if comes down to that Delphi does not allow forward-declaration of records (it does for interfaces and classes), but that you do not need a __PAutoPtr_T = ^__TAutoPtr_T, because you can use ^__TAutoPtr_T in parameters.
In Spring4D, they are called Shared/IShared/TShared, see my comment:
Note that since these are reference counted, you might want to call them
shared_ptr. If you enforce the single-instance behaviour, observe that in C++ they are now calleduniqe_ptr.In Spring4D this rename has already taken place a while ago: https://bitbucket.org/sglienke/spring4d/commits/e252b81fd3788cf5b82588721f68d00c892deb87
–jeroen
Posted in Conference Topics, Conferences, Delphi, Development, Event, Software Development | 2 Comments »
Posted by jpluimers on 2019/03/06
If I ever need to get LetsEncrypt to work with CloudFlare, then I need to read [WayBack] Installing Let’s Encrypt Free SSL/TLS Certificate in 2 Minutes with Certbot, Spending Hours Making it Work with Cloudflare
The steps there should save me hours.
Via [WayBcack] Free Let’s Encrypt SSL/TLS certificates are even easier to install than self-signed certificates. I could do so in 2 minutes in my +Linode … – Jean-Luc Aufranc – Google+.
–jeroen
Posted in Encryption, Let's Encrypt (letsencrypt/certbot), Power User, Security | Leave a Comment »
Posted by jpluimers on 2019/03/06
With the removal of the C# based Windows vSphere Client in ESXi 6.5, the vSphere HTML5 Web Client is the way to go.
It doesn’t cover all functionality yet, and some functionality is in different places in the UI, so below the steps to change the hostname.
Since I prefer a central location of name and address management, I’ve also documented on how to do this with DHCP option 12.
Oh: I’m not alone in finding the changed place
Posted in Development, ESXi6.5, Hardware, MikroTik, Network-and-equipment, Power User, RouterOS, routers, Scripting, Software Development, Virtualization, VMware, VMware ESXi, WinBox | Leave a Comment »
Posted by jpluimers on 2019/03/05
[WayBack] gdbgui – browser based debugger for C, C++, go, rust, Fortran. Modern gdb frontend.: gdbgui (gnu debugger graphical user interface)
Via: [WayBack] Browser-based debugger for C, C++, go, rust, and more – written in Python with Flask. https://github.com/cs01/gdbgui Easy installation via PyPI: pip i… – Joe C. Hecht – Google+
–jeroen
Posted in C, C++, Debugging, Development, Fortran, GDB, Go (golang), Python, Scripting, Software Development | Leave a Comment »
Posted by jpluimers on 2019/03/05
Below are the git statements I used to solve this ASCII art problem from me (as I work in Git Flow feature branches):
old situation:
commit-1..4 - commit-5 - commit-6 - commit-7 - commit-8 - commit-9
^ ^ ^ ^ ^
| | | | |
master develop feature/A feature/old
to:
commit-1..4 - commit-5 - commit-6 - commit-7 - commit-8 - commit-9
^ ^ ^ ^ ^
| | | | |
master develop feature/A feature/old feature/new
git branch
git rev-parse HEAD
git log --pretty=format:'%H' -n 2
git checkout -b feature/new hash-of-commit-8
git branch --set-upstream-to=feature/old
git cherry-pick ..feature/old
git branch --force feature/old hash-of-commit-8
Step by step, this is what happens:
branch lists the current branchesrev-parse HEAD shows the hash of the current commit (commit-9)log --pretty=format:'%H' -n 1shows the hash of the previous two commits (from top to bottom: commit-9 and commit-8)checkout creates a new branch based on the past commit-8branch --set-upstream ensures the new branch tracks the old branchcherry pick ensures the new branch gets all the commits from the old branchbranch --force ensure the old branch looses the extra commits you wanted to only be in newBranchNameBased on
–jeroen
Posted in Development, DVCS - Distributed Version Control, git, Power User, Software Development, Source Code Management | Leave a Comment »