René's URL Explorer Experiment


Title: [RFC] Rust name or Python name? · Issue #3284 · RustPython/RustPython · GitHub

Open Graph Title: [RFC] Rust name or Python name? · Issue #3284 · RustPython/RustPython

X Title: [RFC] Rust name or Python name? · Issue #3284 · RustPython/RustPython

Description: Summary This is only about python objects like #[pymodule], #[pyclass], #[pyfunction], #[pymethod] and #[pyproperty]. Sometimes python names are not fit for rust naming convention. Though we can specify the name with (name = "") attribut...

Open Graph Description: Summary This is only about python objects like #[pymodule], #[pyclass], #[pyfunction], #[pymethod] and #[pyproperty]. Sometimes python names are not fit for rust naming convention. Though we can sp...

X Description: Summary This is only about python objects like #[pymodule], #[pyclass], #[pyfunction], #[pymethod] and #[pyproperty]. Sometimes python names are not fit for rust naming convention. Though we can sp...

Opengraph URL: https://github.com/RustPython/RustPython/issues/3284

X: @github

direct link

Domain: github.com


Hey, it has json ld scripts:
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"[RFC] Rust name or Python name?","articleBody":"## Summary\r\n\r\nThis is only about python objects like `#[pymodule]`, `#[pyclass]`, `#[pyfunction]`, `#[pymethod]` and `#[pyproperty]`.\r\nSometimes python names are not fit for rust naming convention.\r\n\r\n1. Though we can specify the name with `(name = \"\")` attributes, we also need to decide how we give names for its rust side API.\r\n2. There are also python names conflict to rust keywords. They also need a special rule because we normally cannot name them same in Rust.\r\n\r\n## Detailed Explanation\r\n\r\nList of unmatching names.\r\n\r\n1. Python type `int` is type `PyInt` in Rust API.\r\n2. Python function `posix.WIFSIGNALED` is `posix::wifsignaled` in Rust.\r\n3. Python type `_struct.error` is PyTypeRef object `pystruct::error_type` in Rust.\r\n4. Python type `_weakref.ReferenceType` is a function returning PyTypeRef `_weakref::reference_type` in Rust.\r\n4. Python variable `sys.api_version` is const `sys::API_VERSION` in Rust.\r\n5. Python variable `dis.COMPILER_FLAG_NAMES` is a function returning PyDictRef `dis::compiler_flag_names` in Rust.\r\n\r\nWe must handle types differently.\r\nFor example, we can expose `\u0026PyTypeRef` for `builtins::int()` but `PyInt` through `builtins::PyInt`.\r\n\r\nWe can choose one of these kind of options for other names:\r\n1. Strictly follow Python names unless it is impossible.\r\n  - The names will not conflict.\r\n  - Some names will be `r#` prefixed in Rust. They would need human-friendly aliases.\r\n2. Follow Python names as much as possible but with exceptions by its paired Rust type.\r\n  - For example, `_weakref.ReferenceType` and `int` are both type in Python but `PyTypeRef` instance and `PyInt` struct for each in Rust. Similar for sys.api_version and dis.COMPILER_FLAG_NAMES\r\n3. Export a python-name aliased module separately. This can be generated by `derive` macros.\r\n  - For this choice, we can optionally suggest more consistency.\r\n    1. We can expose variable always through a function call. A function to return a const will be generated.\r\n    2. We can attach emitted `vm` parameter again to functions.\r\n  - Still types will be problem.\r\n\r\nList of keyword conflict.\r\n1. `struct` module.\r\n  - The exact python name is `_struct`\r\n2. `mod` operator.\r\n  - The exact python name is `__mod__`\r\n3. `match` function.\r\n4. `type` type.\r\n5. `enum` module.\r\n\r\nList of confusing non-keyword names.\r\n1. `bool` types\r\n2. `str` types\r\n3. `Iterator` for python and rust\r\n\r\nExample of solutions\r\n1. Always keep python name using `r#`. But allow alias.\r\n2. Add additional `_` suffix for conflicting type. `match` will be `match_`. But allow `r#` alias.\r\n3. Add `py` prefix like current `pybool`, `pytype`, `pystruct`.\r\n\r\n\u003c!-- Elaborate on your suggestion in all its details --\u003e\r\n\r\n## Drawbacks, Rationale, and Alternatives\r\n\r\n\u003c!-- What drawbacks might this solution have? Why do you feel it is necessary? What other options might there be to solving this problem? --\u003e\r\n\r\n## Unresolved Questions\r\n\r\n\u003c!-- What would you like feedback on for fleshing out your suggestion? --\u003e\r\nEverything. Any dicision will give concrete idea about public API design.","author":{"url":"https://github.com/youknowone","@type":"Person","name":"youknowone"},"datePublished":"2021-10-12T20:08:11.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":1},"url":"https://github.com/3284/RustPython/issues/3284"}

