skills/adonaivera/fiftyone-code-style/SKILL.md
Write Python code following FiftyOne's official conventions. Use when contributing to FiftyOne, developing plugins, or writing code that integrates with FiftyOne's codebase.
npx skillsauth add aiskillstore/marketplace fiftyone-code-styleInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
"""
Module description.
| Copyright 2017-2025, Voxel51, Inc.
| `voxel51.com <https://voxel51.com/>`_
|
"""
# Standard library
import logging
import os
# Third-party
import numpy as np
# eta (Voxel51 utilities)
import eta.core.utils as etau
# FiftyOne
import fiftyone.core.fields as fof
import fiftyone.core.labels as fol
import fiftyone.core.utils as fou
logger = logging.getLogger(__name__)
def public_function(arg):
"""Public API function."""
return _helper(arg)
def _helper(arg):
"""Private helper (underscore prefix)."""
return arg
Four groups, alphabetized within each:
| Group | Example |
|-------|---------|
| 1. Standard library | import logging, import os |
| 2. Third-party | import numpy as np, from PIL import Image |
| 3. eta packages | import eta.core.utils as etau |
| 4. FiftyOne | import fiftyone.core.labels as fol |
| Module | Alias |
|--------|-------|
| fiftyone | fo |
| fiftyone.core.labels | fol |
| fiftyone.core.fields | fof |
| fiftyone.core.media | fom |
| fiftyone.core.storage | fos |
| fiftyone.core.utils | fou |
| fiftyone.utils.image | foui |
| fiftyone.utils.video | fouv |
def get_operator(operator_uri, enabled=True):
"""Gets the operator with the given URI.
Args:
operator_uri: the operator URI
enabled (True): whether to include only enabled operators (True) or
only disabled operators (False) or all operators ("all")
Returns:
an :class:`fiftyone.operators.Operator`
Raises:
ValueError: if the operator is not found
"""
class ImageMetadata(Metadata):
"""Class for storing metadata about image samples.
Args:
size_bytes (None): the size of the image on disk, in bytes
mime_type (None): the MIME type of the image
width (None): the width of the image, in pixels
height (None): the height of the image, in pixels
"""
Key patterns:
param (default): description:class:fiftyone.module.Class``# Public API delegates to private helper
def build_for(cls, path_or_url, mime_type=None):
"""Builds a Metadata object for the given file."""
if path_or_url.startswith("http"):
return cls._build_for_url(path_or_url, mime_type=mime_type)
return cls._build_for_local(path_or_url, mime_type=mime_type)
# Private: underscore prefix, focused purpose
def _build_for_local(cls, filepath, mime_type=None):
"""Internal helper for local files."""
size_bytes = os.path.getsize(filepath)
if mime_type is None:
mime_type = etau.guess_mime_type(filepath)
return cls(size_bytes=size_bytes, mime_type=mime_type)
Use fou.lazy_import() for optional/heavy dependencies:
# Basic lazy import
o3d = fou.lazy_import("open3d", callback=lambda: fou.ensure_package("open3d"))
# With ensure_import for pycocotools
mask_utils = fou.lazy_import(
"pycocotools.mask", callback=lambda: fou.ensure_import("pycocotools")
)
# Internal module lazy import
fop = fou.lazy_import("fiftyone.core.plots.plotly")
When to use:
Use hasattr() for conditional behavior:
# Check for optional attribute
if hasattr(label, "confidence"):
if label.confidence is None or label.confidence < threshold:
label = label.__class__()
# Check for config attribute
if hasattr(eval_info.config, "iscrowd"):
crowd_attr = eval_info.config.iscrowd
else:
crowd_attr = None
# Dynamic state initialization
if not hasattr(pb, "_next_idx"):
pb._next_idx = 0
pb._next_iters = []
Use logger.warning() for non-fatal errors:
# Non-fatal: warn and continue
try:
for target in fo.config.logging_debug_targets.split(","):
if logger_name := target.strip():
loggers.append(logging.getLogger(logger_name))
except Exception as e:
logger.warning(
"Failed to parse logging debug targets '%s': %s",
fo.config.logging_debug_targets,
e,
)
# Missing optional import
try:
import resource
except ImportError as e:
if warn_on_failure:
logger.warning(e)
return
# Graceful fallback
try:
mask = etai.render_instance_image(dobj.mask, dobj.bounding_box, frame_size)
except:
width, height = frame_size
mask = np.zeros((height, width), dtype=bool)
Before writing new functions, check if FiftyOne already provides the functionality.
fiftyone.core.utils (fou)| Function | Purpose |
|----------|---------|
| fou.lazy_import() | Lazy module loading |
| fou.ensure_package() | Install missing package |
| fou.ensure_import() | Verify import available |
| fou.extract_kwargs_for_class() | Split kwargs for class |
| fou.load_xml_as_dict() | Parse XML to dict |
| fou.get_default_executor() | Get thread pool executor |
eta.core.utils (etau)| Function | Purpose |
|----------|---------|
| etau.guess_mime_type() | Detect file MIME type |
| etau.is_str() | Check if string |
| etau.ensure_dir() | Create directory if missing |
| etau.ensure_basedir() | Create parent directory |
| etau.make_temp_dir() | Create temp directory |
Search existing modules for similar functionality:
grep -r "def your_function_name" fiftyone/
grep -r "similar_keyword" fiftyone/core/utils.py
Check these modules first:
fiftyone.core.utils - General utilitiesfiftyone.core.storage - File/cloud operationsfiftyone.utils.* - Format-specific utilitieseta.core.utils - Low-level helpersRed flags for redundancy:
os.path or etaueta.core.serialfiftyone.utils.imageetau.is_str(), etc.Before submitting code, verify:
logger = logging.getLogger(__name__)_fou.lazy_import()hasattr() guardslogger.warning()except: (specify exception type when possible)# Run linting
pylint fiftyone/your_module.py
# Check style
black --check fiftyone/your_module.py
# Run tests
pytest tests/unittests/your_test.py -v
| Pattern | Convention |
|---------|------------|
| Module structure | Docstring → imports → logger → public → private → classes |
| Private functions | _prefix, module-level, small & focused |
| Docstrings | Google-style with Args/Returns/Raises |
| Error handling | try/except + logger.warning() for non-fatal |
| Lazy imports | fou.lazy_import() for optional deps |
| Guard patterns | hasattr() checks for conditional behavior |
| Import aliases | fol, fof, fom, fos, fou |
| Constants | UPPERCASE, private: _UPPERCASE |
| Class inheritance | Explicit class Foo(object): |
| Redundancy check | Search fou, etau, existing modules first |
development
Apple Human Interface Guidelines for content display components. Use this skill when the user asks about charts component, collection view, image view, web view, color well, image well, activity view, lockup, data visualization, content display, displaying images, rendering web content, color pickers, or presenting collections of items in Apple apps. Also use when the user says how should I display charts, what's the best way to show images, should I use a web view, how do I build a grid of items, what component shows media, or how do I present a share sheet. Cross-references: hig-foundations for color/typography/accessibility, hig-patterns for data visualization patterns, hig-components-layout for structural containers, hig-platforms for platform-specific component behavior.
tools
Automate HelpDesk tasks via Rube MCP (Composio): list tickets, manage views, use canned responses, and configure custom fields. Always search tools first for current schemas.
testing
Expert Haskell engineer specializing in advanced type systems, pure functional design, and high-reliability software. Use PROACTIVELY for type-level programming, concurrency, and architecture guidance.
tools
GraphQL gives clients exactly the data they need - no more, no less. One endpoint, typed schema, introspection. But the flexibility that makes it powerful also makes it dangerous. Without proper controls, clients can craft queries that bring down your server. This skill covers schema design, resolvers, DataLoader for N+1 prevention, federation for microservices, and client integration with Apollo/urql. Key insight: GraphQL is a contract. The schema is the API documentation. Design it carefully.