Skip to main content

Work on patches based on files and directories

Project description

patchutils

patchutils provide utilities for making patches from directories and applying patches to directories. If you like the library and use it in your project, please consider giving us a star :star:

Made with :heart: by Contributers

Usage

Installation

from pip:

pip install patchutils -U

from latest repo

git clone xcodz-dot/patchutils
pip install poetry
poetry install

do not use poetry until you know how it works

API Documentation

You can check the steps to build documentation by doing this:

>>> import patchutils
>>> help(patchutils)

For your convinience all documentation is pre-built under the docs directory.

Concept

There are three things to be noted:

  • directory information
  • patch
  • update files

Directory Information

Directory Information is a simple dictionary object containing 3 fields:

  • files

    Files is a list that contain relative paths for all the files for the provided directory.

  • directories

    Directories is a list that contain relative paths for all the subdirectories for the provided directory.

  • hash

    Hash is a dictionary with key as file names and values as SHA-256 checksums for the respective files.

Here is a Sample Directory Information:

{
    "files": [
        "my_file_1.txt",
        "folder1/myfile2.txt",
        "folder2/another_folder/myfile3.txt"
    ],
    "directories": [
        "folder1",
        "folder2",
        "folder2/another_folder",
        "empty_folder"
    ],
    "hash": {
        "my_file_1.txt": "blablablablbalbalblblablblblblblblbl some sha hash blahblabla",
        "folder1/myfile2.txt": "blablablablablablablablablabla hash is in a hexdigest format",
        "folder2/another_folder/myfile3.txt": "blablablablbalbalblablg7ty913griubkeda"
    }
}

Patch

Patch is a dictionary that tells what changes have been made in comparision to two different Directory Informations. It consists of the following feilds:

  • files_added

    List of Files added in comparision to the old directory information

  • files_removed

    List of Files removed in comparision to the old directory information

  • files_modified

    List of Files modified in comparision to the old directory information

  • directories_added

    List of directories added including empty directories

  • directories_removed

    List of directories removed including all their content within them

Here is an example patch:

{
    "files_added": ["new_file.txt"],
    "files_removed": ["i_hate_python.txt"],
    "files_modified": ["why_i_like_python.txt"],
    "directories_added": ["Temp"],
    "directories_removed": [".Temp"],
    "hash": {
        "new_file.txt": "blablablablbalbalbalbblablbablablbalbblabla",
        "why_i_like_python.txt": "blablablablablablablablablalbalgialbdblablbla"
    }
}

Update Files

Update files are simple uncompressed zip archives that are made using patch. Here is a typical workflow of a server and a client requesting updates:

  • Clients gives their version number to the server.
  • Server checks the version number and loads up stored directory information for that version.
  • Server creates a patch using the latest directory information and that specific version directory information.
  • Server creates an uncompressed update file and starts streaming it to the client OR alternatively server sends the patch in json format and client starts querying the server for different files listed in the patch and applies the patch to required positions.
  • If the client recieved the update file instead of patch information then the client applies the update file to the required positions.

Alternatively to above if their is no version specifications then the workflow might look like this:

  • Client generates directory information from local filesystem and sends it to the server
  • Server creates a patch using client provided directory information and latest server directory information.
  • And from this point on the process of updating is same as in above example

Contributers


xcodz-dot

💻 📖 🚇 ⚠️ 🚧

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

patchutils-1.2.0.tar.gz (16.3 kB view details)

Uploaded Source

Built Distribution

patchutils-1.2.0-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

Details for the file patchutils-1.2.0.tar.gz.

File metadata

  • Download URL: patchutils-1.2.0.tar.gz
  • Upload date:
  • Size: 16.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.8 CPython/3.10.2 Linux/5.16.14-200.fc35.x86_64

File hashes

Hashes for patchutils-1.2.0.tar.gz
Algorithm Hash digest
SHA256 9ec54459062d4ed839907e96df7506839c6313953fc188345af2477867594802
MD5 3eefbf18b9c19b070ea872bca86bfb3f
BLAKE2b-256 004d5a046d93b915067df11cc860dcf30410615ad762ca322af9838410a6b2cc

See more details on using hashes here.

File details

Details for the file patchutils-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: patchutils-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 16.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.8 CPython/3.10.2 Linux/5.16.14-200.fc35.x86_64

File hashes

Hashes for patchutils-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 613a36f0d2501871aa3ade48a13f8d127e10897c75d4cfa5f6d27225b309565b
MD5 185220917f88df7249a25df5969d5cea
BLAKE2b-256 542e9c73de79ec8c66c9946d46778e99ff6880626a7db43a80cefdb5086f38ac

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page