route-pattern/_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format)
route-controllervoltron_issues_fragments
route-actionissue_layout
fetch-noncev2:6d350465-2bd4-915d-5a4e-d28c0a7f6d16
current-catalog-service-hash81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114
request-id912C:62C58:6F1574:9D7626:696F8729
html-safe-noncef64b329a1a793e81a250533d40f4098babb01ed791e84ce40e33612221ad5e4e
visitor-payloadeyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5MTJDOjYyQzU4OjZGMTU3NDo5RDc2MjY6Njk2Rjg3MjkiLCJ2aXNpdG9yX2lkIjoiNTE3NzI0ODQ2MDQ4OTg1MjcxMyIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9
visitor-hmac5a69d520abdbc63c422e49c007bb46f93e710a099faed05b6392245c75e241db
hovercard-subject-tagissue:1024289890
github-keyboard-shortcutsrepository,issues,copilot
google-site-verificationApib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I
octolytics-urlhttps://collector.github.com/github/collect
analytics-location///voltron/issues_fragments/issue_layout
fb:app_id1401488693436528
apple-itunes-appapp-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/RustPython/RustPython/3284/issue_layout
twitter:imagehttps://opengraph.githubassets.com/fd134f7ec733232ee6747153000dcf01ddb1770883b480cbb5b222fc7f74751f/RustPython/RustPython/issues/3284
twitter:cardsummary_large_image
og:imagehttps://opengraph.githubassets.com/fd134f7ec733232ee6747153000dcf01ddb1770883b480cbb5b222fc7f74751f/RustPython/RustPython/issues/3284
og:image:altSummary This is only about python objects like #[pymodule], #[pyclass], #[pyfunction], #[pymethod] and #[pyproperty]. Sometimes python names are not fit for rust naming convention. Though we can sp...
og:image:width1200
og:image:height600
og:site_nameGitHub
og:typeobject
og:author:usernameyouknowone
hostnamegithub.com
expected-hostnamegithub.com
Nonec1b02b4e3a8edff2fe0bd71b0551654be66034591c7ab65aaaaf61a6096862d3
turbo-cache-controlno-preview
go-importgithub.com/RustPython/RustPython git https://github.com/RustPython/RustPython.git
octolytics-dimension-user_id39710557
octolytics-dimension-user_loginRustPython
octolytics-dimension-repository_id135201145
octolytics-dimension-repository_nwoRustPython/RustPython
octolytics-dimension-repository_publictrue
octolytics-dimension-repository_is_forkfalse
octolytics-dimension-repository_network_root_id135201145
octolytics-dimension-repository_network_root_nwoRustPython/RustPython
turbo-body-classeslogged-out env-production page-responsive
disable-turbofalse
browser-stats-urlhttps://api.github.com/_private/browser/stats
browser-errors-urlhttps://api.github.com/_private/browser/errors
release4a1073fcc34432ac33cec03885ff2d96920686de
ui-targetfull
theme-color#1e2327
color-schemelight dark

Links:

