{"id":20905041,"url":"https://github.com/kaste/sharc","last_synced_at":"2025-06-26T10:03:12.666Z","repository":{"id":7244344,"uuid":"8554548","full_name":"kaste/sharc","owner":"kaste","description":"Sharded Counters on Google Appengine","archived":false,"fork":false,"pushed_at":"2013-03-04T11:55:59.000Z","size":112,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-05-18T19:40:45.663Z","etag":null,"topics":["app-engine","google-appengine"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kaste.png","metadata":{"files":{"readme":"README.rst","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2013-03-04T11:51:46.000Z","updated_at":"2022-06-14T19:54:54.000Z","dependencies_parsed_at":"2022-09-19T08:00:22.402Z","dependency_job_id":null,"html_url":"https://github.com/kaste/sharc","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/kaste/sharc","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kaste%2Fsharc","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kaste%2Fsharc/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kaste%2Fsharc/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kaste%2Fsharc/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kaste","download_url":"https://codeload.github.com/kaste/sharc/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kaste%2Fsharc/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":261571501,"owners_count":23178766,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["app-engine","google-appengine"],"created_at":"2024-11-18T13:21:11.243Z","updated_at":"2025-06-26T10:03:12.649Z","avatar_url":"https://github.com/kaste.png","language":"Python","readme":"\nJoe Gregorio originally `posted \u003chttps://developers.google.com/appengine/articles/sharding_counters#implv2_python\u003e`_ about Sharded Counters for Google Appengine.\n\nThis is like a downloadable gist::\n\n    from sharc import Counter\n\n    assert not Counter('A').exists()\n\n    Counter('A', initial_value=5, shards=5)\n    assert Counter('A').exists()\n\n    Counter('A').increment()\n    Counter('A').decrement()\n    Counter('A') + 2\n    Counter('A') - 2\n\n    assert Counter('A') == 5\n\n    Counter('A').shards = 10\n\n    Counter('A').delete()   # .delete_async()\n    assert not Counter('A').exists()\n\n\n\n\n- Added decrement\n- Increment and decrement variable deltas (default=1)\n- Set initial value of the counter (default=0)\n- Set initial value of the num of shards (default=20)\n- Added delete()","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkaste%2Fsharc","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkaste%2Fsharc","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkaste%2Fsharc/lists"}