| route-pattern | /_view_fragments/voltron/pull_requests/show/:user_id/:repository/:id/pull_request_layout(.:format) |
| route-controller | voltron_pull_requests_fragments |
| route-action | pull_request_layout |
| fetch-nonce | v2:245bad91-ed2f-8abd-b22b-3b75fe46a588 |
| current-catalog-service-hash | ae870bc5e265a340912cde392f23dad3671a0a881730ffdadd82f2f57d81641b |
| request-id | 981E:20C836:42FE2E:599C71:698ED24A |
| html-safe-nonce | f6117a628d733439ade739e49f726730e79bdb2bd04a973bbb4f92cbf822e6e1 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5ODFFOjIwQzgzNjo0MkZFMkU6NTk5QzcxOjY5OEVEMjRBIiwidmlzaXRvcl9pZCI6IjQwMzc0NzEwMjAzOTQ2NjQ1MjIiLCJyZWdpb25fZWRnZSI6ImlhZCIsInJlZ2lvbl9yZW5kZXIiOiJpYWQifQ== |
| visitor-hmac | a258b497b47dabf5e854f8eb7c887be53c81f2f9195066abe58bf8714e9a31cf |
| hovercard-subject-tag | pull_request:3225834993 |
| github-keyboard-shortcuts | repository,pull-request-list,pull-request-conversation,pull-request-files-changed,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | ///voltron/pull_requests_fragments/pull_request_layout |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/voltron/pull_requests/show/posit-dev/ggsql/90/pull_request_layout |
| twitter:image | https://opengraph.githubassets.com/51e0c9b6c96b70623efcf306582df4f8b52307f8e49d7242c7387ac4307a82cb/posit-dev/ggsql/pull/90 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/51e0c9b6c96b70623efcf306582df4f8b52307f8e49d7242c7387ac4307a82cb/posit-dev/ggsql/pull/90 |
| og:image:alt | This PR builds on #89 to improve the Python package with a cleaner API structure, proper IDE support, and better error handling.
API Tweaks
Before
import ggsql
import polars as pl
df = pl.DataFram... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | cpsievert |
| hostname | github.com |
| expected-hostname | github.com |
| None | cb2828a801ee6b7be618f3ac76fbf55def35bbc30f053a9c41bf90210b8b72ba |
| turbo-cache-control | no-preview |
| go-import | github.com/posit-dev/ggsql git https://github.com/posit-dev/ggsql.git |
| octolytics-dimension-user_id | 107264312 |
| octolytics-dimension-user_login | posit-dev |
| octolytics-dimension-repository_id | 1109924834 |
| octolytics-dimension-repository_nwo | posit-dev/ggsql |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 1109924834 |
| octolytics-dimension-repository_network_root_nwo | posit-dev/ggsql |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | e6b91a7e6e46287d26887e3fb7a4161657bab8f7 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
| Skip to content | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#start-of-content |
|
| https://patch-diff.githubusercontent.com/ |
|
Sign in
| https://patch-diff.githubusercontent.com/login?return_to=https%3A%2F%2Fgithub.com%2Fposit-dev%2Fggsql%2Fpull%2F90 |
| GitHub CopilotWrite better code with AI | https://github.com/features/copilot |
| GitHub SparkBuild and deploy intelligent apps | https://github.com/features/spark |
| GitHub ModelsManage and compare prompts | https://github.com/features/models |
| MCP RegistryNewIntegrate external tools | https://github.com/mcp |
| ActionsAutomate any workflow | https://github.com/features/actions |
| CodespacesInstant dev environments | https://github.com/features/codespaces |
| IssuesPlan and track work | https://github.com/features/issues |
| Code ReviewManage code changes | https://github.com/features/code-review |
| GitHub Advanced SecurityFind and fix vulnerabilities | https://github.com/security/advanced-security |
| Code securitySecure your code as you build | https://github.com/security/advanced-security/code-security |
| Secret protectionStop leaks before they start | https://github.com/security/advanced-security/secret-protection |
| Why GitHub | https://github.com/why-github |
| Documentation | https://docs.github.com |
| Blog | https://github.blog |
| Changelog | https://github.blog/changelog |
| Marketplace | https://github.com/marketplace |
| View all features | https://github.com/features |
| Enterprises | https://github.com/enterprise |
| Small and medium teams | https://github.com/team |
| Startups | https://github.com/enterprise/startups |
| Nonprofits | https://github.com/solutions/industry/nonprofits |
| App Modernization | https://github.com/solutions/use-case/app-modernization |
| DevSecOps | https://github.com/solutions/use-case/devsecops |
| DevOps | https://github.com/solutions/use-case/devops |
| CI/CD | https://github.com/solutions/use-case/ci-cd |
| View all use cases | https://github.com/solutions/use-case |
| Healthcare | https://github.com/solutions/industry/healthcare |
| Financial services | https://github.com/solutions/industry/financial-services |
| Manufacturing | https://github.com/solutions/industry/manufacturing |
| Government | https://github.com/solutions/industry/government |
| View all industries | https://github.com/solutions/industry |
| View all solutions | https://github.com/solutions |
| AI | https://github.com/resources/articles?topic=ai |
| Software Development | https://github.com/resources/articles?topic=software-development |
| DevOps | https://github.com/resources/articles?topic=devops |
| Security | https://github.com/resources/articles?topic=security |
| View all topics | https://github.com/resources/articles |
| Customer stories | https://github.com/customer-stories |
| Events & webinars | https://github.com/resources/events |
| Ebooks & reports | https://github.com/resources/whitepapers |
| Business insights | https://github.com/solutions/executive-insights |
| GitHub Skills | https://skills.github.com |
| Documentation | https://docs.github.com |
| Customer support | https://support.github.com |
| Community forum | https://github.com/orgs/community/discussions |
| Trust center | https://github.com/trust-center |
| Partners | https://github.com/partners |
| GitHub SponsorsFund open source developers | https://github.com/sponsors |
| Security Lab | https://securitylab.github.com |
| Maintainer Community | https://maintainers.github.com |
| Accelerator | https://github.com/accelerator |
| Archive Program | https://archiveprogram.github.com |
| Topics | https://github.com/topics |
| Trending | https://github.com/trending |
| Collections | https://github.com/collections |
| Enterprise platformAI-powered developer platform | https://github.com/enterprise |
| GitHub Advanced SecurityEnterprise-grade security features | https://github.com/security/advanced-security |
| Copilot for BusinessEnterprise-grade AI features | https://github.com/features/copilot/copilot-business |
| Premium SupportEnterprise-grade 24/7 support | https://github.com/premium-support |
| Pricing | https://github.com/pricing |
| Search syntax tips | https://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax |
| documentation | https://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax |
|
Sign in
| https://patch-diff.githubusercontent.com/login?return_to=https%3A%2F%2Fgithub.com%2Fposit-dev%2Fggsql%2Fpull%2F90 |
|
Sign up
| https://patch-diff.githubusercontent.com/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fvoltron%2Fpull_requests_fragments%2Fpull_request_layout&source=header-repo&source_repo=posit-dev%2Fggsql |
| Reload | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| Reload | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| Reload | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
|
posit-dev
| https://patch-diff.githubusercontent.com/posit-dev |
| ggsql | https://patch-diff.githubusercontent.com/posit-dev/ggsql |
|
Notifications
| https://patch-diff.githubusercontent.com/login?return_to=%2Fposit-dev%2Fggsql |
|
Fork
4
| https://patch-diff.githubusercontent.com/login?return_to=%2Fposit-dev%2Fggsql |
|
Star
34
| https://patch-diff.githubusercontent.com/login?return_to=%2Fposit-dev%2Fggsql |
|
Code
| https://patch-diff.githubusercontent.com/posit-dev/ggsql |
|
Issues
29
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/issues |
|
Pull requests
10
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pulls |
|
Actions
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/actions |
|
Projects
0
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/projects |
|
Security
0
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/security |
|
Insights
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pulse |
|
Code
| https://patch-diff.githubusercontent.com/posit-dev/ggsql |
|
Issues
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/issues |
|
Pull requests
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pulls |
|
Actions
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/actions |
|
Projects
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/projects |
|
Security
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/security |
|
Insights
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pulse |
| Sign up for GitHub
| https://patch-diff.githubusercontent.com/signup?return_to=%2Fposit-dev%2Fggsql%2Fissues%2Fnew%2Fchoose |
| terms of service | https://docs.github.com/terms |
| privacy statement | https://docs.github.com/privacy |
| Sign in | https://patch-diff.githubusercontent.com/login?return_to=%2Fposit-dev%2Fggsql%2Fissues%2Fnew%2Fchoose |
| Jump to bottom | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#issue-comment-box |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| posit-dev:rust-api | https://patch-diff.githubusercontent.com/posit-dev/ggsql/tree/rust-api |
| cpsievert:rust-api-refactor | https://patch-diff.githubusercontent.com/cpsievert/ggsql/tree/rust-api-refactor |
|
Refactor API: Writer-centric rendering and Python module restructure
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#top |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| posit-dev:rust-api | https://patch-diff.githubusercontent.com/posit-dev/ggsql/tree/rust-api |
| cpsievert:rust-api-refactor | https://patch-diff.githubusercontent.com/cpsievert/ggsql/tree/rust-api-refactor |
|
Conversation
4
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
|
Commits
7
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits |
|
Checks
13
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/checks |
|
Files changed
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/files |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| https://github.co/hiddenchars |
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/{{ revealButtonHref }} |
|
| https://patch-diff.githubusercontent.com/cpsievert |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| Jan 30, 2026 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#issue-3873408515 |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| #89 | https://github.com/posit-dev/ggsql/pull/89 |
| Claude Code | https://claude.ai/code |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| January 29, 2026 19:40 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#commits-pushed-7cb225e |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Refactor Rust API: Writer::render(), Reader::execute_sql(), unregister() | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/7cb225e9407cf1e46afc4651366cfb4c6cc287cc |
| 7cb225e | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/7cb225e9407cf1e46afc4651366cfb4c6cc287cc |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Restructure Python bindings with cleaner module hierarchy | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/9d522401f2f2e94a01b0ef102523611d3af6f76a |
| 9d52240 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/9d522401f2f2e94a01b0ef102523611d3af6f76a |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Update Python tests for new API structure | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/3fa8574cce8355b1818f190b19c96c080238944d |
| 3fa8574 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/3fa8574cce8355b1818f190b19c96c080238944d |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Update documentation for new API structure | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/cfa3114a10196924d504653764414a2844eb6d0b |
| cfa3114 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/cfa3114a10196924d504653764414a2844eb6d0b |
| https://patch-diff.githubusercontent.com/cpsievert |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
|
Jan 30, 2026
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#ref-pullrequest-3870651694 |
|
Add high-level Rust API and rework Python bindings
#89
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/89 |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| January 29, 2026 19:51 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#commits-pushed-471602e |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Fix formatting (cargo fmt) | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/471602ecaf1ce0418ec7462aff972738ee4b9762 |
| 471602e | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/471602ecaf1ce0418ec7462aff972738ee4b9762 |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Fix REST API for NoVisualise error and clippy warnings | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/3bafd5fc696bd9d2bbae0b03a889164f12a4719d |
| 3bafd5f | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/3bafd5fc696bd9d2bbae0b03a889164f12a4719d |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/claude |
| Add Reader ABC for custom reader implementations | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/84091f6fb7eafcf9399755f91d0ebb945264cb5b |
| 84091f6 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/commits/84091f6fb7eafcf9399755f91d0ebb945264cb5b |
| https://patch-diff.githubusercontent.com/cpsievert |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| January 30, 2026 02:17 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#event-22393635725 |
| https://patch-diff.githubusercontent.com/cpsievert |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| Jan 30, 2026 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#issuecomment-3821494226 |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| @georgestagg | https://github.com/georgestagg |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| https://patch-diff.githubusercontent.com/georgestagg |
| georgestagg | https://patch-diff.githubusercontent.com/georgestagg |
| Feb 2, 2026 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#issuecomment-3834432298 |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| #89 | https://github.com/posit-dev/ggsql/pull/89 |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| https://patch-diff.githubusercontent.com/georgestagg |
| georgestagg | https://patch-diff.githubusercontent.com/georgestagg |
|
Feb 2, 2026
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#pullrequestreview-3738762319 |
|
View reviewed changes
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/files/84091f6fb7eafcf9399755f91d0ebb945264cb5b |
| ggsql-python/python/ggsql/readers.py | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/files/84091f6fb7eafcf9399755f91d0ebb945264cb5b#diff-53c44ed8078cd8febbefd0c65d7939a7ea8f3a4bae3d3c24157a2e6a3ced0af4 |
| georgestagg | https://patch-diff.githubusercontent.com/georgestagg |
| Feb 2, 2026 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#discussion_r2753810936 |
| Learn more | https://docs.github.com/articles/managing-disruptive-comments/#hiding-a-comment |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| https://patch-diff.githubusercontent.com/cpsievert |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| Feb 2, 2026 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#issuecomment-3835992226 |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
| https://patch-diff.githubusercontent.com/cpsievert |
| cpsievert | https://patch-diff.githubusercontent.com/cpsievert |
| Feb 2, 2026 | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90#event-22469896773 |
| Sign up for free | https://patch-diff.githubusercontent.com/join?source=comment-repo |
| Sign in to comment | https://patch-diff.githubusercontent.com/login?return_to=https%3A%2F%2Fgithub.com%2Fposit-dev%2Fggsql%2Fpull%2F90 |
|
| https://patch-diff.githubusercontent.com/georgestagg |
|
georgestagg
| https://patch-diff.githubusercontent.com/georgestagg |
|
| https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90/files/84091f6fb7eafcf9399755f91d0ebb945264cb5b |
| Please reload this page | https://patch-diff.githubusercontent.com/posit-dev/ggsql/pull/90 |
|
| https://patch-diff.githubusercontent.com/cpsievert |
|
| https://patch-diff.githubusercontent.com/georgestagg |
|
| https://github.com |
| Terms | https://docs.github.com/site-policy/github-terms/github-terms-of-service |
| Privacy | https://docs.github.com/site-policy/privacy-policies/github-privacy-statement |
| Security | https://github.com/security |
| Status | https://www.githubstatus.com/ |
| Community | https://github.community/ |
| Docs | https://docs.github.com/ |
| Contact | https://support.github.com?tags=dotcom-footer |