Skip to contenthttps://github.com/RustPython/RustPython/issues/3284#start-of-content
https://github.com/
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2FRustPython%2FRustPython%2Fissues%2F3284
GitHub CopilotWrite better code with AIhttps://github.com/features/copilot
GitHub SparkBuild and deploy intelligent appshttps://github.com/features/spark
GitHub ModelsManage and compare promptshttps://github.com/features/models
MCP RegistryNewIntegrate external toolshttps://github.com/mcp
ActionsAutomate any workflowhttps://github.com/features/actions
CodespacesInstant dev environmentshttps://github.com/features/codespaces
IssuesPlan and track workhttps://github.com/features/issues
Code ReviewManage code changeshttps://github.com/features/code-review
GitHub Advanced SecurityFind and fix vulnerabilitieshttps://github.com/security/advanced-security
Code securitySecure your code as you buildhttps://github.com/security/advanced-security/code-security
Secret protectionStop leaks before they starthttps://github.com/security/advanced-security/secret-protection
Why GitHubhttps://github.com/why-github
Documentationhttps://docs.github.com
Bloghttps://github.blog
Changeloghttps://github.blog/changelog
Marketplacehttps://github.com/marketplace
View all featureshttps://github.com/features
Enterpriseshttps://github.com/enterprise
Small and medium teamshttps://github.com/team
Startupshttps://github.com/enterprise/startups
Nonprofitshttps://github.com/solutions/industry/nonprofits
App Modernizationhttps://github.com/solutions/use-case/app-modernization
DevSecOpshttps://github.com/solutions/use-case/devsecops
DevOpshttps://github.com/solutions/use-case/devops
CI/CDhttps://github.com/solutions/use-case/ci-cd
View all use caseshttps://github.com/solutions/use-case
Healthcarehttps://github.com/solutions/industry/healthcare
Financial serviceshttps://github.com/solutions/industry/financial-services
Manufacturinghttps://github.com/solutions/industry/manufacturing
Governmenthttps://github.com/solutions/industry/government
View all industrieshttps://github.com/solutions/industry
View all solutionshttps://github.com/solutions
AIhttps://github.com/resources/articles?topic=ai
Software Developmenthttps://github.com/resources/articles?topic=software-development
DevOpshttps://github.com/resources/articles?topic=devops
Securityhttps://github.com/resources/articles?topic=security
View all topicshttps://github.com/resources/articles
Customer storieshttps://github.com/customer-stories
Events & webinarshttps://github.com/resources/events
Ebooks & reportshttps://github.com/resources/whitepapers
Business insightshttps://github.com/solutions/executive-insights
GitHub Skillshttps://skills.github.com
Documentationhttps://docs.github.com
Customer supporthttps://support.github.com
Community forumhttps://github.com/orgs/community/discussions
Trust centerhttps://github.com/trust-center
Partnershttps://github.com/partners
GitHub SponsorsFund open source developershttps://github.com/sponsors
Security Labhttps://securitylab.github.com
Maintainer Communityhttps://maintainers.github.com
Acceleratorhttps://github.com/accelerator
Archive Programhttps://archiveprogram.github.com
Topicshttps://github.com/topics
Trendinghttps://github.com/trending
Collectionshttps://github.com/collections
Enterprise platformAI-powered developer platformhttps://github.com/enterprise
GitHub Advanced SecurityEnterprise-grade security featureshttps://github.com/security/advanced-security
Copilot for BusinessEnterprise-grade AI featureshttps://github.com/features/copilot/copilot-business
Premium SupportEnterprise-grade 24/7 supporthttps://github.com/premium-support
Pricinghttps://github.com/pricing
Search syntax tipshttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
documentationhttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2FRustPython%2FRustPython%2Fissues%2F3284
Sign up https://github.com/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fvoltron%2Fissues_fragments%2Fissue_layout&source=header-repo&source_repo=RustPython%2FRustPython
Reloadhttps://github.com/RustPython/RustPython/issues/3284
Reloadhttps://github.com/RustPython/RustPython/issues/3284
Reloadhttps://github.com/RustPython/RustPython/issues/3284
RustPython https://github.com/RustPython
RustPythonhttps://github.com/RustPython/RustPython
Notifications https://github.com/login?return_to=%2FRustPython%2FRustPython
Fork 1.4k https://github.com/login?return_to=%2FRustPython%2FRustPython
Star 21.7k https://github.com/login?return_to=%2FRustPython%2FRustPython
Code https://github.com/RustPython/RustPython
Issues 276 https://github.com/RustPython/RustPython/issues
Pull requests 93 https://github.com/RustPython/RustPython/pulls
Discussions https://github.com/RustPython/RustPython/discussions
Actions https://github.com/RustPython/RustPython/actions
Projects 0 https://github.com/RustPython/RustPython/projects
Wiki https://github.com/RustPython/RustPython/wiki
Security Uh oh! There was an error while loading. Please reload this page. https://github.com/RustPython/RustPython/security
Please reload this pagehttps://github.com/RustPython/RustPython/issues/3284
Insights https://github.com/RustPython/RustPython/pulse
Code https://github.com/RustPython/RustPython
Issues https://github.com/RustPython/RustPython/issues
Pull requests https://github.com/RustPython/RustPython/pulls
Discussions https://github.com/RustPython/RustPython/discussions
Actions https://github.com/RustPython/RustPython/actions
Projects https://github.com/RustPython/RustPython/projects
Wiki https://github.com/RustPython/RustPython/wiki
Security https://github.com/RustPython/RustPython/security
Insights https://github.com/RustPython/RustPython/pulse
New issuehttps://github.com/login?return_to=https://github.com/RustPython/RustPython/issues/3284
New issuehttps://github.com/login?return_to=https://github.com/RustPython/RustPython/issues/3284
[RFC] Rust name or Python name?https://github.com/RustPython/RustPython/issues/3284#top
RFCRequest for commentshttps://github.com/RustPython/RustPython/issues?q=state%3Aopen%20label%3A%22RFC%22
https://github.com/youknowone
https://github.com/youknowone
youknowonehttps://github.com/youknowone
on Oct 12, 2021https://github.com/RustPython/RustPython/issues/3284#issue-1024289890
RFCRequest for commentshttps://github.com/RustPython/RustPython/issues?q=state%3Aopen%20label%3A%22RFC%22
https://github.com
Termshttps://docs.github.com/site-policy/github-terms/github-terms-of-service
Privacyhttps://docs.github.com/site-policy/privacy-policies/github-privacy-statement
Securityhttps://github.com/security
Statushttps://www.githubstatus.com/
Communityhttps://github.community/
Docshttps://docs.github.com/
Contacthttps://support.github.com?tags=dotcom-footer

Viewport: width=device-width


URLs of crawlers that visited me.