Browse Source
Linktastic calls the command line interpreter to do linking. This solution calls the windows API directly. This is faster and cleaner, but most important of all: it doesn't cause a command window to popup every time a link is made. This popup asks window focus and thus interrupts a movie you are watching!! Hopefully this also works on non-windows systems. I am unable to test this so please let me know :)pull/1680/head
committed by
Ruud
3 changed files with 15 additions and 80 deletions
@ -1,76 +0,0 @@ |
|||
# Linktastic Module |
|||
# - A python2/3 compatible module that can create hardlinks/symlinks on windows-based systems |
|||
# |
|||
# Linktastic is distributed under the MIT License. The follow are the terms and conditions of using Linktastic. |
|||
# |
|||
# The MIT License (MIT) |
|||
# Copyright (c) 2012 Solipsis Development |
|||
# |
|||
# Permission is hereby granted, free of charge, to any person obtaining a copy of this software and |
|||
# associated documentation files (the "Software"), to deal in the Software without restriction, |
|||
# including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, |
|||
# and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, |
|||
# subject to the following conditions: |
|||
# |
|||
# The above copyright notice and this permission notice shall be included in all copies or substantial |
|||
# portions of the Software. |
|||
# |
|||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
|||
# LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
|||
# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
|||
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
|||
# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
|||
|
|||
import subprocess |
|||
from subprocess import CalledProcessError |
|||
import os |
|||
|
|||
|
|||
# Prevent spaces from messing with us! |
|||
def _escape_param(param): |
|||
return '"%s"' % param |
|||
|
|||
|
|||
# Private function to create link on nt-based systems |
|||
def _link_windows(src, dest): |
|||
try: |
|||
subprocess.check_output( |
|||
'cmd /C mklink /H %s %s' % (_escape_param(dest), _escape_param(src)), |
|||
stderr=subprocess.STDOUT) |
|||
except CalledProcessError as err: |
|||
|
|||
raise IOError(err.output.decode('utf-8')) |
|||
|
|||
# TODO, find out what kind of messages Windows sends us from mklink |
|||
# print(stdout) |
|||
# assume if they ret-coded 0 we're good |
|||
|
|||
|
|||
def _symlink_windows(src, dest): |
|||
try: |
|||
subprocess.check_output( |
|||
'cmd /C mklink %s %s' % (_escape_param(dest), _escape_param(src)), |
|||
stderr=subprocess.STDOUT) |
|||
except CalledProcessError as err: |
|||
raise IOError(err.output.decode('utf-8')) |
|||
|
|||
# TODO, find out what kind of messages Windows sends us from mklink |
|||
# print(stdout) |
|||
# assume if they ret-coded 0 we're good |
|||
|
|||
|
|||
# Create a hard link to src named as dest |
|||
# This version of link, unlike os.link, supports nt systems as well |
|||
def link(src, dest): |
|||
if os.name == 'nt': |
|||
_link_windows(src, dest) |
|||
else: |
|||
os.link(src, dest) |
|||
|
|||
|
|||
# Create a symlink to src named as dest, but don't fail if you're on nt |
|||
def symlink(src, dest): |
|||
if os.name == 'nt': |
|||
_symlink_windows(src, dest) |
|||
else: |
|||
os.symlink(src, dest) |
Loading…
Reference in new issue