You've already forked slimbootloader
mirror of
https://github.com/Dasharo/slimbootloader.git
synced 2026-03-06 15:26:20 -08:00
Convert the line endings stored for all text files in the repository to LF. The majority previously used DOS-style CRLF line endings. Add a .gitattributes file to enforce this and treat certain extensions as never being text files. Update PatchCheck.py to insist on LF line endings rather than CRLF. However, its other checks fail on this commit due to lots of pre-existing complaints that it only notices because the line endings have changed. Silicon/QemuSocPkg/FspBin/Patches/0001-Build-QEMU-FSP-2.0-binaries.patch needs to be treated as binary since it contains a mixture of line endings. This change has implications depending on the client platform you are using the repository from: * Windows The usual configuration for Git on Windows means that text files will be checked out to the work tree with DOS-style CRLF line endings. If that's not the case then you can configure Git to do so for the entire machine with: git config --global core.autocrlf true or for just the repository with: git config core.autocrlf true Line endings will be normalised to LF when they are committed to the repository. If you commit a text file with only LF line endings then it will be converted to CRLF line endings in your work tree. * Linux, MacOS and other Unices The usual configuration for Git on such platforms is to check files out of the repository with LF line endings. This is probably the right thing for you. In the unlikely even that you are using Git on Unix but editing or compiling on Windows for some reason then you may need to tweak your configuration to force the use of CRLF line endings as described above. * General For more information see https://docs.github.com/en/get-started/getting-started-with-git/configuring-git-to-handle-line-endings . Fixes: https://github.com/slimbootloader/slimbootloader/issues/1400 Signed-off-by: Mike Crowe <mac@mcrowe.com>
151 lines
4.8 KiB
Python
151 lines
4.8 KiB
Python
## @file
|
|
# manage multiple workspace file.
|
|
#
|
|
# This file is required to make Python interpreter treat the directory
|
|
# as containing package.
|
|
#
|
|
# Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
#
|
|
|
|
import Common.LongFilePathOs as os
|
|
from Common.DataType import TAB_WORKSPACE
|
|
|
|
## MultipleWorkspace
|
|
#
|
|
# This class manage multiple workspace behavior
|
|
#
|
|
# @param class:
|
|
#
|
|
# @var WORKSPACE: defined the current WORKSPACE
|
|
# @var PACKAGES_PATH: defined the other WORKSPACE, if current WORKSPACE is invalid, search valid WORKSPACE from PACKAGES_PATH
|
|
#
|
|
class MultipleWorkspace(object):
|
|
WORKSPACE = ''
|
|
PACKAGES_PATH = None
|
|
|
|
## convertPackagePath()
|
|
#
|
|
# Convert path to match workspace.
|
|
#
|
|
# @param cls The class pointer
|
|
# @param Ws The current WORKSPACE
|
|
# @param Path Path to be converted to match workspace.
|
|
#
|
|
@classmethod
|
|
def convertPackagePath(cls, Ws, Path):
|
|
if str(os.path.normcase (Path)).startswith(Ws):
|
|
return os.path.join(Ws, os.path.relpath(Path, Ws))
|
|
return Path
|
|
|
|
## setWs()
|
|
#
|
|
# set WORKSPACE and PACKAGES_PATH environment
|
|
#
|
|
# @param cls The class pointer
|
|
# @param Ws initialize WORKSPACE variable
|
|
# @param PackagesPath initialize PackagesPath variable
|
|
#
|
|
@classmethod
|
|
def setWs(cls, Ws, PackagesPath=None):
|
|
cls.WORKSPACE = Ws
|
|
if PackagesPath:
|
|
cls.PACKAGES_PATH = [cls.convertPackagePath (Ws, os.path.normpath(Path.strip())) for Path in PackagesPath.split(os.pathsep)]
|
|
else:
|
|
cls.PACKAGES_PATH = []
|
|
|
|
## join()
|
|
#
|
|
# rewrite os.path.join function
|
|
#
|
|
# @param cls The class pointer
|
|
# @param Ws the current WORKSPACE
|
|
# @param *p path of the inf/dec/dsc/fdf/conf file
|
|
# @retval Path the absolute path of specified file
|
|
#
|
|
@classmethod
|
|
def join(cls, Ws, *p):
|
|
Path = os.path.join(Ws, *p)
|
|
if not os.path.exists(Path):
|
|
for Pkg in cls.PACKAGES_PATH:
|
|
Path = os.path.join(Pkg, *p)
|
|
if os.path.exists(Path):
|
|
return Path
|
|
Path = os.path.join(Ws, *p)
|
|
return Path
|
|
|
|
## relpath()
|
|
#
|
|
# rewrite os.path.relpath function
|
|
#
|
|
# @param cls The class pointer
|
|
# @param Path path of the inf/dec/dsc/fdf/conf file
|
|
# @param Ws the current WORKSPACE
|
|
# @retval Path the relative path of specified file
|
|
#
|
|
@classmethod
|
|
def relpath(cls, Path, Ws):
|
|
for Pkg in cls.PACKAGES_PATH:
|
|
if Path.lower().startswith(Pkg.lower()):
|
|
Path = os.path.relpath(Path, Pkg)
|
|
return Path
|
|
if Path.lower().startswith(Ws.lower()):
|
|
Path = os.path.relpath(Path, Ws)
|
|
return Path
|
|
|
|
## getWs()
|
|
#
|
|
# get valid workspace for the path
|
|
#
|
|
# @param cls The class pointer
|
|
# @param Ws the current WORKSPACE
|
|
# @param Path path of the inf/dec/dsc/fdf/conf file
|
|
# @retval Ws the valid workspace relative to the specified file path
|
|
#
|
|
@classmethod
|
|
def getWs(cls, Ws, Path):
|
|
absPath = os.path.join(Ws, Path)
|
|
if not os.path.exists(absPath):
|
|
for Pkg in cls.PACKAGES_PATH:
|
|
absPath = os.path.join(Pkg, Path)
|
|
if os.path.exists(absPath):
|
|
return Pkg
|
|
return Ws
|
|
|
|
## handleWsMacro()
|
|
#
|
|
# handle the $(WORKSPACE) tag, if current workspace is invalid path relative the tool, replace it.
|
|
#
|
|
# @param cls The class pointer
|
|
# @retval PathStr Path string include the $(WORKSPACE)
|
|
#
|
|
@classmethod
|
|
def handleWsMacro(cls, PathStr):
|
|
if TAB_WORKSPACE in PathStr:
|
|
PathList = PathStr.split()
|
|
if PathList:
|
|
for i, str in enumerate(PathList):
|
|
MacroStartPos = str.find(TAB_WORKSPACE)
|
|
if MacroStartPos != -1:
|
|
Substr = str[MacroStartPos:]
|
|
Path = Substr.replace(TAB_WORKSPACE, cls.WORKSPACE).strip()
|
|
if not os.path.exists(Path):
|
|
for Pkg in cls.PACKAGES_PATH:
|
|
Path = Substr.replace(TAB_WORKSPACE, Pkg).strip()
|
|
if os.path.exists(Path):
|
|
break
|
|
PathList[i] = str[0:MacroStartPos] + Path
|
|
PathStr = ' '.join(PathList)
|
|
return PathStr
|
|
|
|
## getPkgPath()
|
|
#
|
|
# get all package paths.
|
|
#
|
|
# @param cls The class pointer
|
|
#
|
|
@classmethod
|
|
def getPkgPath(cls):
|
|
return cls.PACKAGES_PATH
|
|